Method for interfacing two buses

Information

  • Patent Grant
  • 6341322
  • Patent Number
    6,341,322
  • Date Filed
    Thursday, February 25, 1999
    25 years ago
  • Date Issued
    Tuesday, January 22, 2002
    22 years ago
Abstract
A method and apparatus for interfacing buses includes a system interface processor coupled to a first bus and including a command register accessible via a second bus. A request buffer and a response buffer are provided which are accessible via the second bus and coupled to the interface processor. The request buffer can be used to store information to be transmitted from the second bus to the first via the interface processor while the response buffer can be used to store information to be transmitted from the first bus to the second bus via the interface processor. The interface processor may include a status register to indicate the status of the interface controller. The interface controller may also include a command register to receive commands transmitted over the second bus.
Description




The following patent applications and patents, all of which were filed on Oct. 1, 1997 and were commonly owned, are hereby incorporated herein in their entirety by reference thereto:

















Patent No./Application






Title




No.











“System Architecture for Remote Access and




6,266,721






Control of Environmental Management”






“Method of Remote Access and Control of




08/942,215






Environmental Management”






“System for Independent Powering of Diagnostic




08/942,410






Processes on a Computer System”






“Method of Independent Powering of Diagnostic




6,134,668






Processes on a Computer System”






“Diagnostic and Managing Distributed Processor




08/942,402






System”






“Method for Managing aDistributed Processor




08/942,448






System”






“System for Mapping Environmental Resources to




6,122,758






Memory for Program Access”






“Method for Mapping Environmental Resources




08/942,214






to Memory for Program Access”






“Hot Add of Devices Software Architecture”




08/942,309






“Method for The Hot Add of Devices”




08/942,306






“Hot Swap of Devices Software Architecture”




6,192,434






“Method for The Hot Swap of Devices”




08/942,457






“Method for the Hot Add of a Network Adapter




5,892,928






on a System Including a Dynamically Loaded






Adapter Driver”






“Method for the Hot Add of a Mass Storage




08/942,069






Adapter on a System Including a Statically






Loaded Adapter Driver”






“Method for the Hot Add of a Network Adapter




08/942,465






on a System Including a Statically Loaded






Adapter Driver”






“Method for the Hot Add of a Mass Storage




08/942,963






Adapter on a System Including a Dynamically






Loaded Adapter Driver”






“Method for the Hot Swap of a Network Adapter




5,899,965






on a System Including a Dynamically Loaded






Adapter Driver”






“Method for the Hot Swap of a Mass Storage




08/942,336






Adapter on a System Including a Statically






Loaded Adapter Driver”






“Method for the Hot Swap of a Network




6,170,028






Adapter on a System Including a Statically






Loaded Adapter Driver”






“Method for the Hot Swap of a Mass Storage




6,173,346






Adapter on a System Including a Dynamically






Loaded Adapter Driver”






“Method of Performing an Extensive Diagnostic




6,035,420






Test in Conjunction with a BIOS Test Routine”






“Apparatus for Performing an Extensive




6,009,541






Diagnostic Test in Conjunction with a BIOS






Test Routine”






“Configuration Management Method for Hot




6,148,355






Adding and Hot Replacing Devices”






“Configuration Management System for Hot




08/942,408






Adding and Hot Replacing Devices”






“Apparatus for Interfacing Buses”




6,182,180






“Method for Interfacing Buses”




5,987,554






“Computer Fan Speed Control Device”




5,990,582






“Computer Fan Speed Control Method”




5,962,933






“System for Powering Up and Powering Down a




6,122,746






Server”






“Method of Powering Up and Powering Down a




6,163,849






Server”






“System for Resetting a Server”




6,065,053






“Method for Resetting a Server”




08/942,405






“System for Displaying a Flight Recorder”




6,138,250






“Method for Displaying a Flight Recorder”




6,073,255






“Synchronous Communication Interface”




08.943,355






“Synchronous Communication Emulation”




6,068,661






“Software System Facilitating the Replacement or




6,134,615






Insertion of Devices in a Computer System”






“Method for Facilitating the Replacement or




6,134,614






Insertion of Devices in a Computer System”






“System Management Graphical User Interfacr”




08.943,357






“Display of System Information”




6,046,742






“Data Management System Supporting Hot Plug




6,105,089






Operations on a Computer”






“Data Management Method Supporting Hot Plug




6,058,445






Operations on a Computer”






“Alert Configuration 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 Method”




08/941,267






“Black Box Recorder for Information System




08/942,381






Events”






“Method of Recording Information System




08/942,164






Events”






“Method for Automatically Reporting a System




08/942,168






Failure in a Server”






“System for Automatically Reporting a System




6,170,067






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”




6,145,098






“Method for Displaying System Status”




6,088,816






“Fault Tolerant Computer System”




6,175,490






“Method for Hot Swapping of Network




08/943,044






Components”






“A Method for Communicating a Software




6,163,853






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 Applications”




6,134,673






“System for Clustering Software Applications”




08/942,411






“Method for Automatically Configuring a Server




08/942,319






after Hot Add of a Device”






“System for Automatically Configuring a Server




08/942,331






after Hot Add of a Device”






“Method of Automatically Configuring and




6,154,835






Formatting a Computer System and Installing






Software”






“System for Automatically Configuring and




6,138,179






Formatting a Computer System and Installing






Software”






“Determining Slot Numbers in a Computer”




08/942,462






“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”




6,105,151






“Method of Detecting Network Errors”




08/942,573














PRIORITY CLAIM




The benefit under 35 U.S.C. § 119(e) of the following U.S. provisional application(s) is hereby claimed:


















Application







Title




No.




Filing Date











“Remote Access and Control of




60/046,397




May 13,






Environmental Management System”





1997






“Hardware and Software Architecture for




60/047,016




May 13,






Inter-Connecting an Environmental





1997






Management System with a Remote






Interface”






“Self Management Protocol for a Fly-By-




60/046,416




May 13,






Wire Service Processor”





1997






“Hot Plug Software Architecture for Off the




60/046,311




May 13,






Shelf Operating Systems”





1997






“Means for Allowing Two or More Network




60/046,491




May 13,






Interface Controller Cards to Appear as One





1997






Card to an Operating System”














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 interfaces between communication buses in electronic systems. Additionally, the invention relates to an interface between two buses in a computer system.




2. Description of the Related Technology




In the electronics industry, and more particularly in the computer industry, various bus architectures are used to permit parts of computer systems, multiple processors, and controllers to communicate. However, different bus architectures which are governed by different standards are frequently used within a single overall system. Therefore, there is a continuing need to develop interface methods and systems to permit communication between different buses.




One such bus architecture is the Inter-IC control bus (I


2


C bus). The I


2


C bus is a bi-directional two-wire bus (a serial data line and a serial clock line). Advantages of the I


2


C bus architecture are that it provides flexibility and lowers interconnecting costs by reducing board space and pin count. The I


2


C bus has particular application in video cards for computer systems and electronic components such as television tuners, AM/FM tuners, video decoders, video encoders, television audio decoders and video cross bars).




Another common bus architecture is the Industry Standard Architecture (ISA bus). The ISA bus is commonly used in computer systems to transfer data to and from the central processing unit or units.




There is a need for a method and apparatus for interfacing an I


2


C with an ISA bus. Such an interface would permit a CPU in a computer system to communicate with devices interconnected over an I


2


C bus.




SUMMARY OF THE INVENTION




The invention addresses the above and other needs by providing an interface apparatus and method, which in one embodiment includes a system interface processor coupled to a first bus and including a command register accessible via a second bus. A request buffer and a response buffer are provided which are accessible via the second bus and coupled to the interface processor. The request buffer can be used to store information to be transmitted from the second bus to the first via the interface processor while the response buffer can be used to store information to be transmitted from the first bus to the second bus via the interface processor. The interface processor may include a status register to indicate the status of the interface controller. The interface controller may also include a command register to receive commands transmitted over the second bus.











BRIEF DESCRIPTION OF THE DRAWINGS





FIG. 1

is a block diagram of a computer system employing an embodiment of the invention;





FIG. 2

is a system block diagram of one embodiment of a system interface in accordance with the invention;





FIG. 3

is a circuit diagram of an embodiment of the system interface depicted in

FIG. 2

;





FIGS. 4A and 4B

