Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
SWITCHING DEVICE FOR ROUTING DATA, COMPUTER INTERCONNECTION NETWORK AND ROUTING METHOD USING SUCH DEVICE
Document Type and Number:
WIPO Patent Application WO/2011/148320
Kind Code:
A1
Abstract:
The invention is directed to a switching device (S ij ) adapted to connects parts of a computer interconnection network, having N input ports (Ia - Ih) and N output ports (Oa - Oh), the device adapted for routing data packets by means of direct crosspoints (CP xy ), the direct crosspoints configured for enabling direct connectivity between each of the N input ports to a subset m < N of the output ports only, in accordance with connectivity needs of the computer interconnection network. Preferably, it further comprises an additional circuitry (L) and additional crosspoints (ΑΡx,L, ΑΡL,y) configured such that at least some of the input ports of the switching device can be indirectly connected to at least some of the output ports of the switching device, through the additional circuitry. The invention further concerns an interconnection network and a method for routing data.

More Like This:
Inventors:
ABEL FRANCOIS (CH)
GUSAT MIRCEA (CH)
MINKENBERG CYRIEL J A (CH)
Application Number:
PCT/IB2011/052267
Publication Date:
December 01, 2011
Filing Date:
May 25, 2011
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
IBM (US)
ABEL FRANCOIS (CH)
GUSAT MIRCEA (CH)
MINKENBERG CYRIEL J A (CH)
International Classes:
G06F15/173; G06F17/50; H04L12/56; H04L45/60
Other References:
SCHERSON I D ET AL: "Least common ancestor networks", PARALLEL PROCESSING SYMPOSIUM, 1993., PROCEEDINGS OF SEVENTH INTERNATI ONAL NEWPORT, CA, USA 13-16 APRIL 1993, LOS ALAMITOS, CA, USA,IEEE COMPUT. SOC, US, 13 April 1993 (1993-04-13), pages 507 - 513, XP010031902, ISBN: 978-0-8186-3442-0, DOI: 10.1109/IPPS.1993.262825
NAKAMURA S ET AL: "LOWER BOUNDS ON CROSSPOINTS IN CONCENTRATORS", IEEE TRANSACTIONS ON COMPUTERS, IEEE SERVICE CENTER, LOS ALAMITOS, CA, US, vol. C-31, no. 12, 1 December 1982 (1982-12-01), pages 1173 - 1179, XP000820685, ISSN: 0018-9340
Attorney, Agent or Firm:
Ragot, Sebastien et al. (IBM Research - ZurichIntellectual Property La, Saeumerstrasse 4 Rueschlikon, CH)
Download PDF:
Claims:
CLAIMS

1. A switching device (Sy) adapted to connect parts of a computer interconnection network ( 100), having N input ports (Ia - Ih) and M output ports (Oa - Oh), wherein M is preferably equal to N, the device adapted for routing data packets by means of direct crosspoints (CPxy), the direct crosspoints configured for enabling direct connectivity between each of the N input ports and a subset m < Μοΐ the output ports only, in accordance with connectivity needs of the computer interconnection network.

2. The switching device according to claim 1, comprising a number of direct crosspoints less than or equal to NM - N\, N\ < Min[N, M], whereby the device prevents direct connectivity between at least a subset of the Ni input ports and Ni output ports corresponding to the same ports. 3. The switching device according to claim 1, comprising:

N\ input ports, N\ < N, adapted to receive data from one or more first network entities; and

N2 output ports, N2 < M, adapted to send data to one or more second network entities;

wherein the number of direct crosspoints is less than or equal to NM - N\ N2.

4. The switching device according to claim 3, wherein M = N and the number of direct crosspoints is equal to N2 - Ni N2 - (N- Min(Ni, N2)), with preferably Ni = N2 = N/2.

5. The switching device according to any one of claims 1 to 4, further comprising an additional circuitry (L) and additional crosspoints (AP^, AP£i J,) configured such that at least some of the input ports of the switching device can be indirectly connected to at least some of the output ports of the switching device, through the additional circuitry.

6. The switching device according to claim 5, wherein the additional crosspoints comprise:

- at least one first set of crosspoints (AP^), each connecting an input port (lx) of the device already connected to one or more direct crosspoints (CP^) to the circuitry (L); and - at least one second set of crosspoints (APL y), each connecting the circuitry to an output port (Oy) of the device already connected to one or more direct crosspoints (CP,,,).

7. A computer interconnection network (100), comprising at least one switching device (S^) according to any one of claims 1 to 6.

8. The computer interconnection network according to claim 7, comprising at least one switching device (S^) according to claim 3 or 4, and further comprising the one or more first network entities ( j-ij) and the one or more second network entities (Sm,). 9. The computer interconnection network according to claim 8, comprising at least one switching device (S^) according to claim 4, wherein:

- the one or more first network entities ( j-ij) are each a lower switching device in the computer interconnection network;

- the one or more second network entities ( ) are each an upper switching device in the computer interconnection network;

and wherein M = N and N\ = N2 = N/2, such that the at least one switching device comprises 3N2/4 - N/2 direct crosspoints, such as to prevent direct connectivity between:

- an input port and an output port corresponding to a same port of said device; and

- the N/2 input ports adapted to receive data from an upper switching device and the N/2 output ports adapted to send data to an upper switching device.

10. The computer interconnection network according to claim 7, 8 or 9, further comprising a computerized routing method for the computer interconnection network, preferably based on the up*/down* routing algorithm, and wherein the computer interconnection network is further configured such that the direct crosspoints (CPx,y) of the at least one switching device (S^) can directly connect the input ports (lx) to a subset of the output ports (Oy) only, in accordance with connectivity needs determined by the computerized routing method. 11. A computer-implemented method for routing data, comprising:

- providing the computer interconnection network according to any one of claims 7 to 10; and - routing data via crosspoints (CPxy) of the at least one switching device of the computer interconnection network.

12. The method of claim 11, wherein the computer interconnection network provided comprises at least one switching device (S^) according to claim 5, and wherein the step of routing data comprises:

- upon receiving a data packet for a pair of input port (I8) and output port (08) not connected by a direct crosspoint, routing said data packet via some of the additional crosspoints (ΑΡ8,ι, AP£,8) and circuitry (L) of the device.

13. The method of claim 11, wherein the computer interconnection network provided comprises at least one switching device according to claim 6, and wherein the step of routing data comprises:

- upon receiving a data packet for a pair of input port (I8) and output port (08) not connected by a direct crosspoint, routing said data packet by:

- directing said packet to a crosspoint (AP8i£) of the at least one first set, connected to the input port (I8) from which the data packet is received;

- via the circuitry (L), looping said packet back to a crosspoint (AP£i 8) of the second set, connected to an output port (08) to which the data packet is destined.

14. The method of claim 11, further comprising, before the step of providing, a step of determining the said connectivity needs by means of known or expected intensity of data packet arrivals at said input and output ports, and wherein the step of providing comprises providing the computer interconnection network (100), comprising at least one switching device (Sy), whose direct crosspoints are configured for enabling direct connectivity between each of the N input ports to a subset m < Μ οΐ the output ports only, in accordance with the determined

connectivity needs of the computer interconnection network.

15. A computer program product for routing data, said computer program product comprising:

- a computer readable storage medium; and

- program instructions to route data via crosspoints (CPx,y) of at least one switching device of a computer interconnection network according to any one of claims 7 to 10, wherein said program instructions are stored on said computer readable storage medium.

Description:
SWITCHING DEVICE FOR ROUTING DATA, COMPUTER INTERCONNECTION NETWORK AND ROUTING METHOD USING

SUCH DEVICE

FIELD OF THE INVENTION

The invention relates to the field of methods and systems for routing data in a computer interconnection network. In particular, it relates to a switching device having optimized circuitry for routing data packets from input ports to output ports thereof.

BACKGROUND OF THE INVENTION

One knows switching devices such as single-stage packet switching nodes. Such nodes have a given, inherent implementation complexity. Namely, in an N-port packet switch, there is an N-to-N connection problem that leads to quadratic complexity. Although there are many different switch architectures (e.g., input- queued, output-queued, combined input- and output-queued, shared memory, etc.), this complexity manifests itself in all of these architectures in some way.

