System for automatically configuring a server after hot add of a device

Information

  • Patent Grant
  • 6263387
  • Patent Number
    6,263,387
  • Date Filed
    Wednesday, October 1, 1997
    27 years ago
  • Date Issued
    Tuesday, July 17, 2001
    23 years ago
Abstract
A system for automatically configuring a computer system, after a device has been hot added to the computer system, which includes the following elements: a detection module which automatically detects a hot added device; a first configuration module which automatically configures the device; an identification module which automatically identifies a device type for the device; a location module which automatically determines the location where the device has been hot added; a driver module which automatically loads a driver corresponding to the hot added device; and a second configuration module which automatically modifies a configuration file so as to integrate the hot added device into the system.
Description




APPENDICES




Appendix A, which forms a part of this disclosure, is a list of commonly owned copending U.S. patent applications. Each one of the applications listed in Appendix A is hereby incorporated herein in its entirety by reference thereto.




COPYRIGHT RIGHTS




A portion of the disclosure of this patent document contains material which is subject to copyright protection. The copyright owner has no objection to the facsimile reproduction by anyone of the patent document or the patent disclosure, as it appears in the Patent and Trademark Office patent files or records, but otherwise reserves all copyright rights whatsoever.




BACKGROUND OF THE INVENTION




1. Field of the Invention




The invention relates to reducing down-time in computer systems. More particularly, the invention relates to a method and system for adding and/or replacing a device in a file server computer, without having to power down the server computer, and automatically configuring the server computer so as to integrate the device into the server system.




2. Description of the Related Technology




In the computer industry, the reduction of computer failures and computer “downtime” is a major focus for companies trying to achieve a competitive edge over their competitors. The reduction of downtime due to system failures and maintenance is critical to providing quality performance and product reliability to the users and buyers of computer systems. Particularly with respect to server computers which are accessed and utilized by many end users, the reduction of server downtime is an extremely desirable performance characteristic. This is especially true for users who depend on the server to obtain data and information in their daily business operations.




As servers become more powerful, they are also becoming more sophisticated and complex. A server is typically a central computer in a computer network which manages common data that may be accessed by other computers, otherwise known as “workstations,” in the network. Server downtime, resulting from hardware or software faults or from repair and maintenance, continues to be a significant problem today. By one estimate, the cost of downtime in mission critical environments has risen to an annual total of $4.0 billion for U.S. businesses, with the average downtime event resulting in a $140 thousand loss in the retail industry and a $450 thousand loss in the securities industry. It has been reported that companies lose as much as $250 thousand in employee productivity for every 1% of computer downtime. With emerging Internet, intranet and collaborative applications taking on more essential business roles every day, the cost of network server downtime will continue to spiral upward.




While early detection and correction of system faults is an important element of an overall high reliability architecture, it is only one piece of the puzzle. Studies show that a significant percentage of network server downtime is due to repair and/or maintenance of the server system, in which defective hardware components must be replaced or new components must be added to upgrade the system. Typical prior art methods for replacing and/or adding new devices, such as a PCI adapter card, for example, involve powering down the entire server, locating the port where the device needs to be replaced or added, replacing or adding the device, powering up the server system, configuring the device, and thereafter, configuring the system so as to permanently integrate the device into the system. The process of configuring the system involves loading appropriate drivers, modifying start-up files, and establishing communication protocols, as necessary, such that the new device is recognized and initialized upon subsequent reboots of the system. This process is tedious and time-consuming and can result in hours of server downtime depending on the nature of the changes made to the server system. Additionally, this manual, human-centered approach often results in configuration errors which further adds to server downtime.




One method of replacing and/or adding devices in a computer system, without first powering down the system, is known as “Hot Plug”, otherwise known as “Hot Swap and Add”. In this method and system, in order to replace an old adapter card with a new one, or add a new adapter card to the system, only a particular slot in which a new or replacement adapter is to be inserted is powered down, while the remaining slots, components, devices, and subsystems of the server remain operational. Therefore, server operation and service to existing customers is not disrupted. One method and system of hot adding devices in a server system is described in further detail in a co-pending and commonly owned U.S. patent application Ser. No. 08/942,309, entitled “Hot Add of Devices Software Architecture,” which is listed in Appendix A attached hereto.




In another embodiment of the hot plug method and system, a “canister”, connected to a PCI bus of the server system, is powered down, rather than powering down the entire server. Canisters are detachable housing modules which interface with a main system board and a “backplane” board in the server system. These canisters can typically house up to four adapter cards, which may be inserted into bus slots within each canister. Each adapter card is capable of communicating to a system device, such as a CD ROM drive. The structure and functionality of a canister allows a server system to be easily upgraded in capacity or repaired by allowing easy adding and swapping of adapter cards into the bus slots within each canister. The structure and functionality of the canister is described in further detail in a co-pending and commonly owned U.S. patent application Ser. No. 08/942,194, entitled “Fault Tolerant Computer System,” which is listed in Appendix A attached hereto.




As used herein, the term “device”, “adapter card” or “adapter” are used synonymously and interchangeably and may refer to any electronic element, component, subsystem, or circuit that may be coupled to a bus system of the server and which may be programmed or configured to communicate data to one or more other entities in the server system. Additionally, as used herein, the term “module” refers to any software program, subprogram, subroutine of a program, or software code capable of performing a specified function.




In the hot plug methods and system discussed above, after an adapter has been hot added to the server system, the adapter must be configured in order to communicate with other devices in the server in accordance with a specified communication protocol. The adapter configuration process includes updating a configuration space within the adapter with a configuration manager program and programming the adapter's registers with appropriate memory, I/O and interrupt parameters, after power to the adapter has been turned on. A method for performing this adapter configuration process is described in further detail in a co-pending and commonly owned U.S. patent application Ser. No. 08/941,268, entitled, “Configuration Management Method For Hot Adding and Hot Replacing Devices,” which is listed in Appendix A attached hereto.




However, after the configuration of the adapter is completed, the process does not end there. A system operator must still reconfigure the server system in order to permanently incorporate the new adapter into the system such that it is initialized upon subsequent reboots of the system. Prior art methods of reconfiguring the server, after a new device has been added to the system, typically require a system operator to manually select and load an appropriate driver for the newly added device, and thereafter, modify start-up configuration files by retrieving the files and inputting appropriate configuration parameters corresponding to the newly added device. If the new device is a LAN card, for example, an additional step of “binding the network protocol” of the device must be performed. The term “binding the network protocol”, and its meaning, is well-known in the art. This prior art configuration process can be time-consuming and tedious, especially for a system operator who is not familiar with the configuration requirements of the server as well as the newly added device. In such circumstances, the system operator often makes mistakes in performing one or more of the configuration steps. These mistakes may lead to serious errors in server operation and result in additional downtime of the server.




A related technology, not to be confused with hot plug systems, is Plug and Play defined by Microsoft and personal computer (PC) product vendors. Plug and Play is an architecture that facilitates the integration of PC hardware devices to systems that are not powered. Plug and Play devices are able to identify themselves to the computer system after the user installs the device on the bus. Plug and Play devices are also able to identify the hardware resources that they need for operation. Once this information is supplied to the operating system, the operating system can load the device drivers for the device that the user had added while the system was in a non-powered state.




However, plug and play is not designed for hot add applications in server systems. Rather, plug and play devices are typically inserted into a PC when the PC is turned off. Plug and Play does not provide a method of automatically detecting newly added devices while the system is in a constant powered state and thereafter automatically configuring the system so as to permanently integrate the newly hot added device into the system. Plug and Play performs configuration functions only after a device has been inserted into a computer that is powered off and subsequently powered on.




Therefore, a method and system is needed which can not only provide hot pluggability in a server system, but which can also automatically reconfigure the server system so as to integrate hot added devices into the server system, without disrupting system operations and service to existing users. Additionally, there is a need to further reduce server downtime by reducing configuration errors commonly made by prior art manual, human-centered approaches to configuring the server after new devices have been added to the system.




SUMMARY OF THE INVENTION




The invention addresses the above and other needs by providing a method and system in which a server system is automatically reconfigured after a hot add of a device into the server system so as to integrate the hot added device into the system such that it is recognized and initialized upon subsequent reboots of the server system.