are flow charts depicting the process followed in one embodiment of the invention in connection with transmitting a message through the system interface;





FIGS. 5A and 5B

are flow charts depicting the process for one embodiment of the invention wherein a client monitors the system interface for events;





FIGS. 6A and 6B

are flow charts depicting the process for one embodiment of the invention wherein the system interface responds to requests from devices on the two buses; and





FIGS. 7A

,


7


B and


7


C are flow charts depicting the process carried out by a driver for communicating across the interface.











DETAILED DESCRIPTION OF THE INVENTION




The invention will be described in terms of exemplary embodiments adapted to operate with particular computer systems. However, it will be clear to those skilled in the art that the principles of the invention can be utilized in other computer systems where it is desired to provide an interface between buses. The exemplary embodiments are described below in further detail with reference to the Figures, wherein like elements are referenced by like numerals throughout.




One specific environment in which the invention can be utilized is described in application Ser. No. 08/942,402 entitled “Diagnostic and Managing Distributed Processor System” and application Ser. No. 08/942,168, entitled “Method for Automatically Reporting a System Failure in a Server”, which are incorporated herein by reference above and is described below in general terms in order to provide the reader with an example of a specific application of the invention. However, the invention can be utilized in various other systems.




Referring to

FIG. 1

, a block diagram of an embodiment of a server system


100


is illustrated. The server system


100


may include a central processing unit (CPU)


101


which executes the operating system (OS) software which controls the communications protocol of the server system


100


. The CPU


101


is coupled to an Industry Standard Architecture bus (ISA bus)


103


which transfers data to and from the CPU


101


. The ISA bus


103


and its functionality are well-known in the art Coupled to the ISA bus


103


is a system interface


105


which provides an interface between the ISA bus and an I


2


C bus


107


. The interface


105


acts as an interface between the ISA bus and an I


2


C bus which couples a group of microcontrollers that monitor and control various subsystems and components of the server system


100


. As described in further detail below, a message such as an event message sent to the system interface


105


may indicate that a system failure or error has occurred. Additionally, other information including date, queries and commands may be sent across the system interface


105


. As used herein, the term “event” may refer to the occurrence of any type of system failure or warning. The structure and functionality of the system interface


105


is described in greater detail below with respect to FIG.


2


.




Coupled to the system interface


105


is a system bus


107


. In one embodiment, the system bus


111


is an Inter-IC control bus (I


2


C bus), which transfers data to and from the various controllers and subsystems mentioned above. The command, diagnostic, monitoring, and logging functions of the failure reporting system of the invention may be accessed through the common I


2


C bus protocol. The I


2


C bus protocol uses a slave address as the means of identifying the devices on the bus. Any function can be queried by generating a “read” request, which has its address as part of its protocol format. Conversely, a function can be executed by “writing” to an address specified in the protocol format. Any controller or processor connected to the bus can initiate read and write requests by sending a message on the I


2


C bus to the processor responsible for that function.




Coupled to the system bus


107


is a CPU A controller


109


, a CPU B controller


111


, a chassis controller


112


and four canister controllers


113


. These controllers monitor and control various operating parameters and/or conditions of the subsystems and components of the server system


100


. For example, CPU A controller


109


may monitor the system fan speeds, CPU B controller


111


may monitor the operating temperature of the CPU


101


, the chassis controller


112


may monitor the presence of various circuit boards and components of the server system, and each of the canister controllers


112


may monitor the presence and other operating conditions of “canisters” connected to the server system


100


. A “canister” is a detachable module which provides the ability to expand the number of peripheral component interface (PCI) devices that may be integrated into the server system


100


. Each canister is capable of providing I/O slots for up to four PCI cards, each capable of controlling and arbitrating access to a PCI device, such as a CD ROM disk drive, for example. If one or more of the various controllers detects a failure, the respective controller sends an event message to the system interface


105


which subsequently reports the occurrence of the event to the CPU


101


. In one embodiment, the controllers


109


,


111


and


113


are PIC16C65 microcontroller chips manufactured by Microchip Technologies, Inc. and the chassis controller


112


is a PIC16C74 microcontroller chip manufactured by Microchip Technologies, Inc.




Upon detecting a failure condition, a controller (


109


,


111


,


112


or


113


) not only transmits an event message to the system interface


105


, but also transmits failure information associated with the failure condition to a system recorder


115


connected to the system bus


107


. The system recorder


115


then assigns a time stamp to the failure information and logs the failure by storing the failure information, along with its time stamp, into a system log


117


. The operation and functionality of the system recorder


115


is described in further detail below with reference to FIG.


6


. In one embodiment, the system log


117


is a non-volatile random access memory (NVRAM), which is well-known for its characteristics in maintaining the integrity of data stored within it, even when power to the memory cells is cut off for extended periods of time as a result of a system shutdown or power failure. The following are examples of various monitoring functions performed by some of the controllers described above. However, it is understood that the invention is not limited to these monitoring functions which serve only as examples.




For example, the controller


109


may be coupled to a system fan unit (not shown) and periodically monitor the speed of the fan. In one embodiment, the fan unit transmits a pulse wave form to the controller


109


, the frequency of which is proportional to the rate of rotation of the fan. The controller


107


checks the frequency of the pulse wave form on a periodic basis and determines whether the frequency is within a specified range of acceptable fan speeds. If a measured frequency is too slow, the controller


109


detects a fan failure condition and sends an event message to the system interface


105


. The controller


109


also sends failure information to the system recorder


115


which assigns a time value to the failure information and stores the failure information with its time stamp into the system log


117


. After the system interface


105


receives an event message, it reports the occurrence of the event to the CPU


101


.




As another example, the controller


111


may monitor a system temperature parameter. For example, a temperature sensor (not shown) may be coupled to the CPU


101


for monitoring its operating temperature. In one embodiment, the temperature sensor generates a voltage which is proportional to a measured operating temperature of the CPU


101


. This voltage may then be converted by well-known means into a digital data signal and subsequently transmitted to the controller


109


. The controller


111


then determines whether the measured temperature falls within specified limits. If the measured temperature is either too low or too high, a temperature failure condition is detected and an event message is transmitted to the system interface


105


which subsequently reports the event to CPU


101


and an entry is written to the system log


117


by the system recorder


115


.




In another embodiment, multiple temperature sensors (not shown) are coupled to a temperature bus (not shown). The temperature readings of all the sensors on the temperature bus are monitored every second and are read by temperature transducers connected to the chasis controller


112


. These sensors are read in address order. The criteria for detecting a temperature fault is provided by three temperature limits: a shutdown limit, which is initialized to 70° C.; and two warning limits, which are initialized to 55° C. and −25° C. Each sensor is compared to the shutdown limit. If any temperature exceeds this limit, the system is powered off. However, each sensor is first compared to the warning limit. If any temperature exceeds this limit, an over-limit fault is created, a temperature LED is set, a temperature event message is sent to the system interface


105


, and an entry is written to the system log


117


by the system recorder


115


.




The chassis controller


112


can monitor the presence of power supplies, for example. In one embodiment, power supplies may be detected and identified by a signal line coupling each power supply to a one-wire serial bus which is in turn connected to a serial number chip for identifying the serial number of each power supply. In order to detect the presence of a power supply, a reset pulse may be sent by controller


112


to detect a power supply presence pulse. If there is a change in the presence of a power supply, a presence bit is updated and a power supply event is sent to the system interface


105


. The power supply data is then written to the system log


117


. If a power supply is removed from the system, no further action takes place. The length of the serial number string for that power supply address is set to zero. However, if a power supply is installed, its serial number is read by the one-wire protocol and written to the system log


117


.




As shown in

FIG. 1

, the server system


100


further may include a remote interface


119


also connected to the system bus


107


. The remote interface


119


also receives event messages from the various controllers


109


,


111


,


112


has been detected. The re condition has been detected. The remote interface


119


is a link to the server system


100


for a remote user or client. The term “client” is used to refer to a software program. In one embodiment, the remote interface


119


encapsulates messages in a transmission packet to provide error-free communications and link security. This method establishes a communication protocol in which data is transmitted to and from the remote interface


119


by using a serial communication protocol known as “byte stuffing.” In this communication method, certain byte values in the data stream always have a particular meaning. For example, a certain byte value may indicate the start or end of a message, an interrupt signal, or any other command. A byte value may indicate the type or status of a message, or even be the message itself.




