The present invention generally relates to the field of platform management systems and, more particularly, to a switched platform management architecture and related methods.
The demand for online systems and services has driven an unprecedented growth in the network infrastructure to support such demand. To satisfy such growth, manufacturers of server equipment have developed increasingly complex server configurations. As the server systems have become more complex, manufacturers of such systems have received increasing pressure to improve the manageability of such systems.
In an effort to address this pressure, server management systems were developed. A server management system is typically composed of hardware, firmware and software embedded within a server system for the purpose of autonomous monitoring, recovery and control of a server's operation. Preferably, this server manageability is performed independently of the main processor(s), BIOS, and operating system of the server. The ultimate goal of server management is to lower the end-user's total cost of ownership (TCO).
An example of just such a server management architecture is detailed in the Intelligent Platform Management Interface (IPMI) specification or, more formally the IPMI—Intelligent Platform Management Interface Specification v1.5, Document Revision 1.0 Feb. 21, 2001, by Intel et al. The IPMI specification, which is incorporated herein by reference for all purposes, describes an architecture of hardware and firmware that monitors and controls a server platform independently of, but responsive to, the main processors and System Management Software (SMS). The IPMI is based on an addressable serial bus communication architecture. An example of a conventional IPMI architecture implementation is presented with reference to
Turning briefly to
In the IPMI architecture 100 depicted in
Those skilled in the art will recognize, however, that one of the strengths of platform management architectures such as, e.g., the IPMI architecture, is the relative simplicity of the conventional interconnection structure. This simplicity brings with it a number of limitations, however. First, as a single-bus architecture, a failure of one of the control elements may well bring down (or, “hang”) the entire bus. In our IPMI example, above, the conventional IPMB architecture fails to provide adequate fault isolation for the IPMI system.
Second, the IPMB protocol employs a simple seven-bit address scheme to uniquely identify each of the elements on the IPMB. In a conventional IPMI architecture, a single baseboard control element, i.e., the master controller for the entire chassis is given the address of 20 Hex. Insofar as each element within the conventional IPMI system must be uniquely identifiable, and the baseboard control element must have the address of 20 H, such a limitation stipulates that a conventional IPMI system is limited to but a single baseboard control element. As mentioned above, however, complex server systems may well house servers for a number of different clients/purposes within a single chassis. The limitation of a single baseboard control element, described above, would prohibit implementation of a baseboard control element for each of the disparate servers within a chassis. Third, extending the limitations of the seven-bit address scheme, conventional IPMB implementations fail to provide for multiple address domains to, for example, provide secure manageability within each of a plurality of disparate servers populating a server chassis.
Finally, the conventional platform management architectures fail to offer virtual addressing, thereby permitting multiple elements coupled with the conventional interconnect to share a common physical address. Accordingly, an enhanced platform management architecture and associated methods is required, unencumbered by the inherent limitations commonly associated with the prior art. Just such a solution is provided in the discussion to follow.
The present invention is illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings in which like reference numerals refer to similar elements and in which:
The present invention is generally directed to a switched platform management architecture and related methods. For ease of illustration, the teachings of the present invention will be developed in the context of an example implementation within an Intelligent Platform Management Interface (IPMI) architecture. Those skilled in the art will appreciate, from the discussion to follow, that the broader inventive concept defined within the appended claims may well be practiced in alternate platform management architectures without deviating from the spirit and scope of the present invention. Indeed, such alternate implementations are anticipated within the scope of the present invention.
In this regard, a platform management (PM) switch is introduced to selectively route communications among and between PM elements over any of a number of communication channels established within a plurality of interconnects. According to one example implementation, i.e., the IPMI implementation introduced above, such elements are coupled through the PM switch in a star network topology. Those skilled in the art will appreciate, based on the description to follow, that the star topology enabled by the innovative PM switch facilitates effective fault isolation, multiple address domains and, in this regard, separate communication channels, multi-owner security, and the use of virtual addressing to enable redundant physical addresses within the same address domain. In this regard, the enhanced platform management architecture described herein overcomes the limitations commonly associated with the conventional platform management architectures.
Reference throughout this specification to “one embodiment” or “an embodiment” means that a particular feature, structure or characteristic described in connection with the embodiment is included in at least one embodiment of the present invention. Thus, appearances of the phrases “in one embodiment” or “in an embodiment” in various places throughout this specification are not necessarily all referring to the same embodiment. Furthermore, the particular features, structures or characteristics may be combined in any suitable manner in one or more embodiments.
Example Enhanced IPMI Architecture
To illustrate an alternate implementation, i.e., that of the independent PM switching element 204, attention is drawn to the enhanced platform management architecture 250. As shown, one or more base controller(s) 102A . . . N are coupled with one or more satellite controllers 104–110 through an innovative PM switching element 204 and a plurality of platform management interconnects, e.g., IPMBs 206–210. As above, the star topology effectively couples any of the IPMI elements 104–110 through any of a number of communication channels established within a plurality of IPMBs 206–210.
Those skilled in the art will appreciate that the multi-bus, star topology of the enhanced platform management architecture 200 and/or 250 provides a number of benefits. First, as the elements 104–110 are coupled through physically disparate interconnects, the elements on one such interconnect, e.g., IPMB 206, are communicatively isolated from the elements on another interconnect, e.g., IPMB 208, providing fault tolerance. Moreover, elements on disparate interconnects may (re)use the same physical addresses, separated by use of independent address domain information, or the use of virtual addressing by the PM switching element 204. That is, elements within the same IPMB address domain may well share the same physical address, as the PM switching element 204 distinguishes between such elements using a virtual addressing mechanism described more fully below. In addition, the switching element 204 facilitates the creation of separate address domains, wherein certain elements of such an address domain are only permitted to communicate with other elements of the address domain. Such address domains may well span multiple physical IPMBs. In this regard, the switching element 204 facilitates the creation of multiple communication channel(s). Further, by supporting the use of routing restriction requirements, multiple virtual private interconnects, e.g., virtual private IPMBs (VpIPMB), may well be created within the disparate communication channels enabled by the multiple address domains.
Example Platform Management Architecture Switching Element
Turning to
In accordance with the illustrated example implementation, control logic 302 controls the overall operation of the switching element 300. In this regard, control logic 302 receives PM messages via the switching engine 304 and communication interface(s) 306, analyzes at least a subset of content of the received message for routing information, and selectively forwards the content to one or more target(s) based, at least in part, on the result of said analysis. In accordance with one aspect of the present invention, to be developed more fully below, control logic 302 employs a management data structure to implement certain features of the present invention such as, for example, the virtual addressing, routing restrictions and the like. According to one embodiment, the management data structure is maintained within, for example, memory subsystem 308.
According to one example implementation of the invention, control logic 302 provides a user interface (e.g., management applications 312) to an appropriate administrator of the system, wherein the administrator can manually associate virtual addresses, set address domains, communication restrictions and the like. In accordance with another example implementation, control logic 302 senses multiple elements within an address domain or a physical interconnect, e.g., IPMB, that share a common physical address, and automatically assigns a virtual address to one or both of the otherwise conflicting devices.
As used herein, switching engine 304 provides a physical interface to selectively couple the platform management communication interface(s) 306 to communication channel(s) established over each of the one or more interconnects (IPMBs) coupled with the switching element 204. As developed more fully below, messages received from a communication channel are sent to control logic 302 via PM communication interface(s) 306. Once the analysis is complete, control logic 302 enables the switching engine 304 to forward the message to a select one or more communication channels established over one or more interconnects, e.g., IPMBs 206–210 based, at least in part, on such analysis. According to one example implementation, switching engine is a multiplexer controlled by control logic 302. In alternate implementations, switching engine merely identifies a domain and/or address information in content received from control logic 302, and automatically routes the message to target(s) via appropriately selected interconnects.
The PM communication interface(s) 306 include the hardware and/or software elements necessary to interface the control logic 302 with the physical communication medium of the interconnect. In this regard, the PM communication interface(s) 306 acts as a network/link layer interface (i.e., in accordance with the conventional Open System Interconnect (OSI) seven-layer model) between the control logic 302 and the physical layer. Accordingly, the PM communication interface(s) 306 include the hardware and software stacks necessary to support such communication.
Memory subsystem 308 is intended to represent a wide range of devices, logic and/or registers used to store content. In this regard, memory subsystem 308 may well be comprised of volatile memory elements, non-volatile memory elements, optical or magnetic mass storage devices, or virtual memory elements such as, for example, logical buffers and/or programmatic variables. As introduced above, as pertaining to the teachings of the present invention, memory subsystem 308 may well maintain a management data structure used by, for example, control logic 302 or switching engine 304 to resolve addressing and/or routing information. As will be developed more fully below, the management data structure may well include information for each of the elements within the enhanced platform management system 200, 250 denoting at least a physical address, associated virtual address(es) if any, and/or routing restrictions associated with the address(es) if any.
As shown, switching element 300 optionally includes one or more applications 310 including, for example, one or more management applications 312. According to one example implementation, such as, e.g., a stand-alone switching element implementation (e.g., 250 of
It will be appreciated by those skilled in the art that, although presented in accordance with a hardware paradigm with reference to a block diagram, switching element 300 may well be implemented in software, firmware or some combination of all of the above. According to one example implementation, switching element 300 is implemented as an integrated circuit. Accordingly, functional elements 302–312 may well be implemented in any combination of hardware, software and/or firmware without deviating from the spirit and scope of the present invention. Moreover, it should be appreciated that the particular architecture of the illustrated example switching element is just that, an example. Accordingly, switching elements of greater or lesser complexity which nonetheless implement the features described herein are contemplated within the scope and spirit of the present invention.
Example Data Structure(s)
Turning to
In contrast, the enhanced platform management architecture datagram 400 of the present invention selectively employs routing information 402. Routing information 402 may well be comprised of a destination address and is, in this regard, compatible with legacy IPMI implementations. Routing information 402 may alternatively comprise information distinguishing different address domains (i.e., domain information) 404, and address information 406 denoting one or more of a source address and/or a destination address associated with elements participating in the communication of the datagram. According to certain implementations, the innovative switching element 204 supports routing of streams of information, wherein routing information 402 will only appear in a select subset of datagrams communicated between select platform management elements (sensors, controllers, etc.).
According to one example implementation, the routing information 402 is contained within a seven-bit address space (i.e., in accordance with conventional implementations), wherein two (2) bits are allocated to the domain information, while the remaining five (5) bits are allocated to the address information. In accordance with this implementation, the two most-significant bits in the field 402 represent address domain information 404, while the remaining five least-significant bits in the field 402 represent address information 406. In certain other implementations, routing information 402 of greater or lesser complexity may well be used without deviating from the scope and spirit of the present invention.
As introduced above, introduction of the PM switching element 204 enables multiple communication channels established over multiple interconnects (IPMBs) within the enhanced platform management architecture. Moreover, the PM switching element 204 enables multiple address domains. It is noted that multiple IPMBs may share a single address domain. Similarly, multiple address domains may well be established between select elements coupled to a common IPMB. In this regard, to uniquely identify an element within the enhanced IPMI architecture of, for example,
In addition, address information 404 may well be comprised of physical address information associated with an PM element and/or virtual address information associated with that element. The establishment and use of virtual addresses enables multiple elements within a common address domain to share the same physical address. That is, if two devices within an address domain share a common physical address, control logic 302 will assign one or more of such elements a unique virtual address to enable the devices to share a common physical address, while directing communication traffic to only a desired one of such elements. To facilitate such “intelligent” switching features, the IPMI switching element 204 maintains a switching management data structure, introduced above. An example of just such a data structure is presented with reference to
In accordance with the illustrated example implementation of
As introduced above, the physical address information denotes the physical address of an element within an address domain or, alternatively, a disparate IPMB. The physical IPMB denotes the physical IPMB on which the element is connected. The virtual address information is established to facilitate the use of multiple physical addresses within a single IPMB or a single address domain spanning multiple IPMBs. By maintaining virtual addressing information within the management data structure 500, switching element 300 privately correlates one or more virtual addresses to a corresponding physical address and physical IPMB.
As introduced above, the routing restrictions denote which elements may communicate with which other elements or, alternatively, which elements may not communicate with which other elements. In this regard, the use of the routing restrictions enable virtual private communication channels within an address domain spanning multiple IPMBs or within a single IPMB.
Example Operation and Implementation
Having introduced the operating environment and architectural elements of the present invention, above, attention is now directed to
Turning to
Once received, the switching element 204 analyzes the content of the received IPMI message 400 to identify routing information 402, block 604. More particularly, as described above, the received message 400 is passed from the switching engine 304 through the communication interface 306 to the control logic 302, which analyzes the message for routing information 402 denoting one or more of a domain information 404 and/or address information 406.
Based, at least in part, on the information identified within the received message 400, switching element 204 identifies one or more target element(s) of the received IPMI message 400, block 606. More specifically, as detailed below with reference to
Once the target is identified, the switching element 204 selectively routes the message 400 to its intended target through an appropriate one or more communication channel(s) established within one or more interconnects (IPMBs), block 608. That is, control logic 302 selectively modifies the routing information 402 of the message 400, as necessary, and forwards the message 400 to the intended recipient(s) through the IPMI communication interface(s) 306 and an appropriate one or more IPMB's, block 608. As introduced above, control logic 302 may well modify physical address information to virtual address information, or vice versa in accordance with the routing rules contained within the management data structure 500. Once the message is ready for forwarding, control logic 302 enables switching engine 304 to receive the message from IPMI communication interface 306 and route the message to an appropriate one or more IPMBs.
In
In block 704, control logic 302 determines whether the routing information 402 denotes that the switching element 204, or the host of the switching element 204 (e.g., base control element 202) is the intended destination of the received message. If so, the process continues with block 706, wherein the received message 400 is processed locally, block 706. According to one example implementation, an application 310 may process the received message.
If, in block 704, the routing information 402 does not indicate a local destination address, the process continues with block 708 wherein control logic 302 determines whether the routing information 402 contains a permissible destination address. According to one example implementation, control logic 302 accesses the management data structure 500 to determine whether the address information corresponds to a valid PM element.
Assuming that the address information denotes a legitimate PM element, control logic 302 determines whether any restrictions are in place that would prohibit forwarding of the message from the particular source element to the destination denoted by the address information. As indicated above, switch element 204 facilitates different address domains and could, therefore, prohibit communication between select elements of different address domains.
If, in block 708, control logic 302 determines that the address information does not denote a permissible destination address, the process continues with block 608 wherein the selective nature of the forwarding results in the message being discarded. According to certain alternate implementations the failed attempt may result in an indication of error being sent from the switching element 204 to the source of the received message, and/or the logging of the failed attempt.
If, in block 708, control logic 302 determines that the routing information does, indeed, include a permissible destination address, control logic 302 identifies which one or more IPMB's are associated with the destination address, block 710. That is, control logic 302 identifies from, for example, the management data structure 500, the IPMB(s) the target(s) are coupled with switch element 204.
In block 712, control logic 302 determines whether the destination address resolved from the routing information is a virtual address. Control logic 302 makes such determination with reference to the management data structure 500. If, in block 712, control logic 302 identifies the destination address as a virtual address, control logic 302 translates the virtual address into a physical address, block 714. In accordance with the illustrated example implementation, such translation is performed with reference to the management data structure 500. In alternate implementations, it is conceived that such translation could be performed dynamically through, for example, some hashing of the virtual address to obtain a corresponding physical address associated with the IPMI element.
Once the destination address is identified, control logic 302 determines whether the routing information contains source address information and, if so, whether it is a virtual address, block 716. As above, this determination may well be made from reference to the management data structure 500 or, alternatively, dynamically through some processing of the virtual source address information itself.
If any identified source address information is determined to correspond with a virtual address, control logic 302 translates the physical address into a virtual address, block 718. As introduced above, such translation may well be performed through reference to the management data structure 500 or, alternatively, dynamically by applying the physical address to some conversion logic/process.
Once the physical destination and/or virtual source address(es) have been identified, as above, the process continues with block 608, wherein the received message 400 is selectively forwarded to the one more target IPMI elements denoted by content in the routing information. As indicated above, the control logic 302 may well selectively modify the routing information 402 in the received message from virtual address(es) to physical address(es) and vice versa, while the remaining content of the IPMI message is left undisturbed.
Given the foregoing, those skilled in the art will appreciate that PM switching element 204 comprising control logic 302, switching engine 304 and management data structure 500 can effectively implement a multi-interconnect enhanced platform management architecture and associated methods described above. In this regard, the enhanced platform management architecture enabled by the switching element 204 facilitates multiple address domains, effective multi-user security, virtual addressing in support of virtual private communication channel(s) within and between interconnect(s), and effective fault isolation.
In the description above, for the purposes of explanation, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without some of these specific details. In other instances, well-known structures and devices are shown in block diagram form.
The present invention includes various steps. The steps of the present invention may be performed by hardware components, such as those shown in
The present invention may be provided as a computer program product which may include a machine-readable medium having stored thereon content which may be used to program a computer (or other electronic devices) to perform a process according to the present invention. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnet or optical cards, flash memory, or other type of media/machine-readable medium suitable for storing electronic instructions. Moreover, the present invention may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer to a requesting computer by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem connection, a network connection, a wireless communication signal, and the like).
Many of the methods are described in their most basic form but steps can be added to or deleted from any of the methods and information can be added or subtracted from any of the described messages without departing from the basic scope of the present invention. Moreover, although well-suited for the illustrated example implementation of a server, or cluster of servers, those skilled in the art will appreciate that the IPMI interface in general, and the switched IPMI architecture in particular, may well be implemented in any of a number of electronic appliances So to introduce a level of manageability to the appliance. In this regard, the particular embodiments are not provided to limit the invention but merely to illustrate it. The scope of the present invention is not to be determined by the specific examples provided above but only by the claims below.
Number | Name | Date | Kind |
---|---|---|---|
6157644 | Bernstein et al. | Dec 2000 | A |
6553029 | Alexander | Apr 2003 | B1 |
Number | Date | Country | |
---|---|---|---|
20030152074 A1 | Aug 2003 | US |