In one embodiment of the invention, a system for automatically configuring a computer system, includes: a detection module which automatically detects a hot added device; a first configuration module which automatically configures the device; an identification module which automatically identifies a device type for the device; a location module which automatically determines the location where the device has been hot added; a driver module which automatically loads a driver corresponding to the hot added device; and a second configuration module which automatically modifies a configuration file so as to integrate the hot added device into the system.




In another embodiment, a system of automatically configuring a server system after a device has been hot added to the system, includes: a first scanning module which scans a system bus in order to identify all devices connected to the bus; a compare module which compares a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; a first configuration module which configures the device; a vendor module which retrieves a Device ID and Vendor ID from the device so as to identify the type of device; a second scanning module which scans the system bus for any devices which have a hardware instance number (HIN); a HIN module which obtains a hardware instance number (HIN) from the hot added device; a recording module which records a slot number and the hardware instance number of the device; a driver module which loads a driver corresponding to the hot added device; a LAN module which determines whether the hot added device is local area network (LAN) device; and a second configuration module which modifies a configuration file, wherein, if it is determined that the hot added device is not a LAN device, a first configuration file is modified, and if it is determined that the hot added device is a LAN device, a second configuration file is modified.




In a further embodiment, a system for automatically configuring a computer system, includes: means for automatically detecting the hot added device; means for automatically configuring the device; means for automatically identifying the type of device; means for automatically determining the location where the device has been hot added; means for automatically loading a driver corresponding to the hot added device; and means for automatically modifying a configuration file so as to integrate the hot added device into the system.




In a further embodiment, a system of automatically configuring a server system after a device has been hot added to the system, comprising: means for scanning a system bus in order to identify all devices connected to the bus; means for comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; means for configuring the device; means for retrieving a Device ID and Vendor ID from the device so as to identify a device type; means for scanning the system bus for any devices which have a hardware instance number (HIN); means for obtaining a hardware instance number (HIN) from the hot added device; means for recording a slot number and the hardware instance number of the device; means for loading a driver corresponding to the hot added device; means for determining whether the hot added device is local area network (LAN) device; and means for configuring the server so as to integrate the hot added device into the server system, wherein if it is determined that the hot added device is not a LAN device, a first configuration file is modified, and if it is determined that the hot added device is a LAN device, a second configuration file is modified.




In another embodiment, a program storage device which stores instructions that when executed by a computer perform a method which includes the acts of: automatically detecting the hot added device; automatically configuring the device; automatically identifying a device type for the device; automatically determining the location where the device has been hot added; automatically loading a driver corresponding to the hot added device; and automatically modifying a configuration file so as to integrate the hot added device into the system.




In yet a further embodiment, the invention provides a program storage device which stores instructions that when executed by a computer perform a method of automatically configuring a server system after a device has been hot added to the system, wherein the method includes: scanning a system bus in order to identify all devices connected to the bus; comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; configuring the device; retrieving a Device ID and Vendor ID from the device so as to identify the type of device; scanning the system bus for any devices which have a hardware instance number (HIN); obtaining a hardware instance number (HIN) from the hot added device; recording a slot number and the hardware instance number of the device; loading a driver corresponding to the hot added device; determining whether the hot added device is local area network (LAN) device; if it is determined that the hot added device is not a LAN device, modifying a first configuration file; and if it is determined that the hot added device is a LAN device, binding a network protocol of the device and modifying a second configuration file.











BRIEF DESCRIPTION OF THE DRAWINGS





FIG. 1

is a top level block diagram of a fileserver computer system in which hot pluggability and automatic configuration may be implemented, in accordance with one embodiment the invention.





FIG. 2

is a block diagram of one embodiment of a multiple bus architecture for the server system of FIG.


1


.





FIG. 3

is a block diagram of an alternative embodiment of a multiple bus computer architecture for the server system of FIG.


1


.





FIG. 4

is a block diagram illustrating some of the subsystems of the server system of FIG.


1


.





FIG. 5

is a block diagram illustrating components of Novell NetWare's Operating System and one embodiment of a configuration manager which both reside within the server computer of FIG.


1


.





FIG. 6

is a flowchart diagram illustrating one embodiment of a process by which a user performs a hot add of a device into a slot of the server computer of FIG.


1


.





FIG. 7

is a flowchart diagram showing one process by which a user performs a hot add of a card into a canister on the server computer of FIG.


1


.





FIG. 8

is a flowchart diagram illustrating one process of automatically configuring a server system so as to integrate a hot added device into the system, in accordance with one embodiment of the invention.











DETAILED DESCRIPTION OF THE INVENTION




The invention is described in detail below with reference to the figures, wherein like parts are referenced with like numerals throughout.





FIG. 1

is a block diagram of one embodiment of a server system


100


in which hot pluggability and automatic configuration may be implemented. Typically, a server plays the role of a central computer in a computer network which manages a central database. This central database is accessed by multiple client computers, otherwise known as “workstations,” connected to the computer network. The server system


100


includes a computer


101


connected to a mass storage adapter


102


and a network adapter


104


. The network adapter


104


may be a Local Area Network (LAN) card, for example, which is well-known in the art. The mass storage adapter


102


may interface with one or more various types of device controllers: a magnetic disk controller


108


for magnetic disks


110


, an optical disk controller


112


for optical disks


114


, a magnetic tape controller


116


for magnetic tapes


118


, a printer controller


120


for various printers


122


, and any other type of controller


124


for other devices


126


.




The peripheral devices communicate and are connected to the adapter


102


by a mass storage bus


106


. In one embodiment, the bus


106


is a Small Computer System Interface (SCSI) bus. In a typical server configuration there is more than one mass storage adapter. The adapters and devices mentioned above may be off-the-shelf products. For instance, sample vendors for a magnetic disk controller


108


and magnetic disks


110


include Qlogic and Adaptec. Each magnetic hard disk may hold multiple Gigabytes of data.




The network adapter


104


typically includes a network controller


128


. The network adapter


104


, also sometimes referred to as a network interface card (NIC), allows digital communication between the server system


100


and other computers (not shown) such as a network of servers and workstations via a connection


130


. For LAN embodiments of the network adapter, the protocol used may be, for example, Ethernet, token ring, Fiber Distributed Datalink Interface (FDDI) or Asynchronous Transfer Mode (ATM). Typically, the mass storage adapter


102


and the network adapter


104


are connected to the computer using a standards-based bus system such as those provided by Peripheral Component Interconnect (PCI), Microchannel, SCSI, Industrial Standard Architecture (ISA) and Extended ISA (EISA) architectures.





FIG. 2

shows one embodiment of the bus structure of the server system


100


of

FIG. 1. A

number of central processing units (CPUs)


200


are connected through a host bus


202


to a memory controller


204


, which allows for access to semiconductor memory by the other system components. In one embodiment, there are four CPUs


200


, each being an Intel Pentium microprocessor. A number of bridges


206


,


208


and


210


connect the host bus to three additional bus systems


212


,


214


, and


216


. The bus systems


212


,


214


and


216


, referred to as PC buses, may be any standards-based bus system such as PCI, ISA, EISA and Microchannel. In one embodiment, the bus system


212


is a peripheral component interface (PCI) bus. An ISA Bridge


218


is connected to the bus system


212


to support legacy devices such as a keyboard, one or more floppy disk drives and a mouse. A network of microcontrollers


225


is also interfaced to the ISA bus


226


to monitor and diagnose the environmental health of the server system. A more detailed description of the microcontroller network


225


is contained in a copending commonly owned U.S. patent application Ser. No. 08/942,402, entitled “Diagnostic and Managing Distributed Processor System”, which is listed in Appendix A attached hereto.




A bridge


230


and a bridge


232


connect, respectively, the PC bus


214


with PC bus


234


and the PC bus


216


with the PC bus


236


to provide expansion slots for peripheral devices or adapters. Separating the devices


238


and


240


, respectively, on PC buses


234


and


236


eliminates the potential that an adapter driver (not shown) or other transient I/O error will bring the entire system down or stop the system administrator from communicating with the system. The adapter devices


238


and


240


are electrically and mechanically connected to the PC Buses


234


and


236


by PC slots


241


. Hence, an adapter is “plugged” into a slot. In one embodiment each slot may be independently powered on and off.





FIG. 3

shows an alternative bus structure embodiment of the server system


100


of FIG.


1


. The two PC buses


214


and


216


contain a set of bridges