Through the remote interface


119


, a failure condition may be reported to a local system operator or to a remote operator. As used herein, the term “local” refers to a computer, system, operator or user that is not located in the same room as the hardware of the server system


100


but may be located nearby in a different room of the same building or a different building of the same campus, for example. The term “remote” refers to a computer, system or operator that may be located in another city or state, for example, and is connected to the server system via a modem-to-modem connection. The remote operator is typically a client who is authorized to access data and information from the server system


100


through a remote computer


125


.




Coupled to the remote interface


119


is a switch


121


for switching connectivity to the remote interface


119


between a local computer


123


and a remote computer


125


. As shown in

FIG. 1

, the local computer


123


is connected to the remote interface


119


via a local communications line


127


. The local communications line


127


may be any type of communication line, e.g., an RS232 line, suitable for transmitting data. The remote computer


125


is connected to the remote interface via a modem-to-modem connection established by a client modem


129


coupled to a server modem


131


. The client modem


129


is connected to the server modem


131


by a telephone line


133


.




The system interface


105


, the system bus


107


, the controllers


109


,


111


,


112


and


113


, the system recorder


115


, the system log


117


, and the remote interface


119


are part of a network of controllers and processors which form the failure reporting system of the invention. In

FIG. 1

, the failure reporting system can be seen as the blocks surrounded by the dashed lines. The failure reporting system monitors the status and operational parameters of the various subsystems of the server system


100


and provides system failure and error reports to a CPU


101


of the server system


100


. Upon being notified of a system event, the CPU


101


executes a software program which allows a system operator to access further information regarding the system failure condition and thereafter take appropriate steps to remedy the situation.




Referring to

FIG. 2

, a block diagram of one embodiment of the system interface


105


is shown surrounded by dashed lines. The system interface


105


provides the interface between the ISA bus and the I


2


C bus. For example, a system operator can access failure information related to a detected system failure or send commands to devices or the I


2


C bus by means of the system interface


105


. The operating system of the CPU


101


may be an operating system (OS), such as Windows® NT or Netware®, for example.




The system interface


105


may include a system interface processor


201


which receives event and request messages, processes these messages, and transmits command, status and response messages to the ISA bus and thereby to the operating system of the CPU


101


. In one embodiment, the system interface processor


201


is a PIC16C65 controller chip manufactured by Microchip Technology, Inc. which includes an event memory (not shown) organized as a bit vector, having at least sixteen bits. Each bit in the bit vector represents a particular type of event. Writing an event to the system interface processor


201


sets a bit in the bit vector that represents the event. Upon receiving an event message from the controller


109


(FIG.


1


), for example, the system interface


105


sends an interrupt to the CPU


101


via the ISA bus. Upon receiving the interrupt, the CPU


101


will check the status of the system interface


105


in order to ascertain that an event is pending. Alternatively, the CPU


101


may periodically poll the status of the system interface


105


in order to ascertain whether an event is pending. The CPU


101


may then read the bit vector in the system interface processor


201


to ascertain the type of event that occurred and thereafter notify a system operator of the event by displaying an event message on a monitor coupled to the CPU


101


. After the system operator has been notified of the event, as described above, he or she may then obtain further information about the system failure which generated the event message by accessing the system log


117


. The system interface


105


communicates with the CPU


101


by receiving request messages from the CPU


101


and sending response messages back to the CPU


101


. Furthermore, the system interface


105


can send and receive status and command messages to and from the CPU


101


. For example, a request message may be sent from a system operator enquiring as to whether the system interface


105


has received any event messages, or enquiring as to the status of a particular processor, subsystem, operating parameter, etc. A request buffer


203


is coupled to the system interface processor


201


and stores, or queues request data in the order that they are received. Similarly, a response buffer


205


is coupled to the system interface processor


201


and queues outgoing response data in the order that they are received. Collectively the request buffer


203


and the response buffer


205


are referred to as the message data register (MDR)


207


. In one embodiment, the MDR


207


is eight bits wide and has a fixed address on the ISA bus which may be accessed by the server's operating system via the ISA bus


103


coupled to the MDR


207


. As shown in

FIG. 2

, the MDR


207


has an I/O address (on the ISA bus) of 0CC0h. “Reads” to that address access the response buffer


205


while “writes” to that address access the request buffer


203


.




The system interface


105


may further include a command register and a status register which are collectively referred to as the command status register (CSR)


209


which controls operations and reports on the status of commands. In one embodiment the CSR has an I/O address (on the ISA bus) of OCC1h and is eight bits wide. Reads to that address access the status register and writes to that address access the command register. The operation and functionality of CSR


209


are described in further detail below.




Both synchronous and asynchronous I/O modes are provided by the system interface


105


. Thus, an interrupt line


211


is coupled between the system interface processor


201


and the ISA bus


103


and provides the ability to request an interrupt when asynchronous I/O is complete, or when an event occurs while the interrupt is enabled. As shown in

FIG. 2

, in one embodiment, the address of the interrupt line


211


is fixed and indicated as IRQ


15


which is an interrupt address number used specifically for the ISA bus


103


.




The MDR


207


and the request and response buffers


203


and


205


, respectively, transfer messages between a system operator or client and one or more as of the microcontrollers on the I


2


C bus. The buffers


203


and


205


may utilize the first-in first-out (FIFO) technique. That is, the next message processed is the one that has been in the queue the longest time. The buffers


203


and


205


have two functions: (


1


) they match speeds between the high-speed ISA bus


103


and the slower system bus


107


(FIG.


1


); and (


2


) they serve as interim buffers for the transfer of messages—this relieves the system interface processor


201


of having to provide this buffer.




When the MDR


207


is written to via the ISA bus


103


, it loads a byte into the request buffer


203


. When the MDR


207


is read from via the ISA bus


203


, it unloads a byte from the response buffer


205


. The system interface processor


201


reads and executes the request from the request buffer


203


when a message command is received in the CSR


209


. A response message is written to the response buffer


205


when the system interface processor


201


completes executing the command. The system operator or client can read and write message data to and from the buffers


203


and


205


by executing read and write instructions to the MDR


207


via the ISA bus.




The CSR


209


has two functions. The first is to issue commands, and the second is to report on the status of the execution of a command. The system interface


105


commands are usually executed synchronously. That is, after issuing a command, the client polls the CSR status to confirm command completion. In addition to synchronous I/O mode, the client can also request an asynchronous I/O mode for each command by setting a “Asyn Req” bit in the command. In this mode, an interrupt is generated and sent to the ISA bus


103


, via the interrupt line


211


, after execution of the command has been completed.




The interrupt line


211


may use an ISA IRQ


15


protocol, as mentioned above, which is well-known in the art. Alternatively, the interrupt line


211


may utilize a level-triggered protocol. A level-triggered interrupt request is recognized by keeping the message at the same level, or changing the level of a signal, to send an interrupt. In contrast, an edge-triggered interrupt, for example, is recognized by the signal level transition. A client can either enable or disable the level-triggered interrupt by sending “Enable Ints” and “Disable Ints” commands. If the interrupt line is enabled, the system interface processor sends an interrupt signal to the ISA bus


103


, either when an asynchronous I/O is complete or when an event has been detected.




In the embodiment shown in

FIG. 2

, the system interface


105


may be a single-threaded interface. That is, only one client, or system operator, is allowed to access the system interface


105


at a time. Therefore, a program or application should allocate the system interface


105


for its use before using it, and then deallocate the interface


105


when its operation is complete. The CSR


209


indicates which client or operator is allocated access to the system interface


105


at a particular time.




For example, in one embodiment, the last three bits of the CSR register are used to indicate whether a client is using (has control) of the system interface


105


. Thus, the last three bits identify whether the interface is available or who has control of the interface. Whether someone has control of the system interface


105


can be determined by simply reading the CSR register.




When using the CSR as a command register, the client writes an 8-bit command to the CSR register. In one embodiment, the commands are:




Allocate The first command in a sequence of commands. This command clears both request register


203


and response register


205


. The allocate command can only be successfully accomplished if the interface


105


is not presently allocated to another client.




Deallocate: The last command in a sequence of commands. This command clears the “done” bit and the “interface owner ID” fields in the CSR status register.




Enable Interrupts: This enables the interface


105


to send interrupts to the ISA bus.