This complexity essentially stems from the non-blocking requirement, which requires that any one-to-one communication pattern (permutation) can be routed without conflicts. The complexity can only be reduced by relaxing this requirement, i.e., by allowing conflicts to occur even between communications from/to different ports. This leads to blocking switch architectures, which are usually based on a shared medium such as a bus or on a multi-stage arrangement. A disadvantage of such approaches is the limited aggregate throughput achievable due to physical limitations of e.g. a bus-based implementation.

Most existing single-stage switching node implementations satisfy the non- blocking requirement, i.e., they provide the capability to send at full capacity from any input port to any output port. In the specific case of crossbar-based architectures (which may be buffered or unbuffered), this implies that the switching node comprises N 2 crosspoints. Moreover, in the case of buffered crossbar architectures, each crosspoint comprises a buffer that is sized to allow full link utilization over a full round-trip. In many cases, it can be realized that much of this buffering capacity will go largely unused, which represents a waste of precious resources.

BRIEF SUMMARY OF THE INVENTION

According to a first aspect, the present invention is embodied as a switching device adapted to connect parts of a computer interconnection network, having N input ports and M output ports, wherein M is preferably equal to N, the device adapted for routing data packets by means of direct crosspoints, the direct crosspoints configured for enabling direct connectivity between each of the N input ports to a subset m < M of the output ports only, in accordance with connectivity needs of the computer interconnection network.

In embodiments, the said device may comprise one or more of the following features:

The switching device comprises a number of direct crosspoints less than or equal to N M - N \ , N \ ≤ Min[N, M], whereby the device prevents direct connectivity between at least a subset of the Ni input ports and Ni output ports corresponding to the same ports. The switching device comprises:

o Ni input ports, Ni < N, adapted to receive data from one or more first network entities; and

o N 2 output ports, N 2 < M, adapted to send data to one or more second network entities; wherein the number of direct crosspoints is less than or equal to NM - N \ N 2 .

M = N and the number of direct crosspoints is equal to N 2 - N \ N 2 - (N - Min(Ni , N 2 )), with preferably N X = N 2 = Nil.

- the switching device further comprises an additional circuitry and additional crosspoints configured such that at least some of the input ports of the switching device can be indirectly connected to at least some of the output ports of the switching device, through the additional circuitry.

- the additional crosspoints comprise:

o at least one first set of crosspoints, each connecting an input port of the device already connected to one or more direct crosspoints to the circuitry; and

o at least one second set of crosspoints, each connecting the circuitry to an output port of the device already connected to one or more direct crosspoints.

According to a second aspect, the present invention is further embodied as a computer interconnection network, comprising at least one switching device according to embodiments of the invention.

In embodiments, the said network may comprise one or more of the following features: the computer interconnection network comprises at least one switching device according to embodiments of the invention and further comprises the one or more first network entities and the one or more second network entities;

the computer interconnection network comprises at least one switching device according to an embodiment of the invention, wherein:

o the one or more first network entities are each a lower switching device in the computer interconnection network;

o the one or more second network entities are each an upper switching device in the computer interconnection network;

and wherein M = N and = N 2 = N/2, such that the at least one switching device comprises 3N 2 /4 - N/2 direct crosspoints, such as to prevent direct connectivity between:

o an input port and an output port corresponding to a same port of said device; and

o the N/2 input ports adapted to receive data from an upper switching device and the N/2 output ports adapted to send data to an upper switching device;

the computer interconnection network further comprises a computerized routing method for the computer interconnection network, preferably based on the up*/down* routing algorithm, and the computer interconnection network is further configured such that the direct crosspoints of the at least one switching device can directly connect the input ports to a subset of the output ports only, in accordance with connectivity needs determined by the computerized routing method.

In yet another aspect, the present invention is embodied as a computer- implemented method for routing data, comprising: providing the computer interconnection network according to embodiments of the invention; and routing data via crosspoints of the at least one switching device of the computer interconnection network.

In embodiments, the said method may comprise one or more of the following features:

the computer interconnection network provided comprises at least one switching device according to an embodiment of the invention and the step of routing data comprises: upon receiving a data packet for a pair of input port and output port not connected by a direct crosspoint, routing said data packet via some of the additional crosspoints and circuitry of the device;