242


-


248


to a set of PC bus systems


250


-


256


. As with the PC buses


214


and


216


, the PC buses


250


-


256


can be designed according to any type of bus architecture including PCI, ISA, EISA, and Microchannel. The PC buses


250


-


256


are connected, respectively, to canisters


258


,


260


,


262


and


264


. As discussed above, the canisters


258


-


264


are housings for a detachable bus system and provide multiple PC slots


266


for additional adapters to be integrated into the system


100


. In one embodiment, each canister may be independently powered on and off.





FIG. 4

is a block diagram illustrating hardware and software components of the server system


100


relating to hot plugging an adapter. A hot plug user interface


302


accepts requests by a user such as a system manager or administrator to perform the hot add or a hot swap of an adapter


310


. The user interface


302


preferably communicates through an industry standard operating system


304


such as Windows NT or NetWare, to the hot plug system driver


306


and an adapter driver


308


.




The hot plug system driver


306


controls the adapter driver


308


for a hot plug operation. The hot plug system driver


306


stops and resumes the communications between the adapter


310


and the adapter driver


308


. During a hot add or swap of the adapter


310


, the hot plug hardware


312


deactivates the power to the PC slots


266


. One embodiment of the hot plug hardware


312


may include the network of microcontrollers


225


(

FIGS. 2 and 3

) to carry out this functionality.




The adapter


310


could be any type of peripheral device such as a network adapter, a mass storage adapter, a VGA adapter, a math co-processor, or a sound board. The adapter


310


is physically connected to the hot plug hardware by PC slots such as slots


266


.




Alternative embodiments of the server system may use other commercial operating systems, such as Macintosh O.S., OS/2, VMS, DOS, Windows® 3.1/95/98 or UNIX to support hot add and swap. The following sections describe hot pluggability under both a NetWare Operating System and WinNT operating system.

FIGS. 6 and 7

illustrate one embodiment of a generic process by which these operating systems can perform the hot add of devices. The process for hot add of an adapter under the NetWare Operating System is described with reference to

FIGS. 6 and 7

.




Adapter Hot Add with NetWare Operating System Implementation





FIG. 5

is a block diagram illustrating the system components of a NetWare Operating System and an embodiment of the software components of a hot add program. A configuration manager


500


is responsible for managing all of the adapters on the PC buses


234


and


236


(FIG.


2


), or


250


,


252


,


254


and


256


(FIG.


3


). The configuration manager


500


keeps track of the configuration information for every adapter located on the server system


100


. The configuration manager


500


also allocates resources for every adapter and initializes each adapter's registers during a hot add operation. The registers of an adapter


310


are components or intermediate memories whose values control a certain action in the adapter, or whose values indicate the status of the adapter.




Novell has created two interfaces for adapter drivers to communicate with the Netware Operating Systems (FIGS.


1


and


4


). First, Novell has provided the Open Datalink Interface (ODI) for network drivers. Second, Novell has created the Netware Peripheral Architecture (NWPA) for mass storage adapters. Each of these interfaces is described below.




With respect to network device drivers, such as a driver


524


, ODI was created to allow multiple LAN adapters, such as the adapter


104


to co-exist on network systems. The ODI specification describes the set of interface (

FIG. 1

) and software modules used by hardware vendors to interface with the NetWare operating system. At the core of the ODI is the link support layer (LSL)


502


. The LSL


502


is the interface between drivers and protocol stacks (not shown). Any LAN driver written to ODI specifications can communicate with any ODI protocol stack via the LSL


502


. A protocol stack is a layered communication architecture, whereby each layer has a well defined interface.




Novell has provided a set of support modules that provide the interface to the LSL


502


. These modules are a collection of procedures, macros and structures. These modules are the media support module (MSM)


504


which contains general functions common to all drivers and the topology specific modules (TSM)


506


which provide support for the standardized media types of token ring, Fiber Distributed Datalink Interface (FDDI) and Ethernet. The MSM


504


manages the details of interfacing ODI multi-link interface drivers to the LSL


502


and the NetWare Operating System. The MSM


504


handles all of the generic initialization and run-time issues common to all drivers. The topology specific module (TSM)


506


manages operations that are unique to a specific media type. The Hardware Specific Modules (HSM) are created by each adapter vendor for each type of adapter


308


. The HSM


508


contains the functionality to initialize, reset and shutdown the adapter


308


. The HSM


508


also handles packet transmission and reception to and from each adapter


308


.




With respect to mass storage device drivers, such as a driver


526


, the NetWare Peripheral Architecture (NWPA)


510


is a software architecture developed by Novell which provides an interface for mass storage developers to interface with the NetWare operating system. The NWPA


510


is divided into two components: a host adapter module (HAM)


512


and a custom device module (CDM)


513


. The HAM


512


is a component that contains information on the host adapter hardware. The CDM


513


is the component of the NWPA


510


that regulates the mass storage adapters


102


.




The main purpose of the Filter CDM


516


is to locate each HAM


512


register for adapter events, and process the I/O suspend and I/O restart requests from the configuration manager


500


. These commands are discussed in greater detail in the co-pending U.S. patent application Ser. No. 08/942,309 entitled, “Hot Add of Devices Software Architecture” mentioned above.




A NetWare user interface


518


initiates the requests to the configuration manager


500


to freeze and restart communications to a specified adapter


310


. A remote Small Network Management Protocol (SNMP) agent


520


can also start the request to freeze and resume communications to the configuration manager


500


through a local SNMP agent


522


. SNMP is a communication protocol used by software designers to facilitate communication among computers on a network. In one embodiment of the invention, the computers would be similar to the server system of FIG.


1


and connected in a server network via connection


132


.





FIG. 6

is a flowchart illustrating one process to hot add an adapter


310


. For instance, the process shown in

FIG. 6

may be utilized by a server system


100


containing the bus structure shown in FIG.


2


. The process described by

FIG. 6

is generic to various implementations of the invention. The following description of

FIG. 6

focuses on the hot add of an adapter


310


under the NetWare Operating System.




Starting in a state


600


, a user inserts an adapter


310


into one of the PC bus slots, such as a slot


266


(FIGS.


3


and


4


). At this point, the hot plug hardware


312


has not turned on the power to the adapter's slot, although the server system


100


is operational. Since the adapter's slot is not powered, the PC adapter


310


will not be damaged by a short circuit during the insertion process. Moving to a state


602


, the hot plug hardware


312


supplies power to the adapter's slot. In one embodiment, the hot plug hardware automatically detects the presence of the newly added adapter


310


. In another embodiment, the user notifies the hot plug hardware


312


that the adapter


310


is connected to one of the PC slots


266


. The configuration manager


500


then programs the newly added adapter


310


(state


604


) by initializing the adapter's registers with appropriate memory, I/O and interrupt parameters, after power to the adapter has been turned on. Once an adapter


310


is added to the computer system, a device driver must be loaded for the adapter


310


.





FIG. 7

is a flowchart illustrating one process of hot adding an adapter


310


on one of the canisters


258


-


264


. The process described by

FIG. 7

is generic to multiple implementations of hot adding a device. For instance, the process shown in

FIG. 7

is utilized by a server system


100


containing the bus structure shown in FIG.


3


. The following description of

FIG. 7

focuses on the hot add of an adapter


310


on a canister under the NetWare Operating System.




Starting in a state


700


, The SNMP agent


520


or the NetWare User Interface


518


initiates the request for the suspension for every adapter, such as the adapter


310


, on the canister. For each request the configuration manager


500


suspends the I/O for one of the adapters that is located on one of the canisters


258


-


264


. The configuration manager


500


initiates the suspension of I/O to either the NWPA


510


for the mass storage adapters


102


or the LSL


502


and MSM


504


for the network adapter


104


. A further discussion of the process by which the configuration manager


500


suspends and resumes the I/O to a mass storage adapter and to a network adapter is presented in the co-pending U.S. patent application Ser. No. 08/942,309, “Hot Add of Devices Software Architecture” mentioned above.




For hot plug methods and systems that use the PCI architecture, the software must assert the bus reset bit as defined by the PCI specification (state


702


). If the power to the canister is on, the hot plug hardware


312


is directed by the configuration manager


500


to disable the power to one of the specified canisters


258


-


264


(state


704


).




Proceeding to state


706


, the user inserts an adapter into one of the PC slots