Disable Interrupts: This command disables the interface


105


from sending interrupts to the ISA bus.




Message: This command informs the interface


105


that a command to be transmitted over the e


2


C bus has been placed in the request buffer


203


.




Clear Done: This command clears the done bit and the CSR status register.




Clear Interrupt This command clears the interrupt request bit in the CSR status register.




Request: This command should be executed after receiving an interrupt in order to turn off the hardware interrupt request.




Reset: This command unconditionally clears all bits in the CSR status register except the “event indication” bit. This command aborts any currently in progress message operation and clears any interrupt.




In one embodiment, the 8bit CSR status register has the following format: bit


7






(error indication)




bit


6


(interrupt enable)




bit


5


(event indication)




bit


4


(command done)




bit


3


(interrupt request)




bit


2


-


0


(interface owner identification).




Turning now to

FIG. 3

, a detailed description of one embodiment of the circuit of the system interface


105


(

FIG. 2

) will be provided. Generally speaking, the system interface


105


may include system interface processor


201


(in one embodiment a PIC16C65 microcontroller manufactured by Microchip Technologies, Inc is used), request buffer


303


in the form of a FIFO memory chip, response buffer


305


, also in the form of a FIFO memory chip, and address decoder


302


. The system interface processor


201


is coupled to the data line


304


and the clock line


306


of the I


2


C bus. The system interface processor


201


is also coupled to the ISA bus via data lines RD


0


-


7


. That interface to the ISA bus corresponds to CSR


209


in FIG.


2


. System interface processor


201


is also coupled to request buffer


303


and response buffer


305


via lines RB


0


through RB


7


indicated at


308


. Output RC


2


of system interface processor


201


is coupled to interrupt line IRQ


15


of the ISA bus


103


.




Request buffer


303


has its output from lines D


0


-


7


coupled to the ISA bus. Response register


305


has its input lines Q


7


-Q


0


coupled to the ISA bus. This allows for data to be received from the ISA bus by the request buffer


303


and data to be sent to the ISA bus from the request buffer


305


. Data is sent, or read from, the request buffer


303


by the system interface processor


201


over the lines indicated at


308


discussed above. Similarly, data is sent from the system interface processor


201


to the response buffer


305


also over lines indicated as


308


.




The system interface processor


201


, request buffer


303


and response buffer


305


are read from over the ISA bus or are written to over the ISA bus according to ISA address and read/write signals which may include timing and enable signals generally indicated as


310


. Address decoder


302


generates a write signal for request buffer


303


, a read signal for response buffer


305


and both read and write and enable signals for system interface processor


201


in response to the ISA address and read/write signals


310


. Specifically, when ISA address 0CC0H is present at the address decoder and an ISA write signal is present, data is received by (or written to) request buffer


303


. In response to ISA address 0CC0H and a read signal, address decoder


302


generates the read signal for response buffer


305


which allows data to be read from that buffer by the ISA bus. When ISA address 0CC1H is present and a read signal is also present, address decoder


302


sends the enable and read signals to signal interface processor


201


which enables data to be read at the ports represented by lines R


0


-


7


in the system interface processor


201


. Finally, when ISA address 0CC1H and a write signal are present, address decoder


302


generates the write and the enable signals for system interface processor


201


which enables data to be written over the ISA bus to the system interface processor


201


at lines RD


0


-


7


.




Turning now to

FIGS. 4A and 4B

, the process followed in one embodiment by a client in connection with transmitting a message through the interface


105


to a device on the I


2


C bus, the message operation, will be described. The flowcharts represent the steps which are accomplished in one embodiment by software operating within the computer system. In one embodiment, the software which accomplishes these steps is in the form of a driver routine operating in CPU


101


(

FIG. 1

) that is discussed below with regard to

FIGS. 7A-C

.




Referring first to

FIG. 4A

, the process begins with step


404


. At step


404


, the client reads the CSR status register


209


(

FIG. 2

) to determine whether the interface owner ID is cleared. This indicates whether another client has control of the interface


105


. If the interface owner ID is not clear, as indicated by circle


406


, the process stops. If the interface owner ID is clear, the process continues to step


408


where the client issues the allocate command to attempt to take control of the interface


105


.




Next, at step


410


, the client determines whether its allocate command was successful by again reading the CSR status register and then determining whether its own identification now appears in the interface owner ID portion of the status register. If that has not occurred, the process continues to step


412


. If the interface owner ID is not clear, indicating that a different client has gained control of the interface, the process then ends at step


414


. If the interface owner ID is clear, the process continues to step


416


, wherein the client can either return to step


410


and again read the status register to determine if its own ID is present, or it can continue on to the timeout process indicated by circle


418


and which is described below in more detail with reference to FIG.


4


B.




If at step


410


the allocate command is successful and the client's ID is then read from the status register, the process continues to step


420


. At this step, the client has successfully taken control of interface


105


.




As described above, the allocate command, when successful, clears both the request buffer and the response buffer. Therefore, at step


420


, the client now writes the request message to the request buffer


203


. Next, at step


422


, the client writes the “message” command to the command status register. Receipt of the “message” command by the interface


105


causes the interface to begin processing the information in the request buffer


203


. Next, at step


424


, the client waits for an interrupt issued by the interface


105


. The interface


105


issues the interrupt once it has received a response to the “message” command from the ultimate recipient or I


2


C bus. When the interrupt is issued, the client then reads the response buffer


205


as indicated at step


426


.




Continuing now to

FIG. 4B

, the process continues to the step represented by box


427


where the client issues the clear interrupt request command. As was described above, the clear interrupt request command turns off the interrupt generated by the interface


105


. Next, at step


428


, the client then reads the command status register to determine whether the interrupt request bit has been cleared which indicates that the clear interrupt request command has been successful. If the interrupt request bit in the command status register has not been cleared, the process continues to step


430


. At step


430


, the client either proceeds to the timeout process represented by circle


432


or returns to repeat step


428


. Once the interrupt request bit has been cleared, the process continues on to step


434


.




At step


434


the client issues the deallocate command in order to release control of the interface


105


. Next at step


436


, the client reads the command status register to determine if the interface owner ID has been cleared which indicates that the deallocate command has been successful. If the interface owner ID has not been cleared, the process continues to step


438


wherein the client either proceeds to repeat step


436


or proceeds to the timeout process as represented by circle


440


.




If at step


436


the client determines that the interface owner ID has been cleared, the process continues is completed as indicated at step


442


once.




Referring to the bottom of

FIG. 4B

, the timeout process referred to above will now be described. At step


444


client issues the reset command which clears all the bits in the command status register except for the event bit and aborts any in progress message operation and clears any current interrupts. Next, at step


446


, the client goes into a wait state. In some embodiments the unit state may be for 500 microseconds. This wait state provides time for the buffers


203


and


205


to clear. Finally, the process returns to the start of the process


402


in FIG.


4


A.




Turning now to

FIGS. 5A and 5B

, the process for one embodiment wherein the client monitors the interface for events which are reported by the microcontrollers on the I


2


C bus will be described. This process is useful in systems in which the devices on the I


2


C bus monitor certain parameters of the system such as temperature. The flowcharts represent the steps which are accomplished by software operating within the computer system.




First, at decision block


510


in

FIG. 5A

, the client reads the CSR status register to determine whether the interface owner ID is cleared. This indicates whether any client has control of the interface


105


at this time. If the interface ID is not clear, meaning a client has control of the interface, the process is exited. If the interface owner ID is clear, the process continues on to step


512


. At step


512


the client issues the allocate command which clears the request and response buffers and writes the client's identification into the interface owner ID in the CSR status register. At step


514


, the client determines whether its allocate command was successful by again reading the CSR status register and then determining whether its own identification now appears in the interface owner ID portion of the status register. If the command was not successful, the process continues to the step represented by decision block


516


. At decision block


516


, if the interface owner ID is not clear, the process stops. If it is clear, the process continues to step


518


.




At step


518


the system can either go into a timeout process which is previously the same as that described with reference to

FIG. 4B

or the process can return to step


514


.




Once the client has successfully taken control or ownership of the interface


105


at step


514


, the process continues to the step represented by box


521


. At this step, the client issues the enable interrupts command writing that command to the CSR. This command enables the interface


105


to issue an interrupt over line ISA IRQ


15


.




Next, at decision block


522