the computer interconnection network provided comprises at least one switching device according to an embodiment of the invention and the step of routing data comprises: upon receiving a data packet for a pair of input port and output port not connected by a direct crosspoint, routing said data packet by: directing said packet to a crosspoint of the at least one first set, connected to the input port from which the data packet is received; via the circuitry, looping said packet back to a crosspoint of the second set, connected to an output port to which the data packet is destined;

the method further comprises, before the step of providing, a step of determining the said connectivity needs by means of known or expected intensity of data packet arrivals at said input and output ports, and the step of providing comprises providing the computer interconnection network, comprising at least one switching device, whose direct crosspoints are configured for enabling direct connectivity between each of the N input ports to a subset m < M of the output ports only, in accordance with the determined connectivity needs of the computer interconnection network.

According to a final aspect, the present invention is further embodied as a computer program product for routing data, said computer program product comprising: a computer readable storage medium; and program instructions to route data via crosspoints of at least one switching device of a computer interconnection network according to embodiments of the invention, wherein said program instructions are stored on said computer readable storage medium.

A switching device, a computer interconnection network and a touting method embodying the present invention will now be described, by way of non-limiting examples, and in reference to the accompanying drawings.

BRIEF DESCRIPTION OF SEVERAL VIEWS OF THE DRAWINGS FIG. 1 schematically depicts a computer interconnection network;

FIG. 2 schematically illustrates a switching device having a crossbar- based architecture, with N 2 crosspoints, as known from prior art; and

FIGS. 3 - 7 depict switching devices, represented as sparsely populated crossbar structures, according to embodiments of the invention. One or more such devices may for instance be arranged in a computer interconnection network as depicted in FIG. 1.

DETAILED DESCRIPTION OF THE INVENTION

The present invention proposes switching devices that reduce redundancy based on a sparsely populated crossbar structure. In other words, the crosspoints are configured for enabling direct connectivity between N input ports of the switch to a subset m < M of the output ports only. Each of said crosspoints can thus be regarded as a direct crosspoint, inasmuch as it allows for a direct port-to-port connectivity. For the sake of simplicity, use is made of M = N (a square switch is assumed). However, many of the concepts discussed below can be straightforwardly extended to non- square switches.

As to be discussed in details later, embodiments provide additional crosspoints beyond the direct crosspoint, which are arranged such as to avoid sacrificing reachability. Yet, a reduced number of crosspoints can still be achieved.

We take here advantage of the fact that, generally, a switch is not meant to be used in isolation but instead as part of a larger system that comprises many such switches, connected to form a certain topology, and with a given routing method being used to route data packets according to that topology. In addition, the traffic patterns (spatial distribution) occurring in a given system may give rise to certain connections being much lighter loaded than others.

Taking these factors into account, we can reduce the switch complexity by optimizing the internal resources according to the usage patterns that result from routing scheme and/or traffic characteristics, be it prefixed or not. In other words, the presence of absence of direct crosspoints depends on connectivity needs of the computer interconnection network.

A key advantage of the invention is a reduction in the number of crosspoints needed to implement a switching node of a given dimension N. A sparsely populated structure basically reduces the complexity of the device. Note that the switch can be buffered or not. In the former case, the use of the buffering capacity can be optimized.

In this context, a crosspoint is to be understood as a generic means of (directly) connecting an input port with an output port. Taken individually, a crosspoint as used in embodiments of the present invention is for instance essentially comparable to one of the N 2 crosspoints as provided in known crossbar-based switch architectures. As the overall crosspoint count is a good indicator of overall switching node cost and complexity, reducing the number of crosspoints will generally lead to a commensurate cost reduction. As a specific example, in a buffered crossbar switch the crosspoints with their associated buffers and control logic account for the vast majority of the total complexity (in gates).

More in details now, computer interconnection networks such as interconnection networks in data centers or high-performance computing (HPC) systems are made up of individual packet switching nodes, inter-connected in a certain topology. Common topologies include indirect networks such as Clos networks, Benes networks, fat trees (k-ary n-trees), k-ary n- flies, and direct networks such as torus networks (k-ary n-cubes), meshes, hypercubes.

To determine a path from any source to any destination node on a given topology, a routing algorithm is needed. A path is uniquely determined by the sequence of links between switches that are taken to get from source to destination. Often, a routing algorithm has a particular structure or is subject to particular constraints. Examples of such constraints can be that only shortest-path routes may be taken (minimum number of hops), and that routes must be deadlock free (no cycles in the channel dependency graph).

