1. Field of the Invention
The present invention relates to a system for sharing a plurality of downstream information processing apparatuses such as a plurality of I/O equipment among a plurality of upstream information processing apparatuses such as CPUs and a method used to the system, and particularly, to an I/O equipment sharing system which a plurality of CPUs and a plurality of I/O equipment are connected through a network and a method used to the I/O equipment sharing system.
This application is based upon and claims the benefit of priority from Japanese patent application No. 2006-254366, filed on Sep. 20, 2006, the disclosure of which is incorporated herein in its entirety by reference.
2. Related Art
At present, a peripheral component interconnect (PCI) is widely used as a bus standard for connecting between respective parts in a computer. A PCI Express is standardized as a next generation standard of the PCI. The PCI Express increases a communication capacity by changing a conventional parallel bus to a serial bus and carrying out communication by a packet system accompanied with switching.
However, the PCI Express permits only a tree-like arrangement in which a plurality of I/O equipment 108-1 to 108-3 are connected to one CPU 101 as shown in
On the other hand, conventionally, when a plurality of I/O equipment are shared among a plurality of CPUs, the advanced switching interconnect (ASI), in which a plurality of CPUs and a plurality of I/O apparatuses are connected to a network in a dispersed state, is standardized as shown in “ASI Core Architecture Specification Rev. 1. 1, ASI-SIG, November, 2004”.
With reference to
The ASI network 1701 includes route complex side PC Express-ASI bridges 1702-1 and 1702-2, an ASI switch 1703, a fabric manager 1704, and I/O equipment side PCI Express-ASI bridges 1705-1 to 1705-3.
The route complex side PCI Express-ASI bridges 1702-1 and 1702-2 are connected to the route complexes 102-1 and 102-2, and have a function for encapsulating a TLP (Transaction Layer Packet) in an ASI packet and carrying out transmission and reception. The ASI switch 1703 carries out switching so that the ASI packet, which encapsulates the packet (TLP) of the PCI Express, is transferred to a port of the destination of the ASI packet. The I/O equipment side PCI Express ASI bridges 1705-1 to 1705-3 are connected to the I/O equipment 108-1 to 108-3 and have a function for encapsulating a TLP in an ASI packet and carrying out transmission and reception. A fabric manager 1704 manages an inter-bridge connection in the route complex side PCI Express-ASI bridges 1702-1, 1702-2 and the I/O equipment side PCI Express-ASI bridges 1705-1 to 1705-3.
As a technology relating to the present invention, FIG. 1 of Japanese Patent Application Laid-Open Publication (JP-A) No. 10-49482 discloses a system in which one or at least two processors, a first bridge, a second bridge, and a plurality of peripheral devices are connected through a bus, respectively, (a bus for connecting a first bridge and a second bridge, and a bus for connecting the second bridge and the plurality of peripheral devices are a PCI bus). Further, JP-A No. 10-178442 discloses a system for allocating each one VLAN ID to each terminal, managing by a table, and controlling a connection between terminals.
Further, other technology relating the present invention is disclosed in “Protocol Interface #8 (PI-8) R1.0, ASI-SIG, February, 2004”.
However, when an ASI is used between a plurality of CPUs, there are two disadvantages.
A first disadvantage resides in that it is complex to carry out a group management of a plurality of I/O equipment, and thereby expandability is restricted. This is because, when the group management of the plurality of I/O equipment is carried out in the ASI, a fabric manager is required to hold all the routing information and further a routing path must be set to each of ASI address spaces of the I/O equipment 108-1 to 108-3.
A second disadvantage resides in that N-fold redundancy cannot be easily set to the same I/O equipment. This is because when a plurality of the same I/O equipment make a different response, they are out of synchronization and cannot be operated, in addition to the reason of the first disadvantage.
Accordingly, an object of the present invention is to provide a system for and a method of easily carrying out setting for sharing a plurality of CPUs and a plurality of I/O equipment while increasing redundancy.
An I/O equipment sharing system of the present invention is characterized in that a plurality of CPUs are connected to a plurality of I/O equipment through at least a plurality of upstream PCI Express-bridges disposed corresponding to the plurality of CPUs and through a plurality of downstream PCI Express-bridges connected to the plurality of upstream PCI Express-bridges through a network and disposed corresponding to the plurality of I/O equipment, the plurality of upstream PCI Express-bridges and the plurality of downstream PCI Express-bridges include identifier setting units for setting the same identifier to the upstream and downstream PCI Express-bridges and filtering units for carrying out filtering by the set identifiers, respectively and the plurality of upstream PCI Express-bridges communicate with the downstream PCI Express-bridges by a frame to which the identifiers are added.
In an I/O equipment sharing method of the present invention which shares a plurality of I/O equipment between a plurality of CPUs in an I/O equipment sharing system in which the plurality of CPUs are connected to the plurality of I/O equipment through at least a plurality of upstream PCI Express-bridges disposed corresponding to the plurality of CPUs and through a plurality of downstream PCI Express-bridges connected to the plurality of upstream PCI Express-bridges through a network and disposed corresponding to the plurality of I/O equipment, the I/O equipment sharing method is characterized by including the steps of setting the same identifier to the plurality of upstream PCI Express-bridges and to the plurality of downstream PCI Express-bridges, carrying out a communication by a frame to which the identifiers are added, and carrying out filtering by the plurality of upstream PCI Express-bridges and the plurality of downstream PCI Express-bridges using the set identifier.
An information processing apparatus sharing system of the present invention is characterized in that a plurality of upstream information processing apparatuses are connected to a plurality of downstream information processing apparatuses through at least a plurality of upstream bridges disposed corresponding to the plurality of upstream information processing apparatuses and through a plurality of downstream bridges connected to the plurality of upstream bridges through a network and disposed corresponding to the plurality of downstream information processing apparatuses, the plurality of upstream bridges and the plurality of downstream bridges include identifier setting units for setting the same identifier to the upstream and downstream bridges and filtering units for carrying out filtering by the set identifiers, respectively, and the plurality of upstream bridges communicate with the plurality of downstream bridges by a frame to which the identifiers are added.
In a downstream information processing apparatus sharing method the present invention which shares a plurality of downstream information processing apparatuses between a plurality of upstream information processing apparatuses in an information processing apparatus sharing system in which the plurality of upstream information processing apparatuses are connected to a plurality of downstream information processing apparatuses through at least a plurality of upstream bridges disposed corresponding to the plurality of upstream processing apparatuses and through a plurality of downstream bridges connected to the plurality of upstream bridges through a network and disposed corresponding to the plurality of downstream processing apparatuses, the downstream information processing apparatus sharing method is characterized by including the steps of setting the same identifier to the plurality of upstream bridges and to the plurality of downstream bridges, carrying out communication by a frame to which the identifiers are added and carrying out filtering by the plurality of upstream bridges and the plurality of downstream bridges using the set identifier.
Since a plurality of downstream information processing apparatuses (for example, I/O equipment) can be shared between a plurality of upstream information processing apparatuses (for example, CPUs) by setting the same identifier without setting networks, a management can be simply carried out, thereby the extendibility of a network can be increased.
Next, exemplary embodiments for carrying out the present invention will be explained in detail referring to the drawings. Note that, although a PCI Express is exemplified in the exemplary embodiments as an example of a bus standard for connecting between respective parts in a computer, the present invention is not limited to the standard. That is, the present invention can be applied to an information processing apparatus sharing system and method. In the information processing apparatus sharing system and method, a connection between a plurality of upstream information processing apparatuses (for example, CPUs and a plurality of I/O equipment) and a plurality of downstream information processing apparatuses is carried out through at least a plurality of upstream bridges and a plurality of downstream bridges. The plurality of upstream bridges are disposed corresponding to the plurality of upstream information processing apparatuses. The plurality of downstream bridges are connected to the upstream bridges through a network and disposed corresponding to the plurality of downstream information processing apparatuses. Further, the present invention is not limited to a connection of a plurality of CPUs and a plurality of I/O equipment and can be widely applied to systems for and methods of carrying out sharing in a connection between a plurality of upstream information processing apparatuses and a plurality of downstream information processing apparatuses such as a connection between a plurality of I/O equipment and a plurality of I/O equipment.
(1) First Exemplary Embodiment
1-1) Explanation of Configuration
The I/O equipment sharing system includes CPUs 101-1 and 101-2, route complexes 102-1 and 102-2 realized by chipsets, memories 103-1 and 103-2, upstream PCI Express-Ethernet (registered trademark) bridges (hereinafter, abbreviated as upstream bridges) 104-1 and 104-2, Ethernet (registered trademark) switches 106-1 to 106-4 constituting a network 105, downstream PCI Express-Ethernet bridges (hereinafter abbreviated as downstream bridges) 107-1 to 107-3, three pieces of I/O equipment 108-1 to 108-3, and input devices 109-1 and 109-2.
The route complex 102-1 is connected to the CPU 101-1, the memory 103-1 the input device 109-1, and the upstream bridge 104-1, and the route complex 102-2 is connected to the CPU 101-2, the memory 103-2, the input device 109-2, and the upstream bridge 104-2. The CPUs 101-1 and 101-2 are coupled to the upstream bridge 104-1 and 104-2, respectively. Further, the I/O equipment 108-1 to 108-3 are connected to the downstream bridges 107-1 to 107-3, respectively. The upstream bridges 104-1, 104-2 and the downstream bridges 107-1 to 107-3 are connected to the Ethernet switches 106-1 to 106-4 that constitute the network 105, respectively. The respective Ethernet switches 106-1 to 106-4 are connected to constitute a network through which data can be transmitted from arbitrary one of the upstream bridges 104-1, 104-2 to arbitrary one of the downstream bridges 107-1 to 107-3.
As shown in
Further, the upstream bridge 104-1 includes a counter 207 for counting the number of times of the VLAN ID-setting, a filtering unit 208 for filtering the frames other than the frame of a set MAC address and a set VLAN ID, a control frame generation (creation) unit 209 for generating a control frame, a control frame selection unit 210 for selecting a control frame and an encapsulated frame, a control frame processing unit 211 for processing the control frame, an error notification unit 212 for notifying the user of occurrence of an error, an encapsulation unit 213 for adding a destination MAC address and affiliation VLAN ID to the TLP and encapsulating the added TLP to an encapsulated frame (capsulized frame), an encapsulation table 214 for holding the information of the MAC address and the affiliation VLAN ID corresponding to the TLP destination in encapsulation, and a decapsulation unit 215 for decapsulating the TLP from the encapsulated frame.
The TLP controller 201 is connected to the route complex 102-1, the I/O equipment sharing controller 202, the error notification unit 212, the encapsulation (capsulization) unit 213, and the decapsulation (decapsulization) unit 215. The I/O equipment sharing controller 202 is connected to the TLP controller 201, the I/O equipment request table 203, the I/O equipment information table 204, the VLAN ID setting unit 205, the control frame generation unit 209, the control frame processing unit 211, the error notification unit 212, and the encapsulation table 214. The VLAN ID setting unit 205 is connected to the I/O equipment sharing controller 202, the VLAN ID information table 206, counter 207 for counting number of times of VLAN ID-setting, the filtering unit 208, the control frame generation unit 209, the control frame processing unit 211, the error notification unit 212, and the encapsulation table 214. The filtering unit 208 is connected to the VLAN ID setting unit 205, the control frame selection unit 210, and the Ethernet switch 106-1.
The control frame generation unit 209 is connected to the I/O equipment sharing controller 202, the VLAN ID setting unit 205, the encapsulation unit 213, and the Ethernet switch 106-1. The control frame selection unit 210 is connected to the filtering unit 208, the control frame processing unit 211, and the decapsulation unit 215. The encapsulation unit 213 is connected to the TLP controller 201, the encapsulation table 214, the Ethernet switch 106-1, and the control frame generation unit 209.
Next, the respective tables will be explained. A part (a) of
The downstream bridge 107-1 includes a TLP controller 301 for processing the TLP, an I/O equipment sharing controller 302 for controlling setting for sharing the I/O equipment 108-1, an I/O equipment information acquisition unit 303 for acquiring the information of connected I/O equipment, an I/O equipment information table 304 for holding the I/O equipment information from the downstream bridges 107-2, 107-3 and the information of the I/O equipment connected thereto (to the downstream bridge 107-1), a VLAN ID setting unit 305 for controlling setting of the VLAN ID, and a VLAN ID information table 306 for holding the VLAN ID set information from the upstream bridges 104-1, 104-2.
Further, the downstream bridge 107-1 includes a request selection unit 307 for selecting one of VLAN ID setting requests from a plurality of the upstream bridges 104-1, 104-2, a filtering unit 308 for filtering the frames other than the frame of a set MAC address and a set VLAN ID, a control frame generation unit 309 for creating a control frame, a control frame selection unit 310 for selecting a control frame and an encapsulated frame, a control frame processing unit 311 for processing the control frame, an encapsulation unit 312 for adding the destination MAC address and affiliation VLAN ID to the TLP and encapsulating the added TLP to an encapsulated frame, an encapsulation table 313 for holding the information of the MAC address and the affiliated VLAN ID corresponding to the TLP destination in encapsulation, and a decapsulation unit 314 for decapsulating the TLP from the encapsulated frame.
The TLP controller 301 is connected to the I/O equipment 108-1, the I/O equipment sharing controller 302, the encapsulation unit 312, and the decapsulation unit 314. The I/O equipment sharing controller 302 is connected to the TLP controller 301, the I/O equipment information acquisition unit 303, the I/O equipment information table 304, the VLAN ID setting unit 305, the control frame creation unit 309, the control frame processing unit 311, and the encapsulation table 313. The VLAN ID setting unit 305 is connected to the I/O equipment sharing controller 302, the VLAN ID information table 306, the request selection unit 307, the filtering unit 308, the control frame creation unit 309, the control frame processing unit 311, and the encapsulation table 313.
The filtering unit 308 is connected to the VLAN ID setting unit 305, the control frame selection unit 310, and the Ethernet switch 106-3. The control frame creation unit 309 is connected to the I/O equipment sharing controller 302, the VLAN ID setting unit 305, and the Ethernet switch 106-3. The control frame selection unit 310 is connected to the filtering unit 308, the control frame processing unit 311, and the decapsulation unit 314. The encapsulation unit 312 is connected to the TLP controller 301, the encapsulation table 313, and the Ethernet switch 106-3.
Next, the respective tables will be explained. A part (a) of
1-2) Explanation of Operation of First Exemplary Embodiment
In the exemplary embodiment, a user carries out an operation for setting I/O equipment necessary to a system which is desired by a CPU manipulated by the user, and an operation for setting the VLAN ID among a plurality of CPUs, and an operation for setting for sharing a plurality of CPUs and a plurality of I/O equipment.
These operations are classified to an operation carried out just after a system starts, an operation carried out when a CPU is newly added to the system, an operation carried out when I/O equipment is newly added to the system, an operation carried out when a CPU is removed from the system, and an operation carried out when I/O equipment is removed from the system.
1) Just after System Starts
Just after the system starts, the filtering units 208 of the respective the upstream bridges 104-1,104-2 and the filtering units 308 of the respective downstream bridges 107-1 to 107-3 are set to receive all the frames of the VLAN IDs.
<Setting of System Architecture>
The user inputs the I/O equipment that he or she wants to use and stores the information of the I/O equipment to the upstream bridges. Setting to share the I/O equipment is carried out based on the stored information. The setting for sharing the I/O equipment is carried out by the following procedure.
First, the user sets I/O equipment necessary to him or her, for example, the I/O equipment 108-1, 108-2 using, for example, the input device 109-1. The set information is issued as a TLP, and the TLP controller 201 of the upstream bridge 104-1 writes necessary I/O equipment information (Vendor ID, Device ID, and Class Code prescribed by PCI Express) written to the TLP to the I/O equipment request table 203 through the I/O equipment sharing controller 202. The I/O equipment request table 203 is held even after a power supply is shut off so that data just before the power supply is shut off is reflected when the system starts next time.
Further, when a system configuration is changed while it is used by the user, the user sets I/O equipment necessary to him or her using the input device 109-1 likewise. The set information is issued as a TLP, and the TLP controller 201 of the upstream bridge 104-1 writes necessary I/O equipment information written to the TLP to the I/O equipment request table 203 through the I/O equipment sharing controller 202. Thereafter, the user carries out an I/O equipment sharing sequence.
Although the operation for setting the I/O equipment necessary to the user in the upstream bridge 104-1 using the input device 109-1 is explained here, an operation for setting I/O equipment necessary to other user in the upstream bridge 104-2 is carried out using the input device 109-2 likewise.
<Setting of VLAN ID>
Next, an operation for setting a VLAN ID (which acts as an identifier) between the upstream bridges 104-1, 104-2, which belong to the CPUs 101-1, 101-2, will be explained.
First, as shown in
The frame broadcasted from the upstream bridge 104-1 is distributed to the upstream bridge 104-2 and the respective downstream bridges 107-1 to 107-3 through the network 105.
The downstream bridges 107-1 to 107-3 which received the VLAN ID notification frame is selected by the control frame selection unit 310, and the control frame processing unit 311 abandons the VLAN ID notification frame.
When the upstream bridge 104-2 receives the VLAN ID notification frame (step S21), the control frame processing unit 211 extracts the information of the VLAN ID and the MAC address from the VLAN ID notification frame selected by the control frame selection unit 210 and writes the information to the VLAN ID information table 206 (step S22). The upstream bridge 104-2 waits until a predetermined time passes and obtains the VLAN ID setting information of the other upstream bridge 104-1. The upstream bridge 104-1 waits until a predetermined time passes after the VLAN ID notification frame is transmitted and obtains the VLAN ID setting information of the other upstream bridge 104-2 (step S23). Although the following processing is explained as the operation of the upstream bridge 104-2, a similar operation is carried out also in the upstream bridge 104-1.
It is determined whether or not the predetermined time has passed (step S24), and when the predetermined time has passed, the VLAN ID setting unit 205 searches the VLAN ID information table 206 to confirm whether or not the set VLAN ID in the upstream bridge 104-2 is set in the other upstream bridge 104-1 (step S25).
When the VLAN ID thereof (the upstream bridge 104-2) overlaps the VLAN ID of the other upstream bridge 104-1, the VLAN ID setting unit 205 determines whether or not the set VLAN ID thereof is fixed (decided) by referring to the VLAN ID information table 206 (step S26). When the VLAN ID is fixed, the VLAN ID setting unit 205 transmits a VLAN ID decision (fixed) frame to the upstream bridge 104-1 to which overlapped setting is carried out, by the control frame generation unit 209 (step S27). When the set VLAN ID is not fixed, the VLAN ID setting unit 205 compares the number of times of the VLAN ID-setting in referring to the counter 207 with the prescribed number of set times (step S28). When a counter value exceeds the prescribed number of set times, the VLAN ID setting unit 205 notifies the user of an error using the error notification unit 212 (step S29). When the user receives the error, he or she carries out the VLAN ID initially setting sequence again by resetting the upstream bridge 104-2 (or manually set the VLAN ID in the VLAN ID initially setting sequence). When the counter value is equal to or less than the prescribed number of set times, the VLAN ID setting unit 205 sets a VLAN ID which is apart from the set VLAN ID by a numerical value created from the MAC address thereof, by referring to the VLAN ID information table 206 (step S30) and writes the VLAN ID to the VLAN ID information table 206 (step S31). Then, the control frame creation unit creates the VLAN ID notification frame of the new VLAN ID and broadcasts it (step S32), increments the number of times of VLAN ID-setting in the counter 207 (step S33), and waits for reception of a next VLAN ID notification frame.
When the VLAN ID of the upstream bridge 104-2 does not overlap that of the other upstream bridge 104-1, the VLAN ID setting unit 205 determines whether or not the set VLAN ID of the upstream bridge 104-2 is already fixed (step S34), and when the set VLAN ID of the upstream bridge 104-2 is already fixed, the VLAN ID notification frame reception sequence is finished. When the VLAN ID of the upstream bridge 104-2 is not fixed, a VLAN ID decision frame is created from the control frame generation unit 209 and broadcasted it (step S35), the filtering unit 208 is set to the VLAN ID or a VLAN ID 0 and set such that it can receive the MAC address thereof or a broadcast frame (step S36), and a decision flag (fixed flag) is attached to the relevant VLAN ID of the VLAN ID information table 206 (step S37), thereby the VLAN ID notification frame reception sequence is finished.
The frame broadcasted from the upstream bridge 104-2 is distributed to the upstream bridge 104-1 other than the upstream bridge 104-2 from which the frame was transmitted and the respective downstream bridges 107-1 to 107-3 through the network 105.
The respective downstream bridges 107-1 to 107-3, which received the VLAN ID decision frame, are selected by the control frame selection unit 310, respectively, and the control frame processing unit 311 extracts the information of the VLAN ID and the MAC address from the VLAN ID decision frame and writes the information together with a decision flag to the VLAN ID information table 306.
When the VLAN ID thereof overlaps, the VLAN ID setting unit 205 confirms whether or not the VLAN ID thereof is fixed (step S45). When the VLAN ID thereof is fixed, the VLAN ID setting unit 205 notifies the user of an error. (step S46). When the VLAN ID thereof is not fixed, the VLAN ID setting unit 205 sets a VLAN ID which is apart from the set VLAN ID by a numerical value created from the MAC address thereof referring to the VLAN ID information table 206 (step S47) and writes the VLAN ID to the VLAN ID information table 206. Then, the control frame creation unit creates the VLAN ID notification frame of the new VLAN ID and broadcasts it (step S47), increments the number of times of VLAN ID-setting in the counter 207 (step S49) and waits for reception of a next VLAN ID notification frame.
Further, the VLAN ID setting unit 205 transmits the VLAN ID notification frame, and when it does not receive a VLAN ID notification frame from the other upstream bridge 104-2 until a predetermined time passes, the VLAN ID setting unit 205 determines that no other starting upstream bridge exists. Thus, the VLAN ID setting unit 205 creates a VLAN ID decision frame from the control frame generation unit 209 and broadcasts it, and the filtering unit 208 is set to the VLAN ID or a VLAN ID 0 and set such that it can receive the MAC address thereof or a broadcast frame, and sets a decision flag to the relevant VLAN ID of the VLAN ID information table 206.
These operations are carried out by each of the upstream bridges 104-1, 104-2. Further, the VLAN ID initially setting sequence is carried out when the system is started and when it is reset, by using reception of the respective control frames as a trigger.
<Setting for Sharing I/O Equipment>
First, the downstream bridge 107-1 acquires the I/O equipment information (Vendor ID, Device ID, Class Code prescribed by PCI Express) of the I/O equipment 108-1 connected thereto using the I/O equipment information acquisition unit 303 (step S51). The downstream bridge 107-1 writes the acquired information and the MAC address thereof to the I/O equipment information table 304 (step S52). The control frame creation unit 309 creates an I/O equipment information notification frame based on the information and broadcasts it (step S53).
Note that when the I/O equipment 108-1 is not used by any of the CPUs 101-1 and 102-2, the I/O equipment information notification frame is set to an VLAN ID 0, whereas when the I/O equipment 108-1 is used by any of the CPUs 101-1 and 102-2, the I/O equipment information notification frame is set to the VLAN ID thereof, and the VLAN ID is periodically broadcasted from the downstream bridge 107-1.
The frame broadcasted from the downstream bridge 107-1 is distributed to the downstream bridges 107-2, 107-3 other than the downstream bridge 107-1 from which the frame was transmitted and the upstream bridges 104-1, 104-2 through the network 105.
The downstream bridge 107-2, which received the I/O equipment information notification frame (step S54) is selected by the control frame selection unit 310 (although explanation is carried out here as to the downstream bridge 107-2, this explanation is also applied to the downstream bridge 107-3 likewise). The control frame processing unit 311 reads the I/O equipment information and the MAC address from the I/O equipment information notification frame and writes them to the I/O equipment information table 304 (step S55).
Further, the downstream bridge 104-1, which received the I/O equipment information notification frame (step S56), is selected by the control frame selection unit 210 (although explanation is carried out here as to the upstream bridge 104-1, this explanation is also applied to the upstream bridge 104-2 likewise). The control frame processing unit 211 reads the I/O equipment information and the MAC address from the I/O equipment information notification frame and writes them to the I/O equipment information table 204 (step S57). Next, the I/O equipment sharing controller 202 compares the I/O equipment request table 203 with the I/O equipment information table 204 and confirms whether or not the I/O equipment required by the user exists (step S58). When the required I/O equipment does not exist, the I/O equipment-sharing setting sequence of in the upstream bridge 104-1 is finished. When the required I/O equipment exists, the control frame generation unit 209 creates a VLAN ID setting frame and transmits the VLAN ID setting frame to set a target I/O equipment to the VLAN ID thereof (step S59). As already described in the setting of system architecture, since the I/O equipment 108-1, 108-2 are set in the upstream bridge 104-1 as the I/O equipment necessary to the user, the VLAN ID setting frame is transmitted to the downstream bridges 107-1, 107-2.
The downstream bridge 107-1, which received the VLAN ID setting frame (step S60), is selected by the control frame selection unit 310, and the control frame processing unit 311 reads the VLAN ID and the MAC address from the VLAN ID setting frame and sets a request flag of the VLAN ID information table 306 (step S61). The downstream bridge 107-1 waits for arrival of the VLAN ID setting frame until a predetermined time passes after it starts (step S62). After the predetermined time has passed, a VLAN ID setting unit 304 first confirms whether or not a plurality of request flags of the VLAN ID information table 306 are set (step S63). When only one request flag is set, the VLAN ID setting unit 304 broadcasts an I/O equipment decision (fixed) frame created by the control frame creation unit 309 with the VLAN ID 0, to the upstream bridge 104-1 of the VLAN ID, the MAC address to which the request flag is set (step S65). When a plurality of request flags are set (when the VLAN ID setting frames are transmitted from both the upstream bridges 104-1, 104-2), the request selection unit 307 selects one request (step S64). The request selection unit 307 may select the request at random or by a method of preferentially selecting a request having a large or small VLAN ID value, a method of selecting a request near to the MAC address thereof, and the like. The I/O equipment decision frame created by the control frame creation unit 309 is broadcasted with the VLAN ID 0 to the upstream bridge 104-1 of the selected VLAN ID, MAC address (step S65). After the I/O equipment decision frame is transmitted, and the filtering unit 308 is set to the VLAN ID or a VLAN ID 0 and set such that it can receive the MAC address thereof or a broadcast frame (step S66), and the VLAN ID is written to the column thereof of the I/O equipment information table.
The frame broadcasted from the downstream bridge 107-1 is distributed to the downstream bridges 107-2, 107-3 other than the downstream bridge 107-1 from which the frame is transmitted and the upstream bridge 104-1 through the network 105. Although explanation is carried out here as to the downstream bridge 107-1, a similar operation is also carried out in the downstream bridge 107-2 which received the VLAN ID setting frame.
The downstream bridge 107-2, which received the I/O equipment decision frame (step S67), is selected by the control frame selection unit 310 (although explanation is carried out here as to the downstream bridge 107-2, this explanation is also applied to the downstream bridge 107-3 likewise), and the control frame processing unit 311 reads the I/O equipment information of a transmission source and the VLAN ID information of a set destination from the I/O equipment decision frame and writes them to the I/O equipment information table 304 (step S68).
The upstream bridge 104-1, which received the I/O equipment decision frame (step S69) is selected by the control frame selection unit 210, and the control frame processing unit 211 reads the I/O equipment information of the transmission source and the VLAN ID information of the set destination from the I/O equipment decision frame and writes them to the I/O equipment information table 204 (step S70). Further, the I/O equipment sharing controller 202 determines whether or not the I/O equipment of the transmission destination is I/O equipment necessary to it (step S71). When the I/O equipment of the transmission destination is not the I/O equipment necessary to the I/O equipment sharing controller 202, it finishes the I/O equipment decision frame reception sequence. When the I/O equipment of the transmission destination is the I/O equipment necessary to the I/O equipment sharing controller 202, it compares the VLAN ID thereof with the VLAN ID of the set destination of the I/O equipment decision frame to determine whether or not the I/O equipment is destined to it (step S72). When the I/O equipment is not destined to it, the I/O equipment sharing controller 202 finishes the I/O equipment decision frame reception sequence. When the I/O equipment is destined to it, the I/O equipment sharing controller 202 carries out a PCI Express setting operation such that the CPU 101-1 thereof can use the I/O equipment (step S73), subsequently records the MAC address and the VLAN ID of the I/O equipment and the bus number, the device number, the I/O address, and the memory address of a PCI Express which are set to the encapsulation table 214 (step S74), and finishes the operation.
When the I/O equipment sharing controller 202 receives no I/O equipment decision frame destined thereto when a predetermined time passes after the upstream bridge 104-1 transmits the VLAN ID setting frame, it notifies the user of that sharing of I/O equipment fails.
2) In Ordinary Operation (Communication Between CPU and I/O Equipment)
Next, how communication is carried out between a route complex and I/O equipment in an ordinary operation after the I/O equipment is shared will be explained. Explanation will be made here as to communication between the route complex 102-1 and the I/O equipment 108-1.
Since the plurality of Ethernet switches 106, which constitute the network 105, have a self-leaning function, they automatically construct an address table and transfer the encapsulated frame to the downstream bridge 107-1 of the destination (it is assumed here that the destination is the downstream bridge 107-1).
The downstream bridge 107-1, which received the encapsulated frame (step S87), determines whether or not the encapsulated frame is the frame of a set VLAN ID in the filtering unit 308 (step S88), and the filtering unit 308 abandons the frames other than the frame of the set VLAN ID (step 89). Whereas, when the encapsulated frame is the frame of the set VLAN ID, the frame is accepted. Further, the filtering unit 308 confirms the MAC address of the destination (step S90), abandons the frames other than the frame destined thereto or a broadcasted frame (step S91) and accepts the frame destined thereto or the broadcasted frame. Next, the control frame selection unit 310 determines whether the frame is a control frame or an encapsulated frame (step S92). When the frame is the control frame, it is transferred to the control frame processing unit 311 and processed therein (step S93). When the frame is the encapsulated frame, it is transferred to the decapsulation unit 314 and decapsulated therein (step S94). The decapsulated TLP is transferred to the TLP controller 301, which reads the destination of the TLP (step S95) and determines whether the TLP is destined to the downstream bridge 107-1 (step S96). When the TLP is destined to the downstream bridge 107-1, TLP controller 301 confirms the contents of the TLP and processes them (step S97). When the destination is directed to the I/O equipment 108-1 to which the destination is connected, TLP controller 301 transfers the contents of the TLP to the I/O equipment 108-1 (step S98) to thereby finish the processing.
Next, a case, in which the downstream bridge 107-1 receives the TLP from the I/O equipment 108-1, will be explained using
The upstream bridge 104-1, which received the encapsulated frame (step S107), determines whether or not the encapsulated frame is the frame of a set VLAN ID in the filtering unit 208 (step S108), the filtering unit 208 abandons the frames other than the frame of the set VLAN ID (step 109). Whereas, when the encapsulated frame is the frame of the set VLAN ID, the frame is accepted. Further, the filtering unit 208 confirms the MAC address of the destination (step S110), abandons the frames other than the frame destined thereto or a broadcast frame (step S111) and accept the frame destined thereto or the broadcasted frame. Next, the control frame selection unit 210 determines whether the frame is a control frame or an encapsulated frame (step S122). When the frame is the control frame, it is transferred to the control frame processing unit 211 and processed therein (step S113). When the frame is the encapsulated frame, it is transferred to the decapsulation unit 215 and decapsulated therein (step S114). The decapsulated TLP is transferred to the TLP controller 201, which reads the destination of the TLP (step S115) and determines whether the TLP is destined to the downstream bridge 104-1 (step S116). When the TLP is destined to the downstream bridge 104-1, the TLP controller 201 confirms the contents of the TLP and processes them (step S117). When the destination is directed to the route complex 102-1 to which the destination is connected, the TLP controller 201 transfers the contents of the TLP to the route complex 102-1 (step S118) to thereby finish the processing.
3) When CPU is Newly Added
An operation, which is carried out when a CPU, a route complex, a memory, an upstream bridge, an input device are newly added while the system is being operated, will be explained. It is assumed here that a CPU 101-3, a route complex 102-3, a memory 103-3, an upstream bridge 104-3, an input device 109-3 (not shown) are added, and the CPU 101-3, the route complex 102-3, the memory 103-3, the upstream bridge 104-3, and the input device 109-3 which are newly added will be mainly explained below. When they are newly added, setting for system architecture, setting for a VLAN ID, and setting for sharing I/O equipment are carried out likewise when the system starts. First, a setting of system architecture is the same as that carried out just after the system starts.
Next, the newly added upstream bridge 104-3 sets a VLAN ID to set the VLAN ID thereof. Although a basic operation is the same as that just after the system starts except that the VLAN IDs of the other upstreams bridge 104-1, 104-2 are already fixed. The operation is carried out according to
Further, the setting for sharing the I/O equipment is carried out according to
4) When I/O Equipment is Newly Added
An operation, which is carried out when a downstream bridge and I/O equipment are newly added, will be explained. It is assumed here that a downstream bridge 107-4 and I/O equipment 108-4 (not shown) are newly added. At the time, an operation is started from the operation in which the added downstream bridge 107-4 obtains the information of the added I/O equipment 108-4. Thereafter, the setting is carried out according to a procedure shown in
5) When CPU is Removed from System
A procedure for removing a CPU, a route complex, a memory, an upstream bridge, and an input device while a system is in operation will be explained. It is assumed here that a CPU 101-1, a route complex 102-1, a memory 103-1, an upstream bridge 104-1, and an input device 109-1 are removed. When it is assumed here that the upstream bridge 104-1 to be removed uses, for example, the downstream bridge 107-1 and the I/O equipment 108-1, a VLAN ID removing frame created by the control frame generation unit 209 is transmitted to the target I/O equipment 108-1 to cancel the setting for sharing the downstream bridge 107-1 and the I/O equipment 108-1. The downstream bridge 107-1, which received the VLAN ID removing frame, resets the I/O equipment 108-1 connected to the downstream bridge 107-1 itself. The reset downstream bridge 107-1 starts an I/O-equipment-sharing setting operation and broadcasts an I/O equipment information notification frame of a VLAN 0. The upstream bridge 104-1 being removed, which received the broadcasted I/O equipment information notification frame, removes relevant I/O equipment information from the I/O equipment request table 203.
The operation is repeated until all the I/O equipment whose secured state flags are set in the I/O equipment request table 203 are removed. After all the secured I/O equipment are removed, the CPU 101-1, the route complex 102-1, the memory 103-1, the upstream bridge 104-1, and the input device 109-1 are placed in a removable state and removed.
6) When I/O Equipment is Removed from System
A procedure for removing I/O equipment being operated from a system in operation will be explained. It is assumed here that the CPU 101-1 is connected to the I/O equipment 108-1, and the I/O equipment 108-1 is to be removed. A removal operation is started in response to a removal instruction from the I/O equipment 108-1 (depression of an attention button) or a removal instruction from the user of the I/O equipment 108-1. When the removal instruction issued from the I/O equipment 108-1, a command based on a PCI Express is issued through communication between the CPU 101-1 and the I/O equipment 108-1 in ordinary operation. When the I/O equipment is removed, since the I/O equipment information notification frame, which is periodically transmitted, is not received by the upstream bridge 104-1, relevant I/O equipment information is removed from the I/O equipment information table 204 and the secured flag of the I/O request table 203 are removed.
On the other hand, when the upstream bridge 104-1 receives the removal instruction from the user, the upstream bridge 104-1, which received the removal instruction, transmits an I/O equipment removing frame created by the control frame generation unit 209 to the target downstream bridge 104-1. The downstream bridge 107-1, which received the I/O equipment removing frame, is selected by the control frame selection unit 310, information is read by the control frame processing unit 311, an I/O removal instruction TLP is sent from the TLP controller 301 to the I/O equipment 108-1, and the I/O equipment 108-1 is placed in a state in which it issues a removal instruction and thereby, an operation is carried out in the same procedure as that in the above case in which the removal instruction issued from the I/O equipment 108-1.
7) When Sharing of I/O Equipment is Cancelled
A procedure for canceling sharing of I/O equipment in use while the system in operation will be explained. It is assumed here that sharing of the I/O equipment 108-1 used by the CPU 101-1 is cancelled. Cancel of sharing is started in response to a removal instruction from the user. The upstream bridge 104-1, which received a removal instruction TLP, transmits a VLAN ID removing frame created by the control frame generation unit 209 to the target I/O equipment 108-1 to cancel the setting for sharing the downstream bridge 107-1 and the I/O equipment 108-1 in use. The downstream bridge 107-1, which received the VLAN ID removing frame, resets the I/O equipment 108-1 connected to the downstream bridge 107-1 itself. The reset downstream bridge 107-1 starts an I/O-equipment-sharing setting operation and broadcasts an I/O equipment information notification frame of a VLAN 0. The upstream bridge 104-1 being removed, which received the broadcasted I/O equipment information notification frame, removes relevant I/O equipment information from the I/O equipment request table 203. Further, when a request for carrying out setting for sharing the I/O equipment issued, the I/O equipment 108-1 whose sharing is cancelled starts the sharing-of-I/O-equipment setting sequence.
8) When Power Supply to CPU is Shut Off
A case, in which a power supply to the CPU 101-1 and the upstream bridge 104-1 is shut off contrary to the intension of the user when the system is in operation, will be explained. It is assumed here that the CPU 101-1 uses the I/O equipment 108-1. When the power supply to the CPU 101-1 and the upstream bridge 104-1 is shut off, the I/O equipment 108-1 used by the upstream bridge 104-1 and the CPU 101-1 does not receive data from the upstream bridge 104-1. When this state continues for a predetermined time, the control frame creation unit 309 of the downstream bridge 107-1 to which the I/O equipment 108-1 is connected transmits an I/O equipment confirmation frame to the upstream bridge 104-1. When the CPU 101-1 and the upstream bridge 104-1 are in operation, the upstream bridge 104-1, which received the I/O equipment confirmation frame, returns a response, and the downstream bridge 107-1, which received the response, carries out an ordinary operation. However, when the CPU 101-1 and the upstream bridge 104-1 are not in operation, since no response is returned, the downstream bridge 107-1 resets the I/O equipment 108-1 connected to the downstream bridge 107-1 itself after a predetermined time passes. The reset downstream bridge 107-1 starts an I/O-equipment-sharing setting operation, broadcasts an I/O equipment information notification frame of a VLAN 0, and when there is a request for the setting for sharing the I/O equipment, a sharing-of-I/O-equipment setting sequence is started.
Although the case, in which three sets of the I/O equipment are shared between the two CPUs, is explained above, the number of them is not limited to the above number, and the configuration of the exemplary embodiment can be also applied to a case in which two or four or more I/O equipment are shared between three or more CPUs likewise. This is the same in the respective exemplary embodiments to be explained below.
1-3) Advantages of First Exemplary Embodiment
Setting for sharing I/O equipment between a plurality of CPUs can be automatically carried out by using the exemplary embodiment. And the setting for sharing I/O equipment is easily because the setting can be managed only the VLAN ID.
(2) Second Exemplary Embodiment
2-1) Explanation of Configuration
In the second exemplary embodiment, a VLAN ID is set to each of I/O equipment in use, and a plurality of the same I/O equipment are caused to belong to the same VLAN ID. One of the same I/O equipment is selected, and the frames of the I/O equipment other than the frame of the I/O equipment selected by a MAC address in the frames of the same VLAN IDs are abandoned by the setting the filtering portion of an upstream bridge.
When communication is carried out to I/O equipment, the I/O equipment is set to the VLAN ID and broadcasted, thereby a frame is distributed to a plurality of the same I/O equipment. The frame from the I/O equipment to the upstream bridge receives the frame from the I/O equipment selected by the setting carried out by the filtering portion.
Further, the second exemplary embodiment includes a redundancy I/O equipment response confirmation unit for confirming whether or not the response from the I/O equipment which is active at the time agrees with the responses from a plurality of I/O equipment in a stand-by state, a redundancy I/O equipment synchronization correcting unit and correction buffer for correcting an unsynchronized state, as a recovery means when an unsynchronized state occurs between a plurality of the same redundantly set I/O equipment
Although the configuration of the second exemplary embodiment is the same as that of the first exemplary embodiment except the configuration of the upstream bridge, it is preferable that the I/O equipment includes a plurality of the same the I/O equipment.
In comparison with the upstream bridge 104 of the first exemplary embodiment shown in
A part (a) of
2-2) Explanation of Operation of Second Exemplary Embodiment
Next, the operation the second exemplary embodiment will be explained.
1) Just after System Starts
Just after the system starts, the filtering units 208 of the upstream bridges 104-1, 104-2 and the filtering units 308 of downstream bridges 107-1 to 107-3 are set such that they can receive the frames of all the VLAN IDs.
<Setting of System Architecture>
A user inputs which I/O equipment he or she wants to use and a degree of redundancy and stores the information to the upstream bridge. I/O equipment is shared based on the stored information. A procedure for sharing it is as described below.
First, the user sets the I/O equipment which the user requires and the degrees of redundancy (number of secured sheets) of the respective I/O equipment using, for example, an input device 109-1. The information issued as a TLP, and a TLP controller 201 of the upstream bridge 104-1 writes the necessary I/O equipment information written to the TLP (Vendor ID, Device ID, and Class Code prescribed by PCI Express) to the I/O equipment request table 203 through the I/O equipment sharing controller 202. At the time, the same I/O equipment information whose amount is equal to the designated number of degree of redundancy is written in the I/O equipment request table 203.
Although the operation for setting the I/O equipment which the user requires and the degree of redundancy on the upstream bridge 104-1 using the input device 109-1 is explained here, an operation for setting the I/O equipment which other user requthisires and a degree of redundancy on the upstream bridge 104-2 using an input device 109-2 is carried out likewise.
<Setting of VLAN ID>
Since a VLAN ID is set to each requested I/O equipment in the second exemplary embodiment, a VLAN ID setting operation is repeated until the VLAN ID is allocated to all the I/O equipment registered to the I/O equipment request table 203.
An operation for setting the VLAN ID between the upstream bridges 104-1, 104-2 which belong to CPUs 101-1, 101-2 will be explained.
The operation when the upstream bridge 104-2 receives a VLAN ID notification frame or the operation when a predetermined time passes after the upstream bridge 104-1 transmits the VLAN ID notification frame includes an operation different from that of the first exemplary embodiment.
After the VLAN ID decision frame is broadcasted (after step S35), the VLAN ID decision flag, which is set by a VLAN ID information table 206 this time, is set (step S121). Then, the VLAN ID is recorded to the column of the affiliated VLAN ID, to which the VLAN ID is not allocated, of the I/O equipment request table 203 shown in the part (a) of
<Setting for Sharing I/O Equipment>
In the first exemplary embodiment of the setting for sharing I/O equipment, the same VLAN ID is set to all the I/O equipment secured by the upstream bridge. In the second exemplary embodiment, however, a different VLAN ID is set to different I/O equipment, and the same VLAN ID is set to the same I/O equipment.
The sharing-of-I/O-equipment setting sequence of the second exemplary embodiment is as shown in
2) When Ordinary Operation is Carried Out
(Communication Between CPU-I/O Equipment, without Setting of N-Fold Redundancy)
Next, how communication is carried out between a route complex and I/O equipment in an ordinary operation after the completion of the setting for sharing the I/O equipment will be explained.
In the second exemplary embodiment, since the VLAN ID is set to each different I/O equipment, and the same VLAN ID is set to the same I/O equipment. When communication is carried out, although a frame directed to the downstream bridge of target I/O equipment is unicasted by the set VLAN ID in the first exemplary embodiment, it is broadcasted in the set VLAN ID in the second exemplary embodiment and transmitted to all the same affiliated I/O equipment. Transmitted encapsulated frames are received by the respective downstream bridges in the VLAN and operated respectively. Since the encapsulated frames from the respective downstream bridges in the VLAN are set such that they abandon the MAC addresses other than that of the downstream bridge of the I/O equipment selected by the filtering unit, the encapsulated frame from the selected I/O equipment is decapsulated and processed as a TLP.
3) When Ordinary Operation is Carried Out
(Communication Between CPU-I/O Equipment, with Setting of N-Fold Redundancy)
Next, an ordinary operation, when N-fold redundancy is set, will be explained. When the N-fold redundancy is set in the ordinary operation in the above operation 2), it is required to make uniformly the status between the same I/O equipment same as that of the I/O equipment set to active. First, when a frame is encapsulated from the upstream bridge and transmitted, a copy of the frame is placed in the correction buffer 1004 sectioned to each VLAN ID. Thereafter, when a response frame is received from respective I/O equipment, the redundant I/O equipment response confirmation unit 1002 compares the responses from the respective I/O equipment, and when the I/O equipment are not synchronized, a result of the comparison is sent to the redundant I/O equipment synchronization correction unit 1003, and the MAC address of the copy of the frame of the correction buffer is changed from a broadcast address to the MAC address of the I/O equipment which is not synchronized and, the MAC address is sent to the I/O equipment which is not synchronized (the I/O equipment from which NACK is transmitted). When the I/O equipment are synchronized, the frame is sent to the filtering unit 208. Subsequent processing is the same as that explained in 2).
4) When CPU is Newly Added
In the operation of the first exemplary embodiment for newly adding a CPU, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
5) When I/O Equipment is Newly Added
In the operation of the first exemplary embodiment for newly adding a CPU, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
6) When CPU is Removed from System
In the operation of the first exemplary embodiment for newly adding a CPU, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
7) When I/O Equipment is Removed from System
In the operation of the first exemplary embodiment for newly adding a CPU, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
8) When Sharing of I/O Equipment is Cancelled
In the operation of the first exemplary embodiment for newly adding a CPU, In the operation of the first exemplary embodiment for newly adding a CPU, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
9) When Power Supply to CPU is Shut Off
In the operation of the first exemplary embodiment when power supply to a CPU is shut off, the points of change, which are carried out in the second exemplary embodiment to the construction of a system, the setting of VLAN ID, and the setting for sharing I/O equipment of the first exemplary embodiment, are reflected as they are.
2-3) Advantages of Second Exemplary Embodiment
The redundancy configuration of the I/O equipment can be easily set using the second exemplary embodiment.
(3) Third Exemplary Embodiment
A third exemplary embodiment will be explained.
The configurations shown in
Next, the operation of the third exemplary embodiment will be explained. The operation of the third exemplary embodiment is different from that of the first and second exemplary embodiments in the operation for sharing a plurality of I/O equipment.
Each of the downstream bridges 107-1 to 107-3 broadcasts the I/O equipment information notification frame (step S53). The I/O equipment database server 1901 receives the I/O equipment information notification frames (step S54) and additionally records I/O equipment information to an I/O equipment information table (step S55). Further, each of the upstream bridges 104-1, 104-2 sends an I/O equipment request frame to the I/O equipment database server 1901 based on necessary I/O equipment information set to it (step S131). The I/O equipment database server 1901 receives the I/O equipment request frame (step S132) and selects corresponding I/O equipment referring to the I/O equipment information table (step S133). In following explanation, it is assumed that the I/O equipment information necessary to the I/O equipment 108-1 is sent from the upstream bridge 104-1 to the I/O equipment database server 1901 and the I/O equipment database server 1901 selects the I/O equipment 108-1.
A VLAN ID setting frame is sent to the downstream bridge 107-1 to which the I/O equipment 108-1 is connected so that the VLAN ID setting frame is set to the VLAN ID to which the upstream bridge 104-1, which requested the selected I/O equipment 108-1, is set (step S134). After the downstream bridge 107-1 receives the VLAN ID setting frame, a similar operation is carried out except that when the I/O equipment database server 1901 receives an I/O equipment decision frame (step S67), it adds VLAN ID information to the I/O equipment information table (step S68).
Further, as shown in
When the third exemplary embodiment is used, since the upstream bridges and downstream bridges do not include the I/O equipment information table, the upstream bridges and the downstream bridges can be easily mounted.
(4) Fourth Exemplary Embodiment
A fourth exemplary embodiment will be explained.
Next, an operation of the fourth exemplary embodiment will be explained. The operation of the fourth exemplary embodiment is the same as that of the first, second, and third exemplary embodiments except the operation for carrying out a VLAN ID setting sequence. The VLAN ID setting sequence of the fourth exemplary embodiment will be explained using
As shown in
When the VLAN ID setting server 2501 receives the VLAN ID setting request frame (step S141), it selects a VLAN ID which is not used at the time referring to a VLAN ID information table shown
When the upstream bridge 104-1, which requested the selected VLAN ID, receives the VLAN ID decision frame (step S144), it hold the VLAN ID thereof in a VLAN ID setting unit. Further, when downstream bridges 107-1 to 107-3 receive the VLAN ID decision frame (step S145), the VLAN ID setting unit holds the VLAN ID thereof. Thereafter, the process goes to a sharing-of-I/O-equipment setting sequence.
Further, as shown in
When the fourth exemplary embodiment is used, since the respective upstream bridges do not include the VLAN ID table 206, the upstream bridges can be easily mounted.
(5) Fifth Exemplary Embodiment
A fifth exemplary embodiment will be explained.
Next, the operation of the fifth exemplary embodiment will be explained. In the fifth exemplary embodiment, the operation of a VLAN ID setting sequence is the same as that of the fourth exemplary embodiment, and the operation of a sharing-of-I/O-equipment setting sequence is the same as that of the third exemplary embodiment.
Further, as shown in
As shown in
Since the respective upstream bridges and downstream bridges do not hold the I/O equipment information table, the VLAN ID information table, and the counter for counting the number of times of the VLAN ID-setting by using the fifth exemplary embodiment, the upstream bridges and the downstream bridges can be easily mounted.
(6) Sixth Exemplary Embodiment
A sixth exemplary embodiment will be explained. The sixth exemplary embodiment will explain a configuration including a unit for controlling competition when set VLAN IDs compete against each other between a plurality of upstream bridges or when a plurality of CPUs request the same I/O equipment to permit for them to belong to it. The configuration of the sixth exemplary embodiment is the same as any of the configurations of the first, second, third, fourth, and fifth exemplary embodiments except the portion for carrying out the competition control. The sixth exemplary embodiment is added the unit (competition control unit) for carrying out the competition control to the competition of the VLAN IDs or the competition of the request to the I/O equipment, as a competition control server.
1) Competition Control when VLAN Id is Set
When respective upstream bridges create VLAN IDs from a MAC address (exemplary embodiments 1 to 3), there is a case in which at least two upstream bridges create the same VLAN IDs. After the upstream bridges create the VLAN IDs from the MAC address, the VLAN IDs advertise against each other. In, for example,
When an upstream bridge receives an advertising frame (VLAN ID notification frame) and finds an upstream bridge other than it which advertises the same VLAN ID as the upstream bridge, the upstream bridge accesses the competition control server 2601 to request it to solve the competition. In
The competition control server 2601 recognizes the occurrence of competition due to the access from the upstream bridges 104-1, 104-2 having the same VLAN ID (step S154), solves the competition, and notifies the upstream bridges 104-1, 104-2 which compete against each other of it. As an example of a method of solving competition, the competition control server 2601 is previously provided with a VLAN ID which cannot be created by any of the upstreams, and when competition occurs, the competition control server 2601 sets the VLAN ID (step S155) and sends it one of the upstream bridges 104-1, 104-2. The upstream bridge receives the set VLAN ID (step S156) and holds in a VLAN ID information table and a VLAN ID setting unit (step S157). It is needless to say that the competition may be solved by a method other than the above method.
2) Competition Control when a Plurality of CPUs Request the Same I/O Equipment to Permit for them to Belong to it
Competition also occurs when a plurality of CPUs request the same the I/O equipment to permit for them to belong to it. As shown in
Note that the competition control server 2601 may be disposed in any location on a network as long as the respective upstream bridges and the respective downstream bridges can access it. Further, as shown in
(7) Seventh Exemplary Embodiment
A seventh exemplary embodiment will be explained. I/O equipment can be roughly classified into a volatile type and a non-volatile type. When power supply is turned of, the data of volatile I/O equipment is erased, and the data of non-volatile I/O equipment is not erased even if power supply is shut off. The volatile I/O equipment is, for example, a graphic accelerator card, a sound card, or an engine card on which various types of processing engines are mounted. The volatile I/O equipment does not have an external output terminal. However, if I/O equipment has an external input/output terminal to which other equipment is connected, the I/O equipment is regarded as volatile I/O equipment when it is connected/disconnected to/from the volatile I/O equipment at the time the volatile I/O equipment is started or ended. On the other hand, the non-volatile I/O equipment is I/O equipment to which the volatile I/O equipment does not belong and for example, is a network interface card whose physical wirings are connected to fixed ports, or a storage interface card to which a storage unit is connected such that the data thereof is stored even if the power supply to which is shut off.
In the volatile I/O equipment, no problem arises even if any CPU uses it. However, when a non-volatile I/O equipment is connected and the allocation thereof is changed, there is a possibility that the data thereof is rewritten by other CUP without permission. To cope with this problem, when the non-volatile I/O equipment is connected, a region management device is newly added to set using-region of an I/O equipment to each CPU.
The data of the non-volatile I/O equipment 108 can be prevented from being broken by other user by using the seventh exemplary embodiment.
The present invention can be used to an apparatus for and a method of sharing I/O equipment between a plurality of the CPUs, and in particular to an apparatus for and method of sharing a plurality of the CPUs and a plurality of I/O equipment through a network.
Although the exemplary embodiments of the present invention have been described in detail, it should be understood that various changes, substitutions and alternatives can be made therein without departing from the spirit and scope of the invention as defined by the appended claims. Further, it is the inventor's intent to retain all equivalents of the claimed invention even if the claims are amended during prosecution.
Number | Date | Country | Kind |
---|---|---|---|
2006-254366 | Sep 2006 | JP | national |
This application is a divisional application of U.S. application Ser. No. 11/857,846 filed Sep. 19, 2007, which claims priority from Japanese Patent Application No. 2006-254366 filed Sep. 20, 2006, which applications are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5086426 | Tsukakoshi et al. | Feb 1992 | A |
5394402 | Ross | Feb 1995 | A |
5684800 | Dobbins et al. | Nov 1997 | A |
6198741 | Yoshizawa et al. | Mar 2001 | B1 |
6798775 | Bordonaro et al. | Sep 2004 | B1 |
7046668 | Pettey et al. | May 2006 | B2 |
7058738 | Stufflebeam, Jr. | Jun 2006 | B2 |
7079544 | Wakayama et al. | Jul 2006 | B2 |
7096310 | Norden | Aug 2006 | B2 |
7380046 | Boyd et al. | May 2008 | B2 |
7519761 | Gregg | Apr 2009 | B2 |
8200880 | Higuchi et al. | Jun 2012 | B2 |
20050053060 | Pettey | Mar 2005 | A1 |
20050262269 | Pike | Nov 2005 | A1 |
20060129709 | Bandholz et al. | Jun 2006 | A1 |
20060206655 | Chappell et al. | Sep 2006 | A1 |
20070025354 | Pettey et al. | Feb 2007 | A1 |
20070067551 | Ikeda et al. | Mar 2007 | A1 |
20070198763 | Suzuki et al. | Aug 2007 | A1 |
Number | Date | Country |
---|---|---|
537408 | Apr 1993 | EP |
10-049482 | Feb 1998 | JP |
10-178442 | Jun 1998 | JP |
2001-045099 | Feb 2001 | JP |
2002-149592 | May 2002 | JP |
2002-351817 | Jun 2002 | JP |
2004-336501 | Nov 2004 | JP |
2005-332396 | Feb 2005 | JP |
2005-101722 | Apr 2005 | JP |
2005-317021 | Oct 2005 | JP |
2007-219873 | Aug 2007 | JP |
2004088522 | Oct 2004 | WO |
2006014573 | Feb 2006 | WO |
Entry |
---|
Jun Suzuki et al., “ExpressEther Ethernet-Based Virualization Technology for Reconfigurable Hardware Platform”, 14th IEEE Symposium on High-Performance Interconnects, Aug. 23-25, 2006, pp. 45-51, IEEE Computer Society, Stanford, CA, USA. |
Yoichi Hidaka et al., “Proposal for the ExpressEther System Virtualation Technology Using Ethernet (1) System Overview and Architecture”, The Institute of Electronics, Information and Communication Engineers 2006 Communications Society Conference Abstracts 2, Sep. 7, 2006, p. 57, The Institute of Electronics, Informationand Communication Engineers, Japan. |
Jun Suzuki et al., “Proposal for the ExpressEther System Virtualization Technology Using Ethernet (2) I/O Virtualization Technology”, The Institute of Electronics, Information and Communication Engineers 2006 Communications Society Conference Abstracts 2, Sep. 7, 2006, p. 58, The Institute of Electronics, Information and Communication Engineers, Japan. |
Hideyuki Shimonishi et al., “Proposal for the ExpressEther System Virtualization Technology Using Ethernet (3) Packet Retransmission Scheme”, The Institute of Electronics, Information and Communication Engineers 2006 Communications Society Conference Abstracts 2, Sep. 7, 2006, p. 59, Institute of Electronics, Information and Communication Engineers , Japan. |
Junichi Higuchi et al., “Proposal for the ExpressEther System Virtualization Technology Using Ethernet (4) Prototyping and Performance Evaluation”, The Institute of Electronics, Information and Communication Engineers 2006 Communications Society Conference Abstracts 2, Sep. 7, 2006, p. 60, The Institute of Electronics, Information and Communication Engineers, Japan. |
ASI Core Architecture Specification Rev. 1. 1, ASI—SIG, Nov. 2004, pp. 29-52. |
“Protocol Interface #8 (PI-8) R1.0, ASI-SIG, Feb. 2004”, pp. 17-25. |
PCI Express Ethernet Networking, Sep. 2005, Intel white paper. |
PCI Express Base Specification Revision 1.0 Jul. 22, 2002. |
Number | Date | Country | |
---|---|---|---|
20120290764 A1 | Nov 2012 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 11857846 | Sep 2007 | US |
Child | 13469335 | US |