1. Field of the Invention
This invention relates in general to networks, and more particularly to load balancing in InfiniBand switches and networks.
2. Background of the Invention
Network systems are commonly used to move network information (may also be referred to interchangeably, as frames, packets or commands) between computing systems (for example, servers) or between computing systems and network devices (for example, storage systems). Various hardware and software components are used to implement network communication, including network switches.
A network switch is typically a multi-port device where each port manages a point-to-point connection between itself and an attached system. Each port can be attached to a server, peripheral, input/output subsystem, bridge, hub, router, or another switch. The term network switch as used herein includes a Multi-Level switch that uses plural switching elements within a single switch chassis to route data packets.
InfiniBand (“IB”) is a switched fabric interconnect standard for servers, incorporated herein by reference in its entirety. IB technology is deployed for server clusters/enterprise data centers ranging from two to thousands of nodes. The IB standard is published by the InfiniBand Trade Association, and is incorporated herein by reference in its entirety.
An IB switch is typically a multi-port device. Physical links (optical or copper) connect each port in a switch to another IB switch or an end device (for example, Target Channel Adapter (TCA) or a Host Channel Adapter (HCA)).
In a multi-tier IB switch environment, plural IB switches are connected through inter-switch links (ISL). ISLs may be uplinks or downlinks. It is desirable to avoid over usage or under usage of IB network links for optimum network throughput.
In one embodiment a method for routing packets in an IB network is provided. The method includes determining if alternate routing is enabled for a packet; determining an alternate route address for the packet, if alternate routing is enabled; and routing the packet using the alternate route address, if the alternate route address is valid.
In another embodiment, a switch element for routing packets in an IB network is provided. The switch element includes a routing table in a port that determines a base route address; and if alternate routing is enabled for a packet, the port determines an alternate route address for a packet; and routes the packet using the alternate route address.
This brief summary has been provided so that the nature of the invention may be understood quickly. A more complete understanding of the invention can be obtained by reference to the following detailed description of the preferred embodiments thereof concerning the attached drawings.
The foregoing features and other features of the present invention will now be described with reference to the drawings of various embodiments. In the drawings, the same components have the same reference numerals. The illustrated embodiments are intended to illustrate, but not to limit the invention. The drawings include the following Figures:
The following definitions are provided for convenience as they are typically (but not exclusively) used in lB and general networking environment, implementing the various adaptive aspects described herein.
“DLID”: Destination local identifier is a field in an IB packet identifying a local subnet packet destination.
“Downlink”: Portion of an ISL that routes packets from a Spine switch element to a switch element coupled to an end device.
“Inter switch link” or “ISL”: A physical link that is used for connecting two or more IB switches.
“Load Balancing”: A method for optimizing load on a network link or network links between switch elements in a Multi Level switch.
“Multi Level Switch”: A switch that includes a plurality of switch elements operationally coupled together
“Opcode”: Opcode is a field in an IB packet that indicates the IB packet type.
“Packet”: A group of one or more network data word(s) used for network communication.
“QP”: Destination queue pair is a field in an IB packet that indicates the work queue pair number at a destination.
“Routing Table”: A table that stores information for routing a packet.
“SLID”: Source local identifier is a field in an IB packet identifying local subnet packet source.
“Spine”: A switch element within a Multi Level switch and is primarily used for switching data packets between other switch elements. It may also be referred to as a cross connect switch element.
“Switch”: A device that facilities network communication conforming to IB and other switch standards/protocols.
“Uplink”: Portion of an ISL that routes packets from a switch element coupled to an end device and to a Spine switch element.
To facilitate an understanding of the various aspects, the general system/process for transmitting data in IB switches is described. The specific architecture and operation is then described with reference to the general description.
The Uplink of ISL 142 routes packets from ASIC 150 to ASIC 141, while uplinks of ISL 144 and ISL 145 route packets from ASIC 152 and ASIC 153 to ASIC 141. The Downlink of ISL 143 routes packets from ASIC 141 to ASIC 151.
Typically, when a packet arrives at a port (150A) of an IB switch element (for example, ASIC 150), the port performs a look-up using a static routing table to determine packet destination (for example, PORT 150A to PORT 151A). In some instances, a packet is routed to one switch element via an uplink and then routed back to another switch element via another downlink. For example, a packet may be routed via the uplink of ISL 142 to IB switch element 141 and then routed back via the downlink of ISL 143 to IB switch element 151.
Static routing table based routing has disadvantages because a particular downlink may be over used (“over subscribed”) by attempting to transmit multiple packets at the same time; or may be under utilized (“or under subscribed”). For example in
Also, depending on a routing path, uplink 142 may be over subscribed. For example, uplink 142 may be over subscribed when port 150A sends packets to port 151A; port 150B sends packets to port 152A; port 150C sends packets to port 153A and port 150D sends packets to 154A. The static routing path selection and data packet flow distribution may determine which link may be over subscribed or under subscribed, at any given time.
The various adaptive aspects described herein provide a load balancing system and method to optimize link usage (for both Uplinks and Downlinks) and avoid over subscription and under subscription conditions, improving overall Multi Level switch and network throughput.
ASIC 100 may include plural ports, for example, 36 ports, shown as Port1 through Port36. Each port includes a receive port (or segment) for receiving packets and a transmit port (or segment) for transmitting packets. Port (Port1-Port36) functions depend on the type of device it is attached to. For example, Port1105 may be coupled to Device1106 and may be used primarily to route packets to and from Device1106. Similarly, Port 19 (107) is coupled to Spine 108 and is used to route packets to and from Spine 108. Although
For illustration purposes only, in
Each port (for example, Port1-port3 includes transmit and receive connections to the switch crossbar 101. Crossbar 101 may use information from routing table 102 to route packets. Although only one routing table is depicted there may be multiple copies to provide increased bandwidth.
Register(s) 104 receive and hold control information accessible by a general-purpose processor 103. Processor 103 can change characteristics or operating configuration of ASIC 100 by placing certain control words in registers 104.
When a packet is received at a port (for example Port1105), the port determines base route 113 based on a DLID. An offset 112, which is determined using a circuit described below with respect to
Comparators 115A-115C are used to detect a “wrap-around” condition. A wrap-around condition occurs when output 117A is greater than a maximum switch element port number. In the case of a 36-port ASIC 100, if the output of adder 117 is greater than 36, then a valid port number is selected as an alternate route. The wrap-around conditions are made programmable to allow for switch element connected in different topologies, the ability to skip inactive or failed links and to allow different port stride values.
The output from comparators 115A-115C pass through logic gates 115D and 115E to generate a select signal 115F. Select signal 115F selects data from one of the plural inputs (for example, 4) to multiplexer (“Mux”) 118A. Three of these inputs (shown as values 21, 20 and 19) are from register 114 and the fourth input is 117A. Output 118B (from MUX 118A) and base route 113 are then input to another Mux 119.
Route 120 is generated via Mux 119 after a valid signal for the selected alternate port is obtained from register 116 (via Mux 119A). Route 120 is then used to route the packet. If the alternate port selected is not valid then Mux 119 selects a different route. When the route valid information is gathered automatically, then circuit 115 may be used to automatically heal a network or the Multi Level switch when links are bad or become inactive.
In one aspect, the Opcode field 122A may be used to identify unreliable datagram (UD) packets to allow for random route selection or selection of routes with the lightest traffic loads.
Configuration register 123 (may be a part of registers 104) is programmed with information for computing parity. For example, an algorithm like a “standard hamming code” may be used to determine input bits. For example if a bit in configuration register 123 has a value of “1” then the corresponding bit extracted from the packet is used in the parity calculation. If the value is “0” then the corresponding bit is not used in the parity calculation.
There may be different ways to implement the algorithms for determining parity. For example, if a scheme for calculating one bit and skipping one bit is used in the algorithm, then parity may be computed on bits 0,2,4,6, 8 and so forth. Similarly, if calculating two bits and skipping two bits is used, then parity is computed on bits 0,1,4,5,8,9 and so forth. Different algorithms may be used to obtain uniform distribution for offset 112. Statistics may be collected to further improve distribution for offset 112.
LUT 130 includes plural columns (shown as D0, D1, D2 and D3), for example, columns 128A, 128B, 128C and 128D that store destination addresses for each base route. The number of rows in LUT 130 may be equal to the number of base addresses possible, i.e., number of ports in ASIC 100. It is noteworthy that 4 columns are shown as an example, and any number of columns may be used to build LUT 130.
LUT 130 output (shown as 130A, 130B, 130C and 130D) includes plural alternate destination addresses that are input to Mux 127. Offset 112 (
It is noteworthy that Offset 112 may be used to form part of a memory address in a different LUT 130 configuration.
LUT 130 may also be used to remap actual physical port numbers to other port numbers (for example, virtual port numbers). Setting a control register bit in registers 104 may enable the remapping of physical port numbers. The remapping function may be used for various reasons, for example, if a link has been renamed; a switchboard design has been changed; link may be disabled and any other reason.
If remapping is enabled, then LUT 130 is loaded with remapped port numbers instead of actual physical port numbers derived directly from route 113. The remapped port numbers are then used to route the packet.
According to one embodiment, using alternate routes reduces congestion on an over-subscribed link (for example downlink of ISL 143) and balances load over multiple links. This method of load balancing enables a Multi Level switch and the network to perform efficiently with minimal congestion.
The process starts in step S200, when a packet arrives at a port (for example Port1105,
In step S201, the receive segment (or receive port) (not shown) of Port1105 parses the packet and extracts information, for example, DLID 122, SLID 121, Opcode 122A, QP 122B and other packet fields (
In step S202, the receive port performs a look up in routing table 102 using DLID 122. The output of the routing table is base route address 113 (
In step S203, receive port determines if an alternate route 120 is allowed for the current packet. Processor 103 may set a control bit to allow alternate routes. Each DLID may also be programmed to enable or disable alternate routes. The QP value may also be programmed to determine if alternate routes are enabled (or allowed). The programming of allowed DLIDs and QPs may be unique for each possible DLID or QP value or may be configured as range of values.
In step S209, the port routes the packet using base route address 113, if an alternate route is not allowed in step S203. Step S209 is also described below in detail with respect to
If alternate route is allowed in step S203, then in step S204, additional information including DLID 122, SLID 121, Opcode 122A and QP 122B or other packet fields are obtained to determine alternate route address 120.
In step S205, an offset 112 is determined using the circuit described above with respect to
In step S206, an alternate route is calculated.
In step S207, the port determines if the alternate route determined in step S206 is valid.
If the alternate route is valid in Step S207, then in step S208, the packet is routed using the alternate route address 120.
If the alternate route is invalid in Step S207, then in step S209, the packet is routed using the base route address 113.
If port number remapping is enabled, then in step S209C, the base address is used to perform LUT 130 access and remapped port numbers are obtained. Thereafter, in step S209D; the packet is routed using remapped port number, instead of the physical port numbers based on route 113.
Although the present invention has been described with reference to specific embodiments, these embodiments are illustrative only and not limiting. Many other applications and embodiments of the present invention will be apparent in light of this disclosure and the following claims.
Number | Name | Date | Kind |
---|---|---|---|
5473602 | McKenna et al. | Dec 1995 | A |
6185203 | Berman | Feb 2001 | B1 |
6397356 | Yonezawa | May 2002 | B1 |
6581166 | Hirst et al. | Jun 2003 | B1 |
6658521 | Biran et al. | Dec 2003 | B1 |
6788682 | Kimmitt | Sep 2004 | B1 |
7010607 | Bunton | Mar 2006 | B1 |
7133929 | Shah | Nov 2006 | B1 |
20030021223 | Kashyap | Jan 2003 | A1 |
20030195983 | Krause | Oct 2003 | A1 |
20050018673 | Dropps et al. | Jan 2005 | A1 |
20050018680 | Dropps et al. | Jan 2005 | A1 |
20050141518 | Schiller et al. | Jun 2005 | A1 |
20050281282 | Gonzalez et al. | Dec 2005 | A1 |
20060107323 | McLean | May 2006 | A1 |
20070147267 | Holland | Jun 2007 | A1 |
20070260814 | Branscome et al. | Nov 2007 | A1 |
20090296715 | Dropps et al. | Dec 2009 | A1 |