, the client reads the CSR status register to determine whether the interrupt enable bit was successfully set. If the interrupt enable bit was not successfully set, the process continues to step


524


wherein the client either continues to the timeout process described previously or returns to step


522


.




Once the enable bit has been successfully set at step


522


, the process continues to step


526


where it waits for an interrupt to be generated by interface


105


.




When an interrupt is generated on the ISA bus by the interface


105


(FIG.


2


), the process proceeds to step


528


wherein the client writes a request message to the request buffer. Next, at step


530


the client issues the clear done command described above. Recall that this command clears the done bit in the CSR status register. The process then continues to step


532


as will be described with reference to FIG.


5


B.




At step


532


, the client reads the CSR status register to determine if the done bit was successfully cleared. If it was not successfully cleared, the process continues to decision block


534


where the client either goes to the timeout process described previously or repeats the step represented by decision block


532


. Once the done bit has been successfully cleared, the process continues to step


536


. At step


536


, the client issues the message command which, as described above, causes the interface


105


to place the message which caused the interrupt onto the response buffer


205


(FIG.


2


). Once this has been accomplished, the done bit is set by the interface


105


.




Next, at decision block


538


, the client reads the CSR status register to determine whether the done bit has been set. If the done bit has not been set, as the process continues to step


540


, wherein the client either proceeds to the timeout process as described above or repeats the step represented by decision block


538


.




Once the done bit has been set, the process continues to step


542


. At step


542


the client reads the message which has been written to the response buffer


205


by the interface


105


. Next, step at


544


, the client issues the deallocate command which relinquishes control of the interface the details of which were described previously. Next, at step


546


, the client confirms that the interface owner ID was successfully cleared by the deallocate command. If the interface owner ID in the command status register was not successfully cleared, the process proceeds to decision block


548


wherein the client either goes to the timeout process or repeats step


546


. Once the interface owner ID is successfully cleared, the process is completed.




The process by which the system interface


105


handles requests from other microcontrollers on the I


2


C bus


107


and clients on the ISA bus


103


(

FIG. 2

) will now be described. The flowcharts in

FIGS. 6A and 6B

represent the steps or actions which are accomplished in one embodiment by firmware or software operating within the interface processor


201


.




Beginning with step


604


, the system interface


105


determines whether the I


2


C bus


107


has timed-out. If the bus has timed-out, then the process proceeds to step


606


wherein the system interface


105


resets the I


2


C bus


107


.




If the I


2


C bus has not timed out, the process continues to step


608


wherein the system interface


105


determines whether any events have occurred. An event occurs when the system interface


105


receives information from another microcontroller over the I


2


C bus. If an event has occurred, the process continues to step


610


wherein the system interface


105


sets the CSR register event bit to one. The system interface


105


also sends an interrupt to the ISA bus if the interrupt is enabled.




The process continues to step


612


from step


610


or proceeds directly to step


612


from step


608


if no event has occurred. At step


612


the system interface


105


check to see if a command has been received in the CSR register


209


(FIG.


2


). If the system interface


105


does not find a command, then the process returns to start


602


. Otherwise, if the system interface finds a command, then the system interface starts to parse the command and as represented by steps


616


-


628


.




If the “allocate” command is present, the process continues to step


616


wherein the system interface


105


resets (clears) the response and request buffers


203


,


205


and resets the done bit in the CSR. The system interface also sets the CSR Interface Owner ID. The Owner ID bits identify which client has control of the system interface


105


. The process then returns to start


602


.




If the “de-allocate” command is present at step


612


, the process continues to step


618


wherein the system interface


105


clears the response and request buffers


203


,


205


, resets the done bit in the CSR and clears the Owner ID bits. The process then returns to start


602


.




If the “clear done bit” command is present at step


612


, the process continues to step


620


wherein the system interface


105


clears the done bit in the CSR. The process then returns to start


602


.




Referring now to

FIG. 7B

, if the “enable interrupt command” is present at step


612


, the process continues to step


622


. At step


622


the system interface


105


sets the interrupt enable bit in the CSR. The process then returns to start


602


.




If the “disable interrupt” command is present at step


612


, the process continues to step


624


, wherein the system interface


105


clears the interrupt enable bit in the CSR. The process then returns to start


602


(FIG.


6


A).




If the “clear interrupt request” command is present at step


612


, the process continues to step


626


, wherein, the system interface


105


clears the interrupt request bit in the CSR. The process then returns to start


602


(FIG.


6


A).




If the “message” command is present at step


612


, the process continues to step


628


. At step


628


, in response to the message command, the system interface


105


reads data from the request buffer


203


(FIG.


2


). The first data read from the request buffer by the interface I


2


C is the ID (address) of the microcontroller for which the message in the request buffer is intended. Next, at step


630


the interface determines whether the ID is its own. If it is, the process continues to step


632


wherein the interface itself responds to the message and then returns to start


602


in FIG.


6


A.




If it is determined at step


630


that the ID is not that of the interface, the process continues to step


634


wherein the message is sent over the I


2


C bus to the appropriated device. The process then returns to start


602


in FIG.


6


A.




Referring now to

FIGS. 7A-C

, an interface driver will be described, which in one embodiment operates in CPU


101


(

FIG. 1

) to permit other software programs (clients) to access the interface


105


. The driver has three aspects: message queuing (FIG.


7


A), interrupt processing (FIG.


7


B), and message processing (FIG.


7


C). Each of these aspects will be described with reference to the figures.




Referring first to

FIG. 7A

, the message queuing process will be described. The message queuing process is initiated by a call from a client as indicated at step


701


. The message queuing process then begins at step


702


, wherein the driver attempts to acquire the message queue semaphore. The message queue semaphore is used to avoid multiple simultaneous accesses to the message queue. Once the message queue semaphore has been acquired, the process continues to step


704


wherein the driver inserts the message from the client into the message queue and changes its status flag to indicate that a message has been queued. The client can transmit to the driver the actual message, or merely a pointer to a buffer containing the message. The message may include a pointer to a memory location where a response message can be written. Next, at step


706


, the message semaphore is released. This process is repeated every time a client call the driver to queue a message.




Turning next to

FIG. 7B

, the processing by the driver of interrupts generated by the interface


105


will be described. The process begins after an interrupt has been transmitted to the ISA bus by the interface


105


. Starting at step


710


the driver reads the CSR register


209


(see FIG.


2


). Next, at step


712


, the driver determines whether the “done bit” in the status register is set. This provides a first indication of whether the interrupt indicates that a response to a message has arrived at the interface or whether the interrupt indicates that an event has occurred. If the done bit is set, the process then continues to step


714


. At step


714


, the driver, in response to the done bit being set, changes the status flag associated with the message to indicate that a message has arrived. The use of this flag is described more fully below with reference to FIG.


7


C. The processing then continues on to step


716


.




If at step


712


it is determined that the done bit is not set, the process bypasses step


714


and proceeds directly to step


716


. At step


716


, the driver determines whether the event bit in the status register is set. If the event bit is not set, the interrupt processing is complete. However, if the event bit is set, indicating that an event has occurred, the process continues to step


718


. At step


718


the driver schedules a process to read event information. That process will be described in further detail below with reference to blocks


722


-


726


. Next, at step


720


the driver disables the event interrupt by writing the disable interrupts command to the CSR. Then, at step


721


the driver clears the interrupt by writing the clear interrupt command to the CSR which clears the interrupt request bit in the CSR status register.




As noted above, at step


718


, the driver initiates the process which includes steps


722


-


726


. Starting at step


722


, the driver initiates a process or thread which is treated by the message insertion process, described previously with reference to

FIG. 7A

, as a separate client. At step


724


the process writes a message to the message queue. The particular message may include a query to the devices on the I


2


C bus to report back the status of any events. Then, at step


725


the driver may notify clients that have registered for notification of the particular event. Such a registry may be maintained by the driver or by another program. Next, at step


726


the process re-enables the event interrupts by writing the enable interrupts command to the CSR. That completes the process.




Referring to

FIG. 7C

, the process by which the driver processes messages in the message queue will be described. First, at step


730


, the driver gets the first message in the queue. If no messages are in the queue, the driver waits until a message is queued. Once the driver has obtained the first message in the queue, it proceeds to step


732


. At step


732


, the driver determines whether the status of the message is “message queued”. If it does, the process proceeds to step