FIG. 1 illustrates a fat tree multi-stage interconnection network 100. The fat tree shown in the figure is a 3-ary 3-tree (k = 3 (radix), n =3 (number of levels)). This notably means that each switch has three ports down and three ports up, so that three nodes can be connected to the switches in the lowest level, and each switch is connected to three switches in the next level. In other words, the fat tree can support 27 end nodes, denoted by Nl to N27, in this example. All connections in the network are fully bidirectional. End nodes (e.g., computing nodes) attach to the ports Ιι,ι,ι to Ii,9,3 at the bottom of the network (also the bottom of the figure), whereas the ports going up (Οι,ι,ι to 01,9,3) connect to another level of switches to scale the system to support additional nodes. More generally, input port (x = 1 , 2, . ..) denotes the x th input port of node Sy, where denotes the h node in the z 'th layer. Similarly, output port Oi j denotes the x th output port of node Sy. Furthermore, for a given node S^: the node j.i j is called a lower level switching device, while node i+ i j is an upper level switching device (with respect to the computing nodes). Note that some of the computing nodes (N2 - N5, N7 - N10, and N12 - N26) are not represented, for obvious clarity reasons. Other topologies could however be contemplated, involving other arrangements/numbers of switches and computing nodes.

On such a fat tree topology, the so called up*/down* routing appears to be a suitable algorithm. This routing algorithm works as follows: for a given source s and destination d:

1. Find a switching node (here denoted functionally by nca(s, d)) that is a nearest common ancestor of s and d; in case there are multiple candidates, one is selected according to a given rule; 2. Route upwards on the unique ascending path from s to nca(s, d);

3. Route downwards on the unique descending path from nca(s, d) to d; This algorithm has the properties of being shortest path as well as free of deadlocks.

For instance, FIG. 1 illustrates one of nine possible paths from node Nl to node N27 and from node Ni l to node N27, as well as one of three possible paths from node Nl to node N6. The switching node nca(l , 6), which corresponds to node S 2 , 2 , is for instance one of the possible nearest common ancestor of the nodes Nl and N6. Similarly, the nodes nca(l , 27) and nca(l l , 27) are identified in FIG. 1 , which respectively correspond to nodes S 3 ,i and S 3 , 2 .

Upon closer inspection, it can be realized that the above routing algorithm results in a limitation of the turns that are allowed to be taken in a given switching node. In particular, whenever a packet enters a switch coming down, it may never be routed back up again.

However, prior art switching nodes are implemented in a way that allows connections between any combination of inputs and outputs, i.e., they offer full connectivity. Such a switching node can for instance be considered as a matrix of crosspoints that directly connect input lines to output lines. An example of a matrix of crosspoints is depicted in FIG. 2: the direct crosspoints CP x , y connects input ports l x to output ports O y (indices i are henceforth dropped for conciseness, i.e., input port I x denotes the x th input port of the represented node). Therefore, a switching node that offers full connectivity has N 2 crosspoints (or N.M crosspoints, for non-square nodes). Furthermore, the actual implementation complexity associated with each crosspoint depends on the specific switching node architecture (unbuffered crossbar, buffered crossbar, shared memory, etc.), as known.

Taking into consideration that a given computer interconnection network (such as the network 100 of FIG. 1) may have "forbidden" turns, as e.g. defined by the routing algorithm and topology, we can next contemplate to remove some of the crosspoints. Yet, beyond networks as depicted in FIG. 1 and the up*/down* routing algorithm, the skilled person shall appreciate that other networks/routing algorithm may also results in forbidden data routes. For example, some particular nodes may be prevented from routing data from given first network entities to given second network entities. In such cases, a sparse crosspoint structure can advantageously be implemented at the switches, as outlined above.

This is for instance illustrated in the crosspoint structures of FIGS. 3 - 5. Again, the underlying switching device has N input ports \ x and M output ports O y . It is designed to route ("in") data packets from each of the input ports to some of the output ports ("out"), via the (direct) crosspoints CP^. In the examples of FIGS. 2 - 5, x = 1 , . ..8, and y = 1 , . .. 8. Furthermore, embodiments of FIGS. 3 - 7 could be applied to any node S y of an interconnection network such as depicted in FIG. 1.

As represented in the embodiments of FIGS. 3 - 5, the crosspoints CP x , y retained enable direct connectivity between the input ports to a subset m < M of the output ports only. From now on and for simplicity, we assume a square switch (M = N). In the particular example of FIG. 3, the number of direct crosspoints is exactly equal to N 2 - N, i.e., the direct crosspoints CP x , y = x have been removed (or rather, the switch is built without the crosspoints CP x , y = x ). Thus, the device prevents direct connectivity between input ports and output ports that correspond to a same port x, i.e. a same bidirectional port in that case. Indeed, if N 2 corresponds to the number of direct crosspoints required for full connectivity, N corresponds to the number of direct crosspoints required for direct connectivity between all pairs of input/output ports corresponding to a same port. Thus, the crosspoint structure illustrated in FIG. 3 has a reduced complexity.

More generally, the residual subset m < N of output ports can be designed in accordance with the connectivity needs of the network, resulting in different levels of node complexity.

For instance, the actual number of direct crosspoints may be less than N 2 - N \ {N \ < N), such as to prevent a direct connectivity between at least a subset of input ports (i.e., Ni input ports) and a corresponding number of output ports (i.e., corresponding to a same bidirectional port).

In other situations, one may want to prevent direct connectivity between the N \ input ports that receive data from a first subset of network entities and the N 2 output ports that send data to a second subset of entities. Thus, N 2 - N \ N 2 crosspoints would here be provided in this case. Comments are in order: each subset of network entities may possibly consist of only one node. Also, the two subsets may overlap and possibly correspond to the same entities.

In FIG. 4, N \ x N 2 crosspoints are notably discarded, preventing direct connectivity between first and second subsets of network entities. More precisely, in this example, one has N \ = N 2 = N/2, owing to the network topology considered here, i.e., the Ni incoming ports corresponding to the "up" side of the switch are not connected to the N 2 outgoing ports of the "up" side of the switch.

In addition, if the connectivity needs of the network are such that no port should ever have to route back to itself, as evoked earlier, then all crosspoints on the diagonal may further be omitted. Such a situation is illustrated in FIG. 4, whence the crosspoint pattern obtained.

The situation of FIG. 4 can be generalized to an embodiment where N 2 - Ni N 2 - (N - Min(Ni , N 2 )) crosspoints are provided, which amounts to prevent direct connectivity between input ports and N 2 output ports, while no port can route back to itself. In the particular case of = N 2 = N/2, the previous formula reduces to 3N 2 /4- N/2. Thus, such an embodiment allows to roughly omit one quarter of the direct crosspoints (for N large).

Next, as eliminating a crosspoint at the intersection between ports l x and O y implies that l x can no longer reach O y , we may want to restore connectivity, e.g. indirectly. To this aim, the switching device of the invention may further comprise, in embodiments, additional crosspoints configured such that input ports can be indirectly connected to output ports of the switch, through an additional circuitry L of the device. Thus, when receiving a data packet for a pair of input and output ports which is not connected by a direct crosspoint, the data packet can still be routed via the additional crosspoints and circuitry L of the device, as depicted in FIG. 5.

Conceptually, it can be realized that such a problem amounts to connect additional rows and columns of the crosspoint matrix structure, such that several actual embodiments can be contemplated. Advantageously yet, and as shown in FIG. 5, a simple embodiment uses two sets of additional crosspoints AP^ and AP^, connected through the additional circuitry L. Each additional crosspoint AP XJL connects an input port l x , already connected to direct crosspoints CP x , y , to the circuitry L. Similarly, a second set of additional crosspoints AP^ connects the circuitry to the output ports O y of the device.

More generally, we may add one or more fully populated columns and one or more fully populated rows to the switching matrix. These columns and rows do however not correspond to external ports; they are for internal use only. We refer to these additional rows and columns as "bypasses". Every bypass column is connected to one of the bypass rows (and vice versa), via the circuitry L, so that the latter creates internal loopback paths. The bypasses may be arranged such as to restore full reachability, independently of how many or which crosspoints have been eliminated. FIG. 5 shows an example for an 8 x 8 switching node with one bypass, i.e., the bypass column AP XTL is connected to the bypass row AP^, via the circuitry L.

Concerning now the operation of data at the nodes: whenever a packet arrives for an unconnected pair of ports (e.g., Is and Os), this packet is routed to the crosspoint on the extra column AP 8 ,i that corresponds to its source port; from there, it is looped back to the extra row AP^s to which the bypass is connected via the circuitry L, and is delivered to the crosspoint that corresponds to its destination port. Note that the bypass is shared by all port pairs that are not directly connected by a direct crosspoint. Packets from (directly) connected pair of ports are routed via the direct crosspoints, as usual. In the example of FIG. 5, the sparse crossbar (including the bypass) has actually 3N 2 /4 - N/2 + 2 N crosspoints (amongst which are 2 N additional crosspoints), versus N 2 for the fully connected crossbar. It can be shown that the sparse crossbar has lower complexity for any N > 6. For example, for N = 32, about 80% of crosspoints only needs to be retained. Increasing N allows for asymptotically approaching ~ 75% of the crosspoints, with respect to the full connectivity.

Next, in embodiments, the bypass may function as follows: when a packet arrives at a switch input, an input interface checks whether the packet is destined for a populated crosspoint. If yes, the packet is immediately routed to the destination crosspoint. Else, the packet cannot be routed directly to its destination column and must therefore be routed through a bypass. The input interface selects one out of available bypasses and routes the packet to the corresponding crosspoint AP^. Preferably, each bypass column has its own scheduler. The bypass scheduler selects a packet from its column and routes it via its loopback to the corresponding bypass row AP^ y and to the particular crosspoint corresponding to the destination port of the packet. Every output scheduler schedules packets from bypass crosspoints as well as the regular crosspoints in its column. Many scheduling disciplines can be contemplated. In addition, as a remark, note that if none of the bypasses is available, a packet may have to be dropped (e.g., in the case of a buffered crossbar).

As said, bypasses are implemented mainly to allow full connectivity, i.e., every port can reach every other port. It can be realized that they may not be suitable for connections that have strict performance requirements. A bypass such as described above typically has two performance drawbacks: First, there is a latency penalty, because every packet that takes a bypass is stored and read twice before exiting the switch (in a buffered crossbar). Second, flows that use bypasses all share a limited set of crosspoints and have access to a limited internal bandwidth, which by design is (much) smaller than the possible maximum aggregate throughput of the attached ports. For example, in FIG. 5, the maximum aggregate throughput of all traffic flowing from the "up"-side inputs to "up"-side outputs is limited to the bandwidth of the single loopback path, so that in the worst case the throughput of the affected flows is only 25% (i.e., when every input sends at 100% load to an unpopulated crosspoint). This limitation can yet be improved by adding more bypasses.

As further evoked, the crosspoint elimination patterns need not be as regular as illustrated in FIG. 5; the sparseness can take any shape, symmetric (see e.g. the exemplary embodiment of FIG. 6) or not (FIG. 7), in accordance with connectivity needs of the computer interconnection network. Furthermore, the bypass rows and columns can sensibly vary from the depicted patterns. In particular, it is noted that that, strictly speaking, there is no need to add bypass crosspoints AP^ / AP^ for row x or column y that is connected to all columns/rows, respectively. Also, where only one direct crosspoints is to be removed (owing to particular connectivity needs), it might actually be preferred to maintain it than to add the two crosspoints needed for the corresponding bypass. Corresponding variants to FIGS. 5 - 7 can thus be contemplated.

This approach can be generalized in a straightforward fashion to any topology and any routing scheme; given those, it is straightforward to determine for any switch which turns are never taken, and correspondingly eliminate crosspoints. Furthermore, the capacity of the bypass could be enhanced by adding multiple extra rows and columns (not represented). Note that, strictly speaking, if certain turns are never taken, a bypass for those turns is not even necessary. Implementing it nonetheless could however be useful for test/diagnosis purposes.

Moreover, the approach can also be generalized to take into account characteristics of the expected spatial traffic distribution. In some applications of packet switching, the traffic patterns observed at a switching node can be highly nonuniform, meaning that the traffic that flows in through a given input port is unequally distributed over the set of output ports, and/or the traffic that flows in through different input ports exhibits different distribution patterns.

For a given switch, all connections for which only very little traffic is expected could be mapped to a shared bypass. For instance, HPC applications often exhibit very particular communication patterns, in which, for example, most communications take place among immediate neighbors. In that respect, the method according to the invention may, in embodiments, comprise an initial step of determining connectivity needs of the network, e.g., relying on expected intensity of data packet arrivals at the switch ports. This in turns allows for optimizing the switch configurations (i.e., an optimized crosspoint structure for one or more switches to be used in the network and possibly how such switches can be arranged within the network too), in accordance with the determined connectivity needs.

As will be appreciated by one skilled in the art, aspects of the present invention may be embodied as a network, method or computer program product. Accordingly, aspects of the present invention may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to as a "circuit," "module" or "system." Furthermore, aspects of the present invention may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon. Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc readonly memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.

A computer readable signal medium may include a propagated data signal with computer readable program code embodied therein, for example, in baseband or as part of a carrier wave. Such a propagated signal may take any of a variety of forms, including, but not limited to, electro-magnetic, optical, or any suitable combination thereof. A computer readable signal medium may be any computer readable medium that is not a computer readable storage medium and that can communicate, propagate, or transport a program for use by or in connection with an instruction execution system, apparatus, or device.

Program code embodied on a computer readable medium may be transmitted using any appropriate medium, including but not limited to wireless, wireline, optical fiber cable, RF, etc., or any suitable combination of the foregoing.

Computer program code for carrying out operations for aspects of the present invention may be written in any combination of one or more programming languages, including an object oriented programming language such as Java, Smalltalk, C++ or the like and conventional procedural programming languages, such as the "C" programming language or similar programming languages. The program code may advantageously execute entirely on one or more of the end nodes or the lowest-level switches Si,,- (e.g., in particular for Ethernet networks). It may else execute partly on a end node or a lowest-level switch and partly on a remote node or switch (e.g. a higher level switch), or entirely on one or more higher level switches if the architecture permits. Different types of networks can be contemplated. As known, such switches can merely be regarded as computers, apart from network functionalities. In this respect, each switch can be implemented in hardware. It can however be implemented as a program run by one or more processors of a general purpose computer. A general purpose computer and processors are known per se.

It will be understood that any operation for aspects of the present invention can be implemented by computer program instructions, e.g., program instructions to route data via crosspoints of a switching device of an interconnection network. Such instructions may for instance be provided to a processor of a general purpose computer, node or switch, special purpose switch, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the switch or other programmable data processing apparatus, create means for implementing the functions/acts specified above.

These computer program instructions may also be stored in a computer readable medium that can direct a switch, computer, other programmable data processing apparatus, or other devices to function in a particular manner, such that the instructions stored in the computer readable medium produce an article of manufacture including instructions which implement the function/act specified in the flowchart and/or block diagram block or blocks.

The computer program instructions may also be loaded onto a computer, other programmable data processing apparatus, or other devices to cause a series of operational steps to be performed on the computer, other programmable apparatus or other devices to produce a computer implemented process such that the instructions which execute on the computer or other programmable apparatus provide processes for implementing the functions/acts specified.

While the present invention has been described with reference to certain

embodiments, it will be understood by those skilled in the art that various changes may be made and equivalents may be substituted without departing from the scope of the present invention. In addition, many modifications may be made to adapt a particular situation or material to the teachings of the present invention without departing from its scope. Therefore, it is intended that the present invention not be limited to the particular embodiment disclosed, but that the present invention will include all embodiments falling within the scope of the appended claims. For example, if most communications take place among immediate neighbors, then the direct crosspoints may be configured for enabling direct connectivity between ports corresponding to first neighbors only. Besides, although the present application essentially assumes bidirectional ports (and therefore squared switches) for illustration, applications can yet be contemplated to non-square switches with unbalanced input vs. output ports. For instance, at least some of the switches may include N input ports and M output ports, with N≠M. Such a device could be adapted for routing data packets by means of direct crosspoints, configured for enabling direct connectivity between each of the N input ports and a subset m < of the output ports only, in accordance with connectivity needs of the computer interconnection network. Similarly, the device may comprise a number of direct crosspoints less than or equal to NM~ N\, N\≤ Min[N, M], instead of N 2 - Ni, Ni < N, as described earlier in an embodiment, etc.