266


. If the card is on a new canister that was not present during boot initialization, the hot plug hardware


312


should support the sparse assignment of bus numbers for those systems that require such functionality. The hot plug hardware


312


then restarts the power to the selection canister, e.g., one of the canisters


258


-


264


(state


708


). For PCI systems, the configuration manager


500


de-asserts the bus reset bit (state


710


). The configuration manager


500


re-initializes the configuration space of each adapter that was previously in the system (state


712


). Since an adapter is non-powered before and during a hot add, the adapter is in an unknown state after receiving power. Moving to a state


714


, the configuration manager


500


programs the configuration space of the new adapter. Finally, the configuration manager


500


resumes operations to all of the adapters located on the canister (state


718


). For mass storage adapters


102


the configuration manager


500


notifies the NWPA


510


to resume communications. For network adapters


104


, the configuration manager


500


contacts the LSL


502


to resume communications.




For further discussion on the operation of hot pluggability and related topics, please refer to co-pending and commonly owned U.S. patent application Ser. No. 08/942,311, entitled “Hot Swap and Add of Devices Software Architecture” as previously mentioned above.




The foregoing briefly describes a method and system of hot adding adapters into a server system and thereafter configuring the adapter. As described above, the adapter configuration process includes updating a configuration space within the adapter with a configuration manager program and programming the adapter's registers with appropriate memory, I/O and interrupt parameters, after power to the adapter has been turned on. One method and system for performing this adapter configuration process is described in further detail in a co-pending and commonly owned U.S. patent application Ser. No. 08/942,268, entitled, “Configuration Management Method For Hot Adding and Hot Replacing Devices,” which is listed in Appendix A attached hereto.




However, after the configuration of the adapter is completed, the process does not end there. A system operator must still reconfigure the server system in order to permanently incorporate the new adapter into the system such that it is recognized upon subsequent reboots of the system. As described above under the section entitled “Background of the Invention,” prior art methods of reconfiguring the server, after a hot add of a new device, typically require a system operator to manually select and load an appropriate driver for the newly added device, and thereafter, modify start-up configuration files by retrieving the files and inputting appropriate configuration parameters corresponding to the newly added device. If the new device is a LAN card, for example, an additional step of “binding the network protocol” of the device must be performed. The term “binding the network protocol,” and its meaning, is well-known in the art. This prior art configuration process can be time-consuming and tedious, especially for a system operator who is not familiar with the configuration requirements of the server as well as the newly added device. In such circumstances, the system operator often makes mistakes in performing one or more of the configuration steps. These mistakes may lead to serious errors in server operation and result in additional downtime of the server.





FIG. 8

illustrates a flowchart diagram of one embodiment of a process of automatically configuring a server system after an adapter has been hot added to the server system. The server system may have a bus architecture as shown in either

FIG. 2

or FIG.


3


. Referring to

FIG. 8

, the process begins at state


800


and proceeds to state


802


, wherein an autoconfiguration software program periodically scans the PCI bus in order to identify all circuit boards on the bus. After each scan, the devices identified are placed in a list and compared against a configuration database kept by the Hot Plug software. In state


804


, the program determines, for each scanning operation, whether any new boards have been added to the bus. If a new board or device is detected, as would be the case after a hot add, the new device must be configured. In step


806


, the new device is configured. In one embodiment, the detection of the new device initiates the configuration of the device. This process is decribed in further detail below with reference to

FIGS. 6 and 7

. As described above, the device configuration process entails initializing the device by programming its registers with appropriate address, memory, I/O and interrupt parameters, and thereafter, updating the devices configuration space and applying power to the board.




Next, the server, itself, may be be configured to permanently integrate the device into the system such that it is automatically initialized upon subsequent reboots of the server. In a PCI bus architecture, for example, each device, or board, includes a Device ID and a Vendor ID which is stored in a read only memory (ROM) chip located on the device. In step


808


, the autoconfiguration program retrieves the Vendor and Device ID from the device in order to determine whether that device is a SCSI or a LAN device, and who its manufacturer is. Next, in state


810


, the program obtains the hardware instance number (HIN) of the device in order to identify the “slot number” of the slot, or port, in which the device has been inserted. This “slot number” is necessary so that a driver, which is subsequently loaded, can address the slot and communicate with the new device.




One type of unique identification number is the hardware instance number (HIN). Operating systems such as Novell Netware create HINs for each device addressable by the network operating system. Under normal circumstances, this number is unique for that particular device in the computer system. By obtaining the HIN of a particular device, the system can determine the expansion slot location of the device within the computer system. This function is carried out by a software program that scans every slot attached to a system bus of the computer system and determines whether any devices having HINs are present. If such a device is present, the software records the current slot number and HIN of the device. Software embodiments can be written in any well known language such as C, Fortran, Basic or Cobol. A further description of a method and system of identifying slot locations by mapping HINs is presented in a co-pending and commonly owned patent application Ser. No. 08/941,412, entitled “Determining Slot Numbers in a Computer”, which is listed in Appendix A attached hereto.




Next, in state


812


, the program determines whether additional data is required to configure the system. Because the Device ID and Vendor ID of the device is known, the program can determine what additional parameters are required. By looking up a table of configuration requirements for that device, the program generates a finite list of parameters that are required to load an appropriate driver for that device. If it is determined that additional data is required, in state


814


, the program announces the detection of the new device and prompts a user to enter the additionally required values. If it is determined that additional data is not required, the program proceeds directly from state


812


to state


816


.




In state


816


, the program automatically loads the appropriate driver with the additional data collected by the user, if any. In order to permanently configure the system such that the new device is initialized upon subsequent restarts, the program may modify appropriate start-up configuration files. In state


818


, the program determines whether the device is a LAN device based on the device ID previously obtained. If it is not a LAN device, the program determines that the device is a SCSI device and proceeds to state


820


, wherein it automatically modifies the STARTUP.NCF configuration file. Many processes of automatically modifying a configuration file with the use of software generated commands are well-known in the art. Any of these methods can be utilized in accordance with the invention. The program then loops back to step


802


in which it once again scans for hot added devices.




If the device is a LAN device, the program proceeds to state


822


, wherein the program binds the network protocol for the device. The process of “binding the network protocol” of a device is well-known in the art. Next, in step


824


, the program modifies the INETCFG configuration file. Many processes of automatically modifying a configuration file with the use of software generated commands are well-known in the art. Any of these methods can be utilized in accordance with the invention. The program then loops back to step


802


in which it once again scans for hot added devices.




As described above, the invention provides a method and system for automatically configuring a server system so as to permanently integrate hot added devices into the system. By sensing a newly added device and automatically initiating a system configuration protocol, one embodiment of the invention eliminates, or reduces, user interaction which is required in current system configuration procedures. By automatically performing the system configuration, one embodiment of the invention expedites the process of hot adding new devices to a server system and further reduces the risk of configuration errors made by the user, leading to an overall reduction in system downtime. Additionally, one embodiment of the invention simplifies the system configuration process by automatically identifying the type of device, its slot location, and thereafter configuring the system based on this information, by loading appropriate drivers, modifying appropriate start-up configuration files, and saving the modified start-up configuration files in the system's main memory.




The invention may be embodied in other specific forms without departing from its spirit or essential characteristics. The described embodiments are to be considered in all respects only as illustrative and not restrictive. The scope of the invention is, therefore, indicated by the appended claims, rather than by the foregoing description. All changes which come within the meaning and range of equivalency of the claims are to be embraced within their scope.












APPENDIX A











Incorporation by Reference of Commonly Owned Applications






The following patent applications, commonly owned and






filed October 1, 1997, are hereby incorporated herein






in their entirety by reference thereto:














Title




Application No.











“System Architecture for Remote Access




08/942,160







and Control of Environmental







Management”







“Method of Remote Access and Control of




08/942,215







Environmental Management”







“System for Independent Powering of




08/942,410







Diagnostic Processes on a Computer







System”







“Method of Independent Powering of




08/942,320







Diagnostic Processes on a Computer







System”







“Diagnostic and Managing Distributed




08/942,402







Processor System”







“Method for Managing a Distributed




08/942,448







Processor System”







“System for Mapping Environmental




08/942,222







Resources to Memory for Program Access”







“Method for Mapping Environmental




08/942,214







Resources to Memory for Program Access”