734


wherein the driver writes the allocated command to the CSR


209


to obtain allocation of the interface


105


. Next, at step


736


the queued message is written to request buffer


203


. Then, at step


738


the driver writes the message command to the CSR


209


. Next, at step


740


the driver changes the message status to “result awaited”. The process then returns to step


730


.




If at step


732


the driver determines the message does not have “status queued” associated with it, then the process proceeds to step


742


. At step


742


the driver determines whether a message result has arrived as indicated by the status flag associated with the message. Note that the status flag is set by the interrupt processing described previously with reference to step


714


in FIG.


7


B. If a message has not arrived, the process returns to step


730


. If a message has arrived the process continues to step


744


wherein the message being processed is removed from the queue.




Next, at step


746


the length or size of the response received is determined. In one embodiment, the first two bytes of the response indicate its length. Then, at step


748


the driver verifies that the client has allocated sufficient space to receive the response. If sufficient space has not been allocated, the process proceeds to step


758


wherein the driver calls the client with a message indicating that an insufficient buffer was allocated for the response and the process continues to step


754


described below.




If sufficient space has been allocated, the process continues to step


750


wherein the response in the response register


205


is written to the memory location allocated by the client for the response. Next, at


752


, the message status is set to CSR command successful, indicating that the message has successfully been read.




Next, at step


754


the driver calls the message back routine selected by the client which informs the client that the response has been successfully received. Then, at step


756


the driver deallocates the interface and returns to step


730


to begin processing the next message in the queue.




The invention has been shown and described with respect to particular embodiments. However, it will be understood by those skilled in the art that various changes may be made therein without departing from the spirit and scope of the invention. The scope of the invention is 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.



Claims
  • 1. A method of controlling the transfer of information between one or more processors on a first bus and one or more processors on a second bus through an interface having an interface processor, comprising:writing information to be transferred across the interface from a second processor on the second bus to a first processor on the first bus to a request buffer; writing a command from the second processor via the second bus to the interface processor to transfer the information residing in the request buffer to the first processor via the first bus; writing information to be transferred across the interface from the first processor on the first bus to the second processor on the second bus to a response buffer; and reading the information in the response buffer via the second bus.
  • 2. The method of claim 1, further including:generating an interrupt on the second bus in response to a request from the first processor on the first bus; and in response to the interrupt, reading the information in the response buffer.
  • 3. The method of claim 1, further including:reviewing a status register associated with the interface to determine whether the interface is currently allocated; if the interface is not currently allocated, then allocating control of the interface to a single client on the second bus.
  • 4. The method of claim 2, wherein the information written to the request buffer includes a command to a processor on the first bus and wherein the information written to the response buffer is transmitted in response to the command.
  • 5. The method of claim 3, further including:setting the status register to indicate that a processor on the first bus has reported an event and generating an interrupt on the second bus.
  • 6. A method of transferring information between first and second electronic buses through an interface having an interface processor, comprising:reviewing a status register associated with the interface to determine whether a transfer between the buses is in process; if a transfer between the buses is not in process, then writing information to be transferred across the interface from the second bus to the first bus to a request buffer; writing a command to the interface processor to transfer the information residing in the request buffer to the first bus; writing information to be transferred across the interface from the first bus to the second bus to a response buffer; and generating a message on the second bus indicating that information has been written in the response buffer.
  • 7. The method of claim 6, wherein the message generated is an interrupt on the second bus generated in response to a request from a device on the first bus and in response to the interrupt, the information in the response buffer is read from the second bus.
  • 8. The method of claim 6, wherein the information written to the request buffer includes a command to a device on the first bus and wherein the information written to the response buffer is transmitted in response to the command.
  • 9. The method of claim 6, further including:setting the status register to indicate that a device on the first bus has reported an event and generating an interrupt on the second bus.
  • 10. A method of controlling the transfer of information between a first bus and a plurality of clients on a second bus through an interface having an interface processor, comprising:reviewing a status register associated with the interface to determine whether the interface is currently allocated to one of said plurality of clients; if the interface is not currently allocated to a client, then allocating control of the interface to a single client on the second bus; writing information to be transferred across the interface from the second bus to the first bus to a request buffer; writing a command to the interface processor to transfer the information residing in the request buffer to the first bus; writing information to be transferred across the interface from the first bus to the second bus to a response buffer; generating an interrupt on the second bus in response to a request from a device on the first bus; and in response to the interrupt, reading the information in the response buffer from the second bus.
  • 11. A method of controlling the transfer of information between a first bus and clients on a second bus through an interface including an interface processor, comprising:placing client messages to be transferred across the interface into a queue; reviewing a status register associated with the interface to determine whether the interface is currently allocated to a client; if the interface is not currently allocated to a client, then assuming control of the interface; writing a first of the client messages in the queue to a request buffer; writing a command to the interface processor to transfer the message in the request buffer to the first bus; determining whether a message result has arrived in a response buffer in response to a client message that was transferred to the first bus; determining the size of the response in the response buffer; verifying that the client associated with the response in the response buffer has allocated sufficient space to receive the response; and writing the contents of the response buffer to a memory location allocated by the client.
  • 12. The method of claim 11, further including repeating the method for each message placed in the queue.
  • 13. The method of claim 11, further including deallocating the interface.
  • 14. A program storage device storing instructions that when executed by a computer perform the method comprising:writing information to be transferred across a bus interface having an interface processor from a second processor on a second bus to a first processor on a first bus to a request buffer; writing a command from the second processor via the second bus to the bus interface to transfer the information residing in the request buffer to the first processor via the first bus; writing information to be transferred across the bus interface from the first processor on the first bus to the second processor on the second bus to a response buffer; and reading the information in the response buffer via the second bus.
  • 15. A program storage device storing instructions that when executed by a computer perform the method comprising:reviewing a status register associated with a bus interface between first and second buses to determine whether the bits interface is currently allocated to one of a plurality of clients; if the bus interface is not currently allocated to a client, then allocating control of the bus interface to a single client on the second bus; writing information to be transferred across the bus interface from the second bus to the first bus to a request buffer; writing a command to a bus interface processor to transfer the information residing in the request buffer to the first bus; receiving an interrupt on the second bus; in response to the interrupt, reading information in a response buffer associated with the bus.
  • 16. A method of transferring information between an I2C bus and an ISA bus through an interface, comprising:reviewing a status register associated with the interface to determine whether the interface is currently allocated; if the interface is not currently allocated, then allocating control of the interface to a client on the ISA bus; writing information to be transferred across the interface from the ISA bus to the I2C bus to a request buffer; writing a command to an interface processor to transfer the information residing in the request buffer to the I2C bus; writing information to be transferred across the interface from the I2C bus to the ISA bus to a response buffer; generating an interrupt on the ISA bus in response to a request from a device on the I2C bus; and reading the information in the response buffer via the ISA bus.
RELATED APPLICATIONS

This application is a continuation of U.S. Pat. No. 5,987,554, issued Nov. 16, 1999. The subject matter of U.S. Pat. No. 6,182,180, issued Jan. 30, 2001 is related to this application.

US Referenced Citations (263)
Number Name Date Kind
4057847 Lowell et al. Nov 1977 A
4449182 Rubinson et al. May 1984 A
4672535 Katzman et al. Jun 1987 A
4692918 Elliott et al. Sep 1987 A
4695946 Andreasen et al. Sep 1987 A
4707803 Anthony, Jr. et al. Nov 1987 A
4769764 Levanon Sep 1988 A
4774502 Kimura Sep 1988 A
4821180 Gerety et al. Apr 1989 A
4835737 Herrig et al. May 1989 A
4949245 Martin et al. Aug 1990 A
4968977 Chinnaswamy et al. Nov 1990 A
4999787 McNally et al. Mar 1991 A
5006961 Monico Apr 1991 A
5007431 Donehoo, III Apr 1991 A
5033048 Pierce et al. Jul 1991 A
5051720 Kittirutsunetorn Sep 1991 A
5073932 Yossifor et al. Dec 1991 A
5103391 Barrett Apr 1992 A
5118970 Olson et al. Jun 1992 A
5121500 Arlington et al. Jun 1992 A
5123017 Simpkins et al. Jun 1992 A
5136708 Lapourtre et al. Aug 1992 A
5138619 Fasang et al. Aug 1992 A
5157663 Major et al. Oct 1992 A
5210855 Bartol May 1993 A
5245615 Treu Sep 1993 A
5247683 Holmes et al. Sep 1993 A
5253348 Scalise Oct 1993 A
5261094 Everson et al. Nov 1993 A
5265098 Mattson et al. Nov 1993 A
5266838 Gerner Nov 1993 A
5269011 Yanai et al. Dec 1993 A
5272382 Heald et al. Dec 1993 A
5272584 Austruy et al. Dec 1993 A
5276863 Heider Jan 1994 A
5280621 Barnes et al. Jan 1994 A
5283905 Saadeh et al. Feb 1994 A
5307354 Cramer et al. Apr 1994 A
5311451 Barrett May 1994 A
5317693 Cuenod et al. May 1994 A
5329625 Kannan et al. Jul 1994 A
5337413 Liu et al. Aug 1994 A
5351276 Doll, Jr. et al. Sep 1994 A
5367670 Ward et al. Nov 1994 A
5379184 Barraza et al. Jan 1995 A
5379409 Ishikawa Jan 1995 A
5386567 Lien et al. Jan 1995 A
5388267 Chan et al. Feb 1995 A
5402431 Saadeh et al. Mar 1995 A
5404494 Garney Apr 1995 A
5423025 Goldman et al. Jun 1995 A
5430717 Fowler et al. Jul 1995 A
5430845 Rimmer et al. Jul 1995 A
5432715 Shigematsu et al. Jul 1995 A
5432946 Allard et al. Jul 1995 A
5438678 Smith Aug 1995 A
5440748 Sekine et al. Aug 1995 A
5455933 Schieve et al. Oct 1995 A
5463766 Schieve et al. Oct 1995 A
5471617 Farrand et al. Nov 1995 A
5471634 Giorgio et al. Nov 1995 A
5473499 Weir Dec 1995 A
5483419 Kaczeus, Sr. et al. Jan 1996 A
5485550 Dalton Jan 1996 A
5485607 Lomet et al. Jan 1996 A
5487148 Komori et al. Jan 1996 A
5491791 Glowny et al. Feb 1996 A
5493574 McKinley Feb 1996 A
5493666 Fitch Feb 1996 A
5513314 Kandasamy et al. Apr 1996 A
5513339 Agrawal et al. Apr 1996 A
5517646 Piccirillo et al. May 1996 A
5526289 Dinh et al. Jun 1996 A
5528409 Cucci et al. Jun 1996 A
5530810 Bowman Jun 1996 A
5533198 Thorson Jul 1996 A
5535326 Baskey et al. Jul 1996 A
5539883 Allon et al. Jul 1996 A
5542055 Amini et al. Jul 1996 A
5546272 Moss et al. Aug 1996 A
5548712 Larson et al. Aug 1996 A
5555510 Verseput et al. Sep 1996 A
5559764 Chen et al. Sep 1996 A
5559958 Farrand et al. Sep 1996 A
5559965 Oztaskin et al. Sep 1996 A
5564024 Pemberton Oct 1996 A
5566299 Billings et al. Oct 1996 A
5566339 Perholtz et al. Oct 1996 A
5568610 Brown Oct 1996 A
5568619 Blackledge et al. Oct 1996 A
5572403 Mills Nov 1996 A
5577205 Hwang et al. Nov 1996 A
5579487 Meyerson et al. Nov 1996 A
5579491 Jeffries et al. Nov 1996 A
5581712 Herrman Dec 1996 A
5581714 Amini et al. Dec 1996 A
5584030 Husak et al. Dec 1996 A
5586250 Carbonneau et al. Dec 1996 A
5588121 Reddin et al. Dec 1996 A
5588144 Inoue et al. Dec 1996 A
5592610 Chittor Jan 1997 A
5596711 Burckhartt et al. Jan 1997 A
5598407 Bud et al. Jan 1997 A
5602758 Lincoln et al. Feb 1997 A
5604873 Fite et al. Feb 1997 A
5606672 Wade Feb 1997 A
5608876 Cohen et al. Mar 1997 A
5615207 Gephardt et al. Mar 1997 A
5621159 Brown et al. Apr 1997 A
5621892 Cook Apr 1997 A
5622221 Genga, Jr. et al. Apr 1997 A
5625238 Ady et al. Apr 1997 A
5627962 Goodrum et al. May 1997 A
5628028 Michelson May 1997 A
5630076 Saulpaugh et al. May 1997 A
5631847 Kikinis May 1997 A
5632021 Jennings et al. May 1997 A
5638289 Yamada et al. Jun 1997 A
5644470 Benedict et al. Jul 1997 A
5644731 Liencres et al. Jul 1997 A
5651006 Fujino et al. Jul 1997 A
5652832 Kane et al. Jul 1997 A
5652839 Giorgio et al. Jul 1997 A
5652892 Ugajin Jul 1997 A
5652908 Douglas et al. Jul 1997 A
5655081 Bonnell et al. Aug 1997 A
5655083 Bagley Aug 1997 A
5655148 Richman et al. Aug 1997 A
5659682 Devarakonda et al. Aug 1997 A
5664118 Nishigaki et al. Sep 1997 A
5664119 Jeffries et al. Sep 1997 A
5666538 DeNicola Sep 1997 A
5668992 Hammer et al. Sep 1997 A
5669009 Buktenica et al. Sep 1997 A
5671371 Kondo et al. Sep 1997 A
5675723 Ekrot et al. Oct 1997 A
5680288 Carey et al. Oct 1997 A
5684671 Hobbs et al. Nov 1997 A
5689637 Johnson et al. Nov 1997 A
5692947 Kellum et al. Dec 1997 A
5696895 Hemphill et al. Dec 1997 A
5696899 Kalwitz Dec 1997 A
5696949 Young et al. Dec 1997 A
5696970 Sandage et al. Dec 1997 A
5704031 Mikami et al. Dec 1997 A
5708775 Nakamura Jan 1998 A
5708776 Kikinis Jan 1998 A
5712754 Sides et al. Jan 1998 A
5715456 Bennett et al. Feb 1998 A
5721935 DeSchepper et al. Feb 1998 A
5724529 Smith et al. Mar 1998 A
5726506 Wood Mar 1998 A
5727207 Gates et al. Mar 1998 A
5732266 Moore et al. Mar 1998 A
5737708 Grob et al. Apr 1998 A
5740378 Rehl et al. Apr 1998 A
5742514 Bonola Apr 1998 A
5742833 Dea et al. Apr 1998 A
5747889 Raynham et al. May 1998 A
5748426 Bedingfield et al. May 1998 A
5752164 Jones May 1998 A
5754797 Takahashi May 1998 A
5758165 Shuff May 1998 A
5758352 Reynolds et al. May 1998 A
5761033 Wilhelm Jun 1998 A
5761045 Olson et al. Jun 1998 A
5761085 Giorgio Jun 1998 A
5761462 Neal et al. Jun 1998 A
5761707 Aiken et al. Jun 1998 A
5764924 Hong Jun 1998 A
5764968 Nimomiya Jun 1998 A
5765008 Desai et al. Jun 1998 A
5765198 McCrocklin et al. Jun 1998 A
5767844 Stoye Jun 1998 A
5768541 Pan-Ratzlaff Jun 1998 A
5768542 Enstrom et al. Jun 1998 A
5771343 Hafner et al. Jun 1998 A
5774645 Beaujard et al. Jun 1998 A
5774741 Choi Jun 1998 A
5777897 Giorgio Jul 1998 A
5778197 Dunham Jul 1998 A
5781703 Desai et al. Jul 1998 A
5781716 Hemphill et al. Jul 1998 A
5781744 Johnson et al. Jul 1998 A
5781767 Inoue et al. Jul 1998 A
5781798 Beatty et al. Jul 1998 A
5784555 Stone Jul 1998 A
5784576 Guthrie et al. Jul 1998 A
5787019 Knight et al. Jul 1998 A
5787459 Stallmo et al. Jul 1998 A
5787491 Merkin et al. Jul 1998 A
5790775 Marks et al. Aug 1998 A
5790831 Lin et al. Aug 1998 A
5793948 Asahi et al. Aug 1998 A
5793987 Quackenbush et al. Aug 1998 A
5794035 Golub et al. Aug 1998 A
5796185 Takata et al. Aug 1998 A
5796580 Komatsu et al. Aug 1998 A
5796981 Abudayyeh et al. Aug 1998 A
5797023 Berman et al. Aug 1998 A
5798828 Thomas et al. Aug 1998 A
5799036 Staples Aug 1998 A
5799196 Flannery Aug 1998 A
5801921 Miller Sep 1998 A
5802269 Poisner et al. Sep 1998 A
5802298 Imai et al. Sep 1998 A
5802305 McKaughan et al. Sep 1998 A
5802324 Wunderlich et al. Sep 1998 A
5802393 Begun et al. Sep 1998 A
5802552 Fandrich et al. Sep 1998 A
5802592 Chess et al. Sep 1998 A
5803357 Lakin Sep 1998 A
5805804 Laursen et al. Sep 1998 A
5805834 McKinley et al. Sep 1998 A
5809224 Schultz et al. Sep 1998 A
5809256 Najemy Sep 1998 A
5809287 Stupek, Jr. et al. Sep 1998 A
5809311 Jones Sep 1998 A
5812748 Ohran et al. Sep 1998 A
5812750 Dev et al. Sep 1998 A
5812757 Okamoto et al. Sep 1998 A
5812858 Nookala et al. Sep 1998 A
5815117 Kolanek Sep 1998 A
5815647 Buckland et al. Sep 1998 A
5815652 Ote et al. Sep 1998 A
5821596 Miu et al. Oct 1998 A
5822547 Boesch et al. Oct 1998 A
5835719 Gibson et al. Nov 1998 A
5835738 Blackledge, Jr. et al. Nov 1998 A
5838932 Alzien Nov 1998 A
5841964 Yamaguchi Nov 1998 A
5841991 Russell Nov 1998 A
5852720 Gready et al. Dec 1998 A
5852724 Glenn, II et al. Dec 1998 A
5857074 Johnson Jan 1999 A
5857102 McChesney et al. Jan 1999 A
5864653 Tavellaei et al. Jan 1999 A
5867730 Leyda Feb 1999 A
5875307 Ma et al. Feb 1999 A
5875308 Egan et al. Feb 1999 A
5875310 Buckland et al. Feb 1999 A
5878237 Olarig Mar 1999 A
5878238 Gan et al. Mar 1999 A
5881311 Woods Mar 1999 A
5884027 Garbus et al. Mar 1999 A
5889965 Wallach et al. Mar 1999 A
5892898 Fujii et al. Apr 1999 A
5892928 Wallach et al. Apr 1999 A
5898888 Guthrie et al. Apr 1999 A
5905867 Giorgio May 1999 A
5907672 Matze et al. May 1999 A
5909568 Nason Jun 1999 A
5911779 Stallmo et al. Jun 1999 A
5913034 Malcolm Jun 1999 A
5922060 Goodrum Jul 1999 A
5930358 Rao Jul 1999 A
5935262 Barrett et al. Aug 1999 A
5936960 Stewart Aug 1999 A
5938751 Tavallaei et al. Aug 1999 A
5941996 Smith et al. Aug 1999 A
5964855 Bass et al. Oct 1999 A
5983349 Kodama et al. Nov 1999 A
Foreign Referenced Citations (6)
Number Date Country
0 866 403 Sep 1998 EP
04 333 118 Nov 1992 JP
5-233 110 Sep 1993 JP
07 093 064 Apr 1995 JP
7-093 064 Apr 1995 JP
7-261 874 Oct 1995 JP
Non-Patent Literature Citations (44)
Entry
Standard Overview, http://www.pc-card.com/stand-overview.html#1, 9 pages, Jun. 1990, “Detailed Overview of the PC Card Standard.”*
Digital Equipment Corporation, datasheet, 140 pages, 1993, “DECchip 21050 PCI-To-PCI Bridge.”*
NetFRAME Systems Incorporated, News Release, 3 pages, referring to May 9, 1994, “NetFRAME's New High-Availability ClusterServer Systems Avoid Scheduled as well as Unscheduled Downtime.”*
Compaq Computer Corporation, Phenix Technologies, LTD, and Intel Corporation, specification, 55 pages, May 5, 1995, “Plug & Play BIOS Specification.”*
NetFRAME Systems Incorporated, datasheet, Feb. 1996, “NF450FT Network Mainframe.”*
NetFRAME Systems Incorporated, datasheet, Mar. 1996, “NetFRAME Cluster Server 8000.”*
Joint work by Intel Corporation, Compaq, Adaptec, Hewlett Packard, and Novell, presentation, 22 pages, Jun. 1996, “Intelligent I/O Architecture.”*
Lockareff, M., HTINews, http://www.hometoys.com/htinews/dec96/articles/loneworks.htm, Dec. 1996, “Loneworks—An Introduction.”*
Schofield, M.J., http://www.omegas.co.uk/CAN/canworks.htm, Copyright 1996, 1997, “Controller Area Network—How CAN Works.”*
NTRR, Ltd, http://nrtt.demon.co.uk/cantech.html, 5 pages, May 28, 1997, “CAN: Technical Overview.”*
PCI Special Interest Group, specification, 35 pages, Draft For Review Only, Jun. 15, 1997, “PCI Bus Hot Plug Specification.”*
Microsoft Corporation, file:///A|/Rem-devs.htm, 4 pages, Copyright 1997, updated Aug. 13, 1997, “Supporting Removable Devices Under Windows and Windows NT.”*
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 I-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.”*
“CAN: Technical Overview”, NRTT, Ltd. Sep. 23, 1997, 15 pp.*
M.J. Schofield, “Controller Area Network—How CAN Works”, mschofield@cix.compulink.co.uk, Sep. 23, 1997, 4 pp.*
“DECchip 21050 PCI-to-PCI Bridge Data Sheet Update”, Digital Equipment Corporation, Jun. 1994.*
“Detailed Overview of the PC Card Standard”, www.pc-card.com/stand-overview.html#1, Sep. 30, 1997, 9 pp.*
Goble, et al., “Intelligent I/O Architecture I2O”, Jun. 1996, 22 pp.*
Lockareff, “Lonworks—An Introduction”, HTI News, Dec. 1996, 2 pp.*
Goodrum, “PCI Bus Hot Plug Specification”, PCI SIG Membership, Jun. 15, 1997, 29 pp.*
Compaq Computer Corporation “Plug and Play BIOS Specification”, Version 1.0A, May 5, 1994, 56 pp.*
Microsoft Corporation, “Supporting Removable Devices Under Windows and Windows NT”, Sep. 15, 1997, 4 pp.*
NetFRAME Systems, Inc. News Release/Brochures, 14 pp.*
NetFRAME Systems Incorporated, News Release, 3 pages, referring to May 9, 1994, “NetFRAME's New High-Availability ClusterServer Systems Avoid Scheduled as well as Unscheduled Downtime.”*
NetFRAME Systems Incorporated, datasheet, 2 pages, Feb. 1996, “NF450FT Network Mainframe.”*
NetFRAME Systems Incorporated, datasheet, 9 pages, Mar. 1996, “NetFRAME Cluster Server 8000.”*
Herr, et al., Linear Technology Magazine, Design Features, pp. 21-23, Jun. 1997, “Hot Swapping the PCI Bus.”*
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-1000226-01, pp. 1-2, 5-8, 359-404, and 471-512, Apr. 1996, “NetFrame Clustered Multiprocessing Software: NW0496 DC-ROM for Novell® 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 Guide.”*
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.*
Lyons, Computer Reseller News, Iss. 721, pp. 61-62, Feb. 3, 1997, “ACC Releases Low-Cost Solution for ISPs.”
M2 Communications, M2 Presswire, 2 pages, Dec. 19, 1996, “Novell IntranetWare Supports Hot Pluggable PCI from NetFRAME.”
Rigney, PC Magazine, 14(17): 375-379, Oct. 10, 1995, “The One for the Road (Mobile-aware capabilities in Windows 95).”
Shanley, and Ande4rson, PCI System Architecture, Third Edition, p. 382, Copyright 1995.
Provisional Applications (5)
Number Date Country
60/046397 May 1997 US
60/047016 May 1997 US
60/046416 May 1997 US
60/046311 May 1997 US
60/046491 May 1997 US
Continuations (1)
Number Date Country
Parent 08/942413 Oct 1997 US
Child 09/258095 US