“Hot Add of Devices Software




08/942,309







Architecture”







“Method for The Hot Add of Devices”




08/942,306







“Hot Swap of Devices Software




08/942,311







Architecture”







“Method for The Hot Swap of Devices”




08/942,457







“Method for the Hot Add of a Network




08/943,072







Adapter on a System Including a







Dynamically Loaded Adapter Driver”







“Method for the Hot Add of a Mass




08/942,069







Storage Adapter on a System Including a







Statically Loaded Adapter Driver”







“Method for the Hot Add of a Network




08/942,465







Adapter on a System Including a Statically







Loaded Adapter Driver”







“Method for the Hot Add of a Mass




08/962,963







Storage Adapter on a System Including a







Dynamically Loaded Adapter Driver”







“Method for the Hot Swap of a Network




08/943,078







Adapter on a System Including a







Dynamically Loaded Adapter Driver”







“Method for the Hot Swap of a Mass




08/942,336







Storage Adapter on a System Including a







Statically Loaded Adapter Driver”







“Method for the Hot Swap of a Network




08/942,459







Adapter on a System Including a Statically







Loaded Adapter Driver”







“Method for the Hot Swap of a Mass




08/942,458







Storage Adapter on a System Including a







Dynamically Loaded Adapter Driver”







“Method of Performing an Extensive




08/942,463







Diagnostic Test in Conjunction with a







BIOS Test Routine”







“Apparatus for Performing an Extensive




08/942,163







Diagnostic Test in Conjunction with a







BIOS Test Routine”







“Configuration Management Method for




08/941,268







Hot Adding and Hot Replacing Devices”







“Configuration Management System for




08/942,408







Hot Adding and Hot Replacing Devices”







“Apparatus for Interfacing Buses”




08/942,382







“Method for Interfacing Buses”




08/942,413







“Computer Fan Speed Control Device”




08/942,447







“Computer Fan Speed Control Method”




08/942,216







“System for Powering Up and Powering




08/943,076







Down a Server”







“Method of Powering Up and Powering




08/943,077







Down a Server”







“System for Resetting a Server”




08/942,333







“Method of Resetting a Server”




08/942,405







“System for Displaying Flight Recorder”




08/942,070







“Method of Displaying Flight Recorder”




08/942,068







“Synchronous Communication Interface”




08/943,355







“Synchronous Communication Emulation”




08/942,004







“Software System Facilitating the




08/942,317







Replacement or Insertion of Devices in a







Computer System”







“Method for Facilitating the Replacement




08/942,316







or Insertion of Devices in a Computer







System”







“System Management Graphical User




08/943,357







Interface”







“Display of System Information”




08/942,195







“Data Management System Supporting Hot




08/942,129







Plug Operations on a Computer”







“Data Management Method Supporting




08/942,124







Hot Plug Operations on a Computer”







“Alert Configurator and Manager”




08/942,005







“Managing Computer System Alerts”




08/943,356







“Computer Fan Speed Control System”




08/940,301







“Computer Fan Speed Control System




08/941,267







Method”







“Black Box Recorder for Information




08/942,381







System Events”







“Method of Recording Information System




08/942,164







Events”







“Method for Automatically Reporting a




08/942,168







System Failure in a Server”







“System for Automatically Reporting a




08/942,384







System Failure in a Server”







“Expansion of PCI Bus Loading Capacity”




08/942,404







“Method for Expanding PCI Bus Loading




08/942,223







Capacity”







“System for Displaying System Status”




08/942,347







“Method of Displaying System Status”




08/942,071







“Fault Tolerant Computer System”




08/942,194







“Method for Hot Swapping of Network




08/943,044







Components”







“A Method for Communicating a Software




08/942,221







Generated Pulse Waveform Between Two







Servers in a Network”







“A System for Communicating a Software




08/942,409







Generated Pulse Waveform Between Two







Servers in a Network”







“Method for Clustering Software




08/942,318







Applications”







“System for Clustering Software




08/942,411







Applications”







“Method for Automatically Configuring a




08/942,319







Server after Hot Add of a Device”







“Method of Automatically Configuring and




08/942,412







Formatting a Computer System and







Installing Software”







“System for Automatically Configuring




08/941,955







and Formatting a Computer System and







Installing Software”







“Determining Slot Numbers in a




08/942,462







Computer”







“System for Detecting Errors in a Network”




08/942,169







“Method of Detecting Errors in a Network”




08/940,302







“System for Detecting Network Errors”




08/942,407







“Method of Detecting Network Errors”




08/942,573














Claims
  • 1. A system for automatically configuring an operating computer system, comprising:a bus system having a plurality of bus slots; hot plug hardware for enabling and disabling the supply of power to selected ones of the bus slots; a detection module which automatically detects a PCI device in response to the PCI device being connected to a selected one of the bus slots that has a disabled power supply, and wherein the hot plug hardware enables the supply of power to the hot added PCI device in response to the detection of the hot added PCI device by the detection module; a first configuration module which automatically configures the PCI device; an identification module which automatically identifies a device type for the PCI device; a location module which automatically determines the location where the PCI device has been hot added; a driver module which automatically loads a driver corresponding to the PCI device; and a second configuration module which automatically modifies a configuration file so as to integrate the PCI device into the system, wherein the second configuration module comprises a LAN module which determines whether the hot added device is local area network (LAN) device, wherein, if it is determined that the hot added device is not a LAN device, the LAN module modifies a first configuration file, and if it is determined that the hot added device is a LAN device, the LAN module modifies a second configuration file.
  • 2. The system of claim 1 wherein the detection module comprises:a first scanning module which scans a system bus in order to identify all devices connected to the bus; and a compare module which compares a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database.
  • 3. The system of claim 2 wherein the identification module comprises a vendor module which retrieves a Device ID and Vendor ID from the device.
  • 4. The system of claim 3 wherein the location module comprises:a second scanning module which scans all slots connected to the system bus for any devices which have a hardware instance number (HIN), wherein each slot has a specified slot number; a HIN module which obtains a hardware instance number (HIN) from the hot added device; and a recording module which records a slot number and the hardware instance number corresponding to the device.
  • 5. The system of claim 1 further comprising a data module which determines if additional data is required to configure the system, wherein, if it is determined that additional data is required, the data module prompts a system operator for the additional data.
  • 6. The system of claim 5 wherein the data module comprises:a table module which reviews a table of configuration parameters for the device type; and a parameter module which generates a list of parameters required to load a driver for the device.
  • 7. The system of claim 1 wherein the identification module comprises a vendor module which retrieves a Device ID and Vendor ID from the device.
  • 8. The system of claim 1 wherein the detection module comprises:a first scanning module which scans a system bus in order to identify all devices connected to the bus; and a compare module which compares a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database.
  • 9. The system of claim 1 wherein the location module comprises:a second scanning module which scans all slots connected to a system bus for any devices which have hardware instance number (HIN) wherein each slot has a specified slot number; a HIN module which obtains a hardware instance number (HIN) from the hot added device; and a recording module which records a slot number corresponding to each device having a HIN.
  • 10. The system of claim 1 wherein the configuration module comprises a LAN module which determines whether the hot added device is local area network (LAN) device, wherein, if it is determined that the hot added device is not a LAN device, the LAN module modifies a first configuration file, and if it is determined that the hot added device is a LAN device, the LAN module modifies a second configuration file.
  • 11. The system of claim 1 further comprising a data module which determines if additional data is required to configure the system, wherein, if it is determined that additional data is required, the data module prompts a system operator for the additional data.
  • 12. The system of claim 11 wherein the data module comprises:a table module which reviews a table of configuration parameters for the device type; a parameter list module which generates a list of parameters required to load a driver for the device; and a second compare module which compares the list of parameters with presently available data about the device.
  • 13. A system of automatically configuring a server system after a device has been hot added to the system, comprising:a first scanning module which scans a system bus in order to identify all devices connected to the bus; a compare module which compares a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; a first configuration module which configures the device; a vendor module which retrieves a Device ID and Vendor ID from the device so as to identify the type of device; a second scanning module which scans the system bus for any devices which have a hardware instance number (HIN); a HIN module which obtains a hardware instance number (HIN) from the hot added device; a recording module which records a slot number and the hardware instance number of the device; a driver module which loads a driver corresponding to the hot added device; a LAN module which determines whether the hot added device is local area network (LAN) device; and a second configuration module which modifies a configuration file, wherein, if it is determined that the hot added device is not a LAN device, a first configuration file is modified, and if it is determined that the hot added device is a LAN device, a second configuration file is modified.
  • 14. The system of claim 13 further comprising:a data module which determines if additional data is required to configure the system; and a prompt module which prompts a system operator for additional data, if it is determined that additional data is required.
  • 15. The system of claim 14 wherein the data module comprises:a table module which reviews a table of configuration parameters for the device type corresponding to the hot added device; and a parameter module which generates a list of parameters required to load a driver for the device.
  • 16. A system for automatically configuring an operating computer system, comprising:means for receiving a PCI device; means for enabling and disabling a supply of power to the PCI device; means for automatically detecting the PCI device; means for automatically configuring the PCI device; means for automatically identifying the type of the PCI device; means for automatically determining the location where the PCI device has been added; means for automatically loading a driver corresponding to the PCI device; and means for automatically modifying a configuration file so as to integrate the PCI device into the system, wherein the means for automatically modifying a configuration file comprises means for determining whether the hot added device is local area network (LAN) device, wherein, if it is determined that the hot added device is not a LAN device, a first configuration file is modified and if it is determined that the hot added device is a LAN device, a second configuration file is modified.
  • 17. The system of claim 16 wherein the act of automatically detecting the hot added device comprises:means for scanning a system bus in order to identify all devices connected to the bus; and means for comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database.
  • 18. The system of claim 17 further comprising means for initiating the automatic configuration of the device upon the detection of the hot added device.
  • 19. The system of claim 18 wherein the means for automatically identifying the device type comprises means for retrieving a Device ID and Vendor ID from the device.
  • 20. The system of claim 19 wherein the means for automatically determining the location where the device has been hot added comprises:means for scanning the system bus for any devices which have a hardware instance number (HIN); means for obtaining a hardware instance number (HIN) from the hot added device; and means for recording a slot number and the hardware instance number of the device.
  • 21. The system of claim 16 further comprising:means for determining if additional data is required to configure the system; and means for prompting a system operator for the additional data, if it is determined that additional data is required.
  • 22. The system of claim 21 wherein the means for determining if additional data is required comprises:means for reviewing a table of configuration parameters for the type of device; and means for generating a list of parameters required to load a driver for the device.
  • 23. The system of claim 16 wherein the means for automatically identifying the device type comprises means for retrieving a Device ID and Vendor ID from the device.
  • 24. The system of claim 16 wherein the means for automatically determining the location where the device has been hot added comprises:means for scanning a system bus for any devices which have a hardware instance number (HIN); means for obtaining a hardware instance number (HIN) from the hot added device; and means for recording a slot number and the hardware instance number of the device.
  • 25. The system of claim 16 wherein the means for automatically modifying a configuration file comprises means for determining whether the hot added device is local area network (LAN) device, wherein, if it is determined that the hot added device is not a LAN device, a first configuration file is modified, and if it is determined that the hot added device is a LAN device, a second configuration file is modified.
  • 26. The system of claim 25 wherein the means for determining whether the hot added device is a LAN device comprises means for retrieving a Device ID and Vendor ID from the device.
  • 27. The system of claim 16 further comprising:means for determining if additional data is required to configure the system; and means for prompting a system operator for the additional data, if it is determined that additional data is required.
  • 28. The system of claim 27 wherein the means for determining if additional data is required comprises:means for reviewing a table of configuration parameters for the device type; and means for generating a list of parameters required to load a driver for the device.
  • 29. A system of automatically configuring a server system after a device has been hot added to the system, comprising:means for scanning a system bus in order to identify all devices connected to the bus; means for comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; means for configuring the device; means for retrieving a Device ID and Vendor ID from the device so as to identify a device type; means for scanning the system bus for any devices which have a hardware instance number (HIN); means for obtaining a hardware instance number (HIN) from the hot added device; means for recording a slot number and the hardware instance number of the device; means for loading a driver corresponding to the hot added device; means for determining whether the hot added device is local area network (LAN) device; and means for configuring the server so as to integrate the hot added device into the server system, wherein if it is determined that the hot added device is not a LAN device, a first configuration file is modified, and if it is determined that the hot added device is a LAN device, a second configuration file is modified.
  • 30. The system of claim 29 further comprising:means for determining if additional data is required to configure the system; and means for prompting a system operator for the additional data, if it is determined that additional data is required.
  • 31. The system of claim 30 wherein the means for determining if additional data is required comprises:means for reviewing a table of configuration parameters for the device type; and means for generating a list of parameters required to load a driver for the device.
  • 32. A program storage device which stores instructions that when executed by a computer perform a method which comprises:automatically detecting a PCI device; automatically providing, in response to detecting the PCI device, a supply of power to the PCI device; automatically configuring the PCI device; automatically identifying a device type for the PCI device; automatically determining the location where the PCI device has been added; automatically loading a driver corresponding to the PCI device; and automatically modifying a configuration file so as to integrate the PCI device into the system, wherein the act of automatically modifying a configuration file comprises: determining whether the hot added device is local area network (LAN) device; if it is determined that the hot added device is not a LAN device, modifying a first configuration file; and if it is determined that the hot added device is a LAN device, binding a network protocol of the device and modifying a second configuration file.
  • 33. The device of claim 32 wherein the act of automatically detecting the hot added device comprises:scanning a system bus in order to identify all devices connected to the bus; and comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database.
  • 34. The device of claim 33 wherein the detection of the hot added device initiates the automatic configuration of the device.
  • 35. The device of claim 34 wherein the act of automatically identifying a device type for the device comprises retrieving a Device ID and Vendor ID from the device.
  • 36. The device of claim 35 wherein the act of automatically determining the location where the device has been hot added comprises:scanning the system bus for any devices which have a hardware instance number (HIN); obtaining a hardware instance number (HIN) from the hot added device; and recording a slot number and the hardware instance number corresponding to the device.
  • 37. The device of claim 36 wherein the method further comprises:determining if additional data is required to configure the system; and if it is determined that additional data is required, prompting a system operator for the additional data.
  • 38. The device of claim 37 wherein the act of determining if additional data is required comprises:reviewing a table of configuration parameters for the device type; and generating a list of parameters required to load a driver for the device type.
  • 39. The device of claim 32 wherein the act of automatically identifying the device type comprises retrieving a Device ID and Vendor ID from the device.
  • 40. The device of claim 32 wherein the act of automatically determining the location where the device has been hot added comprises:scanning a system bus for any devices which have a hardware instance number (HIN); obtaining a hardware instance number (HIN) from the hot added device; and recording a slot number and the hardware instance number of the device.
  • 41. The device of claim 32 wherein the act of automatically modifying a configuration file comprises:determining whether the hot added device is local area network (LAN) device; if it is determined that the hot added device is not a LAN device, modifying a first configuration file; and if it is determined that the hot added device is a LAN device, modifying a second configuration file.
  • 42. The device of claim 41 wherein the act of determining whether the hot added device is a LAN device comprises retrieving a Device ID and Vendor ID from the device.
  • 43. The device of claim 32 wherein the method further comprises:determining if additional data is required to configure the system; and if it is determined that additional data is required, prompting a system operator for the additional data.
  • 44. The device of claim 43 wherein the act of determining if additional data is required comprises:reviewing a table of configuration parameters for the device type; and generating a list of parameters required to load a driver for the device.
  • 45. A program storage device which stores instructions that when executed by a computer perform a method of automatically configuring a server system after a device has been hot added to the system, wherein the method comprises:scanning a system bus in order to identify all devices connected to the bus; comparing a list of identified devices to a configuration database, wherein a new device is indicated if it is identified in the list but not in the configuration database; configuring the device; retrieving a Device ID and Vendor ID from the device so as to identify the type of device; scanning the system bus for any devices which have a hardware instance number (HIN); obtaining a hardware instance number (HIN) from the hot added device; recording a slot number and the hardware instance number of the device; loading a driver corresponding to the hot added device; determining whether the hot added device is local area network (LAN) device; if it is determined that the hot added device is not a LAN device, modifying a first configuration file; and if it is determined that the hot added device is a LAN device, binding a network protocol of the device and modifying a second configuration file.
  • 46. The device of claim 45 wherein the method further comprises:determining if additional data is required to configure the system; and if it is determined that additional data is required, prompting a system operator for the additional data.
  • 47. The device of claim 46 wherein the act of determining if additional data is required comprises:reviewing a table of configuration parameters for the device type; and generating a list of parameters required to load a driver for the device.
RELATED APPLICATIONS

This application is related to U.S. patent application Ser. No.: 08/942,319, entitled, “Method For Automatically Configuring a Server After Hot Add of A Device,” which is commonly owned and filed concurrently herewith.

US Referenced Citations (285)
Number Name Date Kind
4057847 Lowell et al. Nov 1977
4100597 Fleming et al. Jul 1978
4449182 Rubinson et al. May 1984
4672535 Katzman et al. Jun 1987
4692918 Elliott et al. Sep 1987
4695946 Andreasen et al. Sep 1987
4707803 Anthony, Jr. et al. Nov 1987
4769764 Levanon Sep 1988
4774502 Kimura Sep 1988
4821180 Gerety et al. Apr 1989
4835737 Herrig et al. May 1989
4894792 Mitchell et al. Jan 1990
4949245 Martin et al. Aug 1990
4999787 McNally et al. Mar 1991
5006961 Monico Apr 1991
5007431 Donehoo, III Apr 1991
5033048 Pierce et al. Jul 1991
5051720 Kittirutsunetorn Sep 1991
5073932 Yossifor et al. Dec 1991
5103391 Barrett Apr 1992
5118970 Olson et al. Jun 1992
5121500 Arlington et al. Jun 1992
5136708 Lapourtre et al. Aug 1992
5136715 Hirose et al. Aug 1992
5138619 Fasang et al. Aug 1992
5157663 Major et al. Oct 1992
5210855 Bartol May 1993
5222897 Collins et al. Jun 1993
5245615 Treu Sep 1993
5247683 Holmes et al. Sep 1993
5253348 Scalise Oct 1993
5265098 Mattson et al. Nov 1993
5266838 Gerner Nov 1993
5269011 Yanai et al. Dec 1993
5272382 Heald et al. Dec 1993
5272584 Austruy et al. Dec 1993
5276814 Bourke et al. Jan 1994
5276863 Heider Jan 1994
5277615 Hastings et al. Jan 1994
5280621 Barnes et al. Jan 1994
5283905 Saadeh et al. Feb 1994
5307354 Cramer et al. Apr 1994
5311397 Harshberger et al. May 1994
5311451 Barrett May 1994
5317693 Cuenod et al. May 1994
5329625 Kannan et al. Jul 1994
5337413 Lui et al. Aug 1994
5351276 Doll, Jr. et al. Sep 1994
5367670 Ward et al. Nov 1994
5379184 Barraza et al. Jan 1995
5386567 Lien et al. Jan 1995
5388267 Chan et al. Feb 1995
5402431 Saadeh et al. Mar 1995
5404494 Garney Apr 1995
5423025 Goldman et al. Jun 1995
5430717 Fowler et al. Jul 1995
5430845 Rimmer et al. Jul 1995
5432715 Shigematsu et al. Jul 1995
5432946 Allard et al. Jul 1995
5438678 Smith Aug 1995
5440748 Sekine et al. Aug 1995
5448723 Rowett Sep 1995
5455933 Schieve et al. Oct 1995
5460441 Hastings et al. Oct 1995
5463766 Schieve et al. Oct 1995
5471634 Giorgio et al. Nov 1995
5473499 Weir Dec 1995
5483419 Kaczeus, Sr. et al. Jan 1996
5485550 Dalton Jan 1996
5487148 Komori et al. Jan 1996
5491791 Glowny et al. Feb 1996
5493574 McKinley Feb 1996
5493666 Fitch Feb 1996
5513314 Kandasamy et al. Apr 1996
5513339 Agrawal et al. Apr 1996
5515515 Kennedy et al. May 1996
5517646 Piccirillo et al. May 1996
5519851 Bender et al. May 1996
5526289 Dinh et al. Jun 1996
5528409 Cucci et al. Jun 1996
5530810 Bowman Jun 1996
5533193 Roscoe Jul 1996
5535326 Baskey et al. Jul 1996
5542055 Amini et al. Jul 1996
5546272 Moss et al. Aug 1996
5548712 Larson et al. Aug 1996
5555510 Verseput et al. Sep 1996
5559764 Chen et al. Sep 1996
5559958 Farrand et al. Sep 1996
5559965 Oztaskin et al. Sep 1996
5560022 Dunstan et al. Sep 1996
5564024 Pemberton Oct 1996
5566299 Billings et al. Oct 1996
5566339 Perholtz et al. Oct 1996
5568610 Brown Oct 1996
5568619 Blackledge et al. Oct 1996
5572403 Mills Nov 1996
5577205 Hwang et al. Nov 1996
5579487 Meyerson et al. Nov 1996
5579491 Jeffries et al. Nov 1996
5579528 Register Nov 1996
5581712 Herman Dec 1996
5581714 Amini et al. Dec 1996
5584030 Husak et al. Dec 1996
5586250 Carbonneau et al. Dec 1996
5588121 Reddin et al. Dec 1996
5588144 Inoue et al. Dec 1996
5592611 Midgely et al. Jan 1997
5596711 Burckhartt et al. Jan 1997
5598407 Bud et al. Jan 1997
5602758 Lincoln et al. Feb 1997
5606672 Wade Feb 1997
5608876 Cohen et al. Mar 1997
5615207 Gephardt et al. Mar 1997
5621159 Brown et al. Jan 1997
5622221 Genga, Jr. et al. Apr 1997
5625238 Ady et al. Apr 1997
5627962 Goodrum et al. May 1997
5628028 Michelson May 1997
5630076 Saulpaugh et al. May 1997
5631847 Kikinis May 1997
5632021 Jennings et al. May 1997
5636341 Matsushita et al. Jun 1997
5638289 Yamada et al. Jun 1997
5644470 Benedict et al. Jul 1997
5644731 Liencres et al. Jul 1997
5651006 Fujino et al. Jul 1997
5652832 Kane et al. Jul 1997
5652839 Giorgio et al. Jul 1997
5652892 Ugajin Jul 1997
5652908 Douglas et al. Jul 1997
5655081 Bonnell et al. Aug 1997
5655083 Bagley Aug 1997
5655148 Richman et al. Aug 1997
5659682 Devarakonda et al. Aug 1997
5664118 Nishigaki et al. Sep 1997
5664119 Jeffries et al. Sep 1997
5666538 DeNicola Sep 1997
5668943 Attanasio et al. Sep 1997
5668992 Hammer et al. Sep 1997
5669009 Buktenica et al. Sep 1997
5671371 Kondo et al. Sep 1997
5675723 Ekrot et al. Oct 1997
5680288 Carey et al. Oct 1997
5684671 Hobbs et al. Nov 1997
5689637 Johnson et al. Nov 1997
5696895 Hemphill et al. Dec 1997
5696899 Kalwitz Dec 1997
5696949 Young Dec 1997
5696970 Sandage et al. Dec 1997
5701417 Lewis et al. Dec 1997
5704031 Mikami et al. Dec 1997
5708775 Nakamura Jan 1998
5708776 Kikinis Jan 1998
5712754 Sides et al. Jan 1998
5715456 Bennett et al. Feb 1998
5717570 Kikinis Feb 1998
5721935 DeSchepper et al. Feb 1998
5724529 Smith et al. Mar 1998
5726506 Wood Mar 1998
5727207 Gates et al. Mar 1998
5732266 Moore et al. Mar 1998
5737708 Grob et al. Apr 1998
5740378 Rehl et al. Apr 1998
5742514 Bonola Apr 1998
5742833 Dea et al. Apr 1998
5747889 Raynham et al. May 1998
5748426 Bedingfield et al. May 1998
5752164 Jones May 1998
5754396 Felcman et al. May 1998
5754449 Hoshal et al. May 1998
5754797 Takahashi May 1998
5758165 Shuff May 1998
5758352 Reynolds et al. May 1998
5761033 Wilhelm Jun 1998
5761045 Olson et al. Jun 1998
5761085 Giorgio Jun 1998
5761462 Neal et al. Jun 1998
5761707 Aiken et al. Jun 1998
5764924 Hong Jun 1998
5764968 Ninomiya Jun 1998
5765008 Desai et al. Jun 1998
5765198 McCrocklin et al. Jun 1998
5767844 Stoye Jun 1998
5768541 Pan-Ratzlaff Jun 1998
5768542 Enstrom et al. Jun 1998
5771343 Hafner et al. Jun 1998
5774645 Beaujard et al. Jun 1998
5774741 Choi Jun 1998
5777897 Giorgio Jul 1998
5778197 Dunham Jul 1998
5781703 Desai et al. Jul 1998
5781716 Hemphill et al. Jul 1998
5781744 Johnson et al. Jul 1998
5781767 Inoue et al. Jul 1998
5781798 Beatty et al. Jul 1998
5784555 Stone Jul 1998
5784576 Guthrie et al. Jul 1998
5787019 Knight et al. Jul 1998
5787459 Stallmo et al. Jul 1998
5787491 Merkin et al. Jul 1998
5790775 Marks et al. Aug 1998
5790831 Lin et al. Aug 1998
5793948 Asahi et al. Aug 1998
5793987 Quackenbush et al. Aug 1998
5794035 Golub et al. Aug 1998
5796185 Takata et al. Aug 1998
5796580 Komatsu et al. Aug 1998
5796981 Abudayyeh et al. Aug 1998
5797023 Berman et al. Aug 1998
5798828 Thomas et al. Aug 1998
5799036 Staples Aug 1998
5799196 Flannery Aug 1998
5801921 Miller Sep 1998
5802269 Poisner et al. Sep 1998
5802298 Imai et al. Sep 1998
5802305 McKaughan et al. Sep 1998
5802324 Wunderlich et al. Sep 1998
5802393 Begun et al. Sep 1998
5802552 Fandrich et al. Sep 1998
5802592 Chess et al. Sep 1998
5803357 Lakin Sep 1998
5805804 Laursen et al. Sep 1998
5805834 McKinley et al. Sep 1998
5809224 Schultz et al. Sep 1998
5809256 Najemy Sep 1998
5809287 Stupek, Jr. et al. Sep 1998
5809555 Hobson Sep 1998
5812748 Ohran et al. Sep 1998
5812750 Dev et al. Sep 1998
5812757 Okamoto et al. Sep 1998
5812858 Nookala et al. Sep 1998
5815117 Kolanek Sep 1998
5815647 Buckland et al. Sep 1998
5815652 Ote et al. Sep 1998
5821596 Miu et al. Oct 1998
5822547 Boesch et al. Oct 1998
5826043 Smith et al. Oct 1998
5829311 Jones Sep 1998
5835719 Gibson et al. Nov 1998
5835738 Blackledge, Jr. et al. Nov 1998
5838932 Alzien Nov 1998
5841964 Yamaguchi Nov 1998
5841991 Russell Nov 1998
5845061 Miyamoto et al. Dec 1998
5845095 Reed et al. Dec 1998
5850546 Kim Dec 1998
5852720 Gready et al. Dec 1998
5852724 Glenn, II et al. Dec 1998
5857074 Johnson Jan 1999
5857102 McChesney et al. Jan 1999
5864653 Tavallaei et al. Jan 1999
5864713 Terry Jan 1999
5867730 Leyda Feb 1999
5875307 Ma et al. Feb 1999
5875308 Egan et al. Feb 1999
5875310 Buckland et al. Feb 1999
5878237 Olarig Mar 1999
5878238 Gan et al. Mar 1999
5881311 Woods Mar 1999
5884027 Garbus et al. Mar 1999
5884049 Atkinson Mar 1999
5886424 Kim Mar 1999
5889965 Wallach et al. Mar 1999
5892898 Fujii et al. Apr 1999
5892928 Wallach et al. Apr 1999
5898846 Kelley Apr 1999
5898888 Guthrie et al. Apr 1999
5905867 Giorgio May 1999
5907672 Matze et al. May 1999
5909568 Nason Jun 1999
5911779 Stallmo et al. Jun 1999
5913034 Malcolm Jun 1999
5922060 Goodrum Jul 1999
5930358 Rao Jul 1999
5935262 Barrett et al. Aug 1999
5936960 Stewart Aug 1999
5938751 Tavallaei et al. Aug 1999
5941996 Smith et al. Aug 1999
5964855 Bass et al. Oct 1999
5983349 Kodama et al. Nov 1999
5987554 Liu et al. Nov 1999
5987627 Rawlings, III Nov 1999
6012130 Beyda et al. Jan 2000
6038624 Chan et al. Mar 2000
Foreign Referenced Citations (5)
Number Date Country
0 866 403 A1 Sep 1998 EP
04 333 118 A Nov 1992 JP
05 233 110 A Sep 1993 JP
07 093 064 A Apr 1995 JP
07 261 874 A Oct 1995 JP
Non-Patent Literature Citations (27)
Entry
Shanley and Anderson, PCI System Architecture, Third Edition, Chapters 15 & 16, pp. 297-328, CR 1995.
PCI Hot-Plug Specification, Preliminary Revision for Review Only, Revision 0.9, pp. i-vi, and 1-25, Mar. 5, 1997.
SES SCSI-3 Enclosure Services, X3T10/Project 1212-D/Rev 8a, pp. i iii-x, 1-76, and l-1 (index), Jan. 16, 1997.
Compaq Computer Corporation, Technology Brief, pp. 1-13, Dec. 1996, “Where Do I Plug the Cable? Solving the Logical-Physical Slot Numbering Problem.”
Davis, T, Usenet post to alt.msdos.programmer, Apr. 1997, “Re: How do I create an FDISK batch File?”.
Davis, T., Usenet post to alt.msdos.batch, Apr. 1997, “Re: Need help with automating FDISK and Format . . .”.
NetFrame Systems Incorporated, Doc. No. 78-100026-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996, “NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novell® NetWare® 4.1 SMP, 4.1, and 3.12.”
Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 15, pp. 297-302, Copyright 1995, “Intro To Configuration Address Space.”
Shanley, and Anderson, PCI System Architecture, Third Edition, Chapter 16, pp. 303-328, Copyright 1995, “Configuration Transactions.”
Sun Microsystems Computer Company, Part No. 802-5355-10, Rev. A, May 1996, “Solstice SyMON User's Guid.”
Sun Microsystems, Part No. 802-6569-11, Release 1.0.1, Nov. 1996, “Remote Systems Diagnostics Installation & User Guide.”
Gorlick, M., Conf. Proceedings: ACM/ONR Workshop on Parallel and Distributed Debugging, pp. 175-181, 1991, “The Flight Recorder: An Architectural Aid for System Monitoring.”
IBM Technical Disclosure Bulliten, 92A+62947, pp. 391-394, Oct. 1992, Method for Card Hot Plug Detection and Control.
Shanley, and Anderson, PCI System Architecture, Third Edition, p. 382, Copyright 1995.
ftp.cdrom.com/pub/os2diskutil/, PHDX software, phdx.zip download, Mar. 1995, “Parallel Hard Disk Xfer.”
Cmasters, Usenet post to microsoft.public.windowsnt.setup, Aug. 1997, “Re: FDISK switches.”
Hildebrand, N., Usenet post to comp.msdos.programmer, May 1995, “Re: Structure of disk partition into.”
Lewis, L., Usenet post to alt.msdos.batch, Apr. 1997, “Re: Need help with automating FDISK and FORMAT.”
Netframe, http://www.netframe-support.com/technology/datasheets/data.htm, before Mar. 1997, “Netframe ClusterSystem 9008 Data Sheet.”
Simos, M., Usenet post to comp.os.msdos.misc, Apr. 1997, “Re: Auto FDISK and FORMAT.”
Wood, M. H., Usenet post to comp.os.netware.misc, Aug. 1996, “Re: Workstation duplication method for WIN95.”
PCI Bus Hot Plug Specification dated Jun. 15, 1997.
Supporting Removable Devices Under Windows and Windows NT; updated Aug. 13, 1997.
Plug and Play BIOS Specification dated May 5, 1994.
Lyon, Daniel, Computer Reseller News, ACC releases low-cost solution for ISPs Feb. 3, 1997.*
Noell IntranetWare supports hot pluggable PCI from NetFRAME, Dec. 19, 1996.*
Rigney, Steve, PC Magazine, The one for the road, Oct. 10, 1995.