The present invention relates to a switch device connecting at least one first point, in particular connecting at least one source device and/or at least another switch device, to at least one second point, in particular to at least one destination device and/or to at least another switch device, the switch device comprising at least one virtual channel.
The present invention further relates to a communication network or communication system for transmitting data, in particular at least one data packet or data stream, within at least one virtual channel.
The present invention further relates to a method for transmitting data, in particular data packets or data streams, within at least one virtual channel.
For off-chip interconnects, there is a clear shift towards lower pin-count serial technology and towards organising connections between devices in a network-like style. The communicated data is organised in streams of consecutive packets. For predictability, i. e. real-time applications, streams of different nature, for example video and audio, can be classified as separate traffic classes being differently treated by a network.
So-called virtual channels (VCs) are used in order to decouple those streams of different classes being transmitted over a shared physical connection. Each virtual channel has a certain part of the connection resources, for example physical link bandwidth or buffering, reserved or guaranteed. Data transmitted via different virtual channels arbitrate in a predictable way for a shared resource. By mapping streams of certain traffic classes onto particular virtual channels, mentioned differentiation between streams is achieved.
Above-described principles for organising predictable traffic are used in a newly standardised Intel's P[eripheral]C[component]I[nterconnect] Express off-chip bus/network as described in prior art document “PCI Express Base Specification”, Revision 1.0a, Apr. 15, 2003.
Moreover, the prior art articles by
consider the decoupling of data streams over multiple virtual channels in PCI Express networks.
The basic principle of PCI Express bridges is described in prior art document US 2004/0019729 A1. Moreover, in prior art document US 2004/0019726 A1 a system being built out of such PCI Express bridges is explained.
Both above-mentioned prior art documents describe a way of building a PCI Express bridge
However, differentiation of packets of the same type inside the same virtual channel is not considered in these prior art documents US 2004/0019726 A1 and US 2004/0019729 A1. The reordering is only done between different packet types, which is in the PCI Express specification. When there are two packets of the same type, for example Read Request but from different streams, there is no way of arbitrating which packet goes first. Both packets are treated as belonging to the same V[irtual]C[hannel], i. e. to the same logical stream.
However, such principles are also known from for instance A[synchronous]T[ransfer]M[ode] transmission networks. Exemplarily, in prior art document U.S. Pat. No. 6,339,596 B1 an ATM switching system is described. A new admission control technique in ATM networks, in particular a new way of calculating
using some specific model is described in prior art document U.S. Pat. No. 6,625,155 B1.
In the following, the principle of decoupling data streams that are transmitted over virtual channels (VCs) according to the prior art is described in more detail with reference to
In
The above-described approach has some disadvantages. One of these disadvantages is a limited amount of virtual channels 30, 32. As example, for PCI Express this is set in the specification to be eight. Therefore, a device 10, 12 connected via a single connection to another device 20 can use a maximum number of virtual channels, in case of PCI Express a maximum number of eight virtual channels.
As a consequence, arbitration between packets transmitted over a single connection, for example over a single port 40, can only be performed between those packets belonging to different virtual channels 30, 32. As depicted in
Since in PCI Express only eight virtual channels are allowed, each end point 10, 12 and/or 20, for example each source device and/or each destination device, attached to the PCI Express network can send only eight independent streams. If a PCI Express network should send a ninth stream, this ninth stream has to be multiplexed with one of the previous eight streams, and there is no way of differentiating services of the PCI Express for packets of the same type for both multiplexed and/or combined streams.
A specific case of the previously discussed generic problem exists in a device or switch unit 100* with only one virtual channel 30. Such conventional switch unit 100* comprising a single connection using a single virtual channel 30 is depicted in
However, in certain situations, for example like destination performance bottleneck, or due to congestions of a network, it would be beneficial to be able to differentiate between packets sent via a single connection even for the same virtual channel 30, 32.
In prior art document U.S. Pat. No. 5,754,783, an apparatus for interleaving timed program data with secondary data is described, wherein it is proposed to differentiate transport streams by using the same ports for multiple transport streams. However, since the apparatus according to this prior art document is not based on virtual channels, this prior art document cannot provide a solution for the problem of differentiating different data streams within one single virtual channel.
Starting from the disadvantages and shortcomings as described above and taking the prior art as discussed into account, an object of the present invention is to further develop a switch device of the kind as described in the chapter “Technical field”, a communication network or communication system of the kind as described in the chapter “Technical field” and a method of the kind as described in the chapter “Technical field” in such way that data, in particular data packets or data streams, being transmitted within the same virtual channel can be arbitrated and/or differentiated.
The object of the present invention is achieved by a switch device comprising
data, in particular at least one data packet or data stream, the ports being respectively assigned to the virtual channel. Moreover, the object of the present invention is achieved by a communication network or communication system comprising the features of claim 7 as well as by a method comprising the features of claim 9. Advantageous embodiments and expedient improvements of the present invention are disclosed in the respective dependent claims.
The present invention is principally based on the idea to use multiple ports for a single connection that allows for differentiation of data, in particular of traffic or of streams, within a single virtual channel. Thus, for differentiation of traffic or of streams within a single virtual channel, the present invention proposes to use multiple connections or multiple ports, in particular multi-port connections, instead of a single one. Therefore, the present invention provides a peer-to-peer connection stream differentiation within a single virtual channel.
For differentiation or arbitration of streams within a single virtual channel or within the same virtual channel, multiple ports for point-to-point connections are used. This principle is directly applicable for PCI Express off-chip connections and for other connections using the concept of virtual channels.
According to a particularly inventive refinement of the present invention, for a single connection, for example for a PCI Express connection, between a first point and a second point, in particular between devices, for example between an end point (source device and/or destination device) and a switch device, as many separate ports (so-called links) as the number of the streams
are used. Thus, different priorities between these streams can be set during configuration allowing for arbitration and therefore for differentiation of these streams.
Moreover, in an advantageous embodiment of the present invention, a conventional PCI Express port arbitration mechanism of unchanged PCI Express switches, bridges, etc. as discussed above in the chapter “Background and prior art” with reference to
Appropriately,
For arbitration of data streams incoming from different first points and outgoing to the same second point when they are assigned to the same virtual channel, advantageously multiple input ports and/or multiple output ports are used for a single connection or for a particular connection. In contrast to this advantageous embodiment of the present invention, in conventional systems only a single input port and only a single output port is used for a single connection.
By using multiple input ports, different streams coming from the same first point and sharing the same virtual channel, and therefore conventionally (i. e. without using multiple input ports) would not be distinguishable, according to the present invention can have different priorities and can arbitrate for the at least one output port which in turn allows for their differentiation. This increases overall predictability and flexibility of the system according to the present invention.
According to a particularly inventive refinement of the present invention at least two of the switch devices using multiple ports for point-to-point connections can be connected and/or cascaded. Such configuration allows for differentiation of streams within a single virtual channel for the whole network. The idea is directly applicable for PCI Express off-chip network and for other networks using the concept of virtual channels.
To create a communication network allowing for differentiation of streams even in one virtual channel according to the particularly inventive refinement of the present invention it is proposed to connect switch devices, in particular blocks, as described above.
The blocks can be modified and optionally additionally to usage of multiple input ports instead of a single input port, also multiple output ports instead of a single output port are used for a particular connection. This allows arbitration of data streams incoming from different ports and outgoing to different ports when these data streams are assigned to the same virtual channel.
In this way, different streams sharing the same virtual channel coming from different input ports can be routed to different output ports. Therefore, a network using such blocks can differentiate between streams using the same virtual channel. As a result, in every place in the network it is possible to differentiate streams belonging to the same virtual channel. Thus, the problem of stream differentiation is solved for the whole network.
In general, the present invention can be applied, in fact, in any connection infrastructure (system) using a virtual channel concept as described in the chapter “Background and prior art” above. In particular, PCI Express enabled devices can use the scheme of the present invention.
In particular, the present invention finally relates to the use of at least one switch device as described above and/or of at least one communication network or communication system as described above and/or of the method as described above for arbitration and/or differentiation of data, in particular data packets or data streams, being transmitted within the same virtual channel, in particular
As already discussed above, there are several options to embody as well as to improve the teaching of the present invention in an advantageous manner. To this aim, reference is made to the claims respectively dependent on claim 1 and on claim 7; further improvements, features and advantages of the present invention are explained below in more detail with reference to two preferred embodiments by way of example and to the accompanying drawings where
The same reference numerals are used for corresponding parts in
In order to avoid unnecessary repetitions, the following description regarding the embodiments, characteristics and advantages of the present invention relates (unless stated otherwise)
all embodiments 100, 100′ being operated according to the method of the present invention.
In
Moreover, the switch device 100 according to
For buffering the data, the switch device 100 depicted in
Furthermore, the switch device 100 depicted in
By the embodiment of the switch device 100, the problem of lack of arbitration per single virtual channel 30, 32 is solved. To this aim, in comparison to the conventional switch device 100* (as described in the chapter “Background and prior art” and as shown in
The rest of the switch device 100 in principle is similar to the conventional system of
When comparing the system 100* of
However, for a better understanding, in
The switch device 100 according to
For buffering the data, the switch device 100 depicted in
However, in order to be able to arbitrate the traffic within a single virtual channel 30 the number of ports 40, 42 needs to be increased, which causes increased costs and overall complexity of the system 100. Nevertheless, it is beneficial to be able to differentiate between packets sent via a single connection even for the same virtual channel 30. This as an advantage causes increased number of separate streams which can be accommodated in the switch device 100.
When composing the network out of devices described in
In
The switch device 100′ uses for a single connection, for instance from switch 100′ to switch 100′, two or more connections and two or more ports 40, 42 and 50, 52 at each side. Moreover, port arbiters can be programmed at each side according to priorities of different streams inside the same virtual channel 30, 32.
The embodiment presented in
However, contrarily to
When connecting or cascading devices 100′ as described in
Finally, an example for a situation in which it is beneficial to be able to differentiate between packets sent via a single connection even for the same virtual channel 30, 32 is given:
A video decoder produces video material that is displayed at destination device 20 as a main window combined with a smaller video window or with overlay graphics. Conventionally, all packets containing this video data would be assigned to a certain traffic class and therefore to a certain V[irtual]C[hannel] 30, 32. All video packets therefore are treated to be of the same importance.
However, in certain situations, like destination performance bottleneck, or due to congestions of the network, not all packets can be delivered. By arbitration between packets sent via a single connection even for the same virtual channel, for example packets that belong to main video and to overlay graphics, the system can decide to give a priority to the main video packets over the graphics data packet.
100* switch device (prior art; cf.
100 switch device, in particular first switch device (first embodiment of the present invention; cf.
100′ switch device, in particular first switch device (second embodiment of the present invention; cf.
10 first point, in particular source device, in relation to the switch device 100, 100′
12 another first point, in particular second source device, in relation to the switch device 100, 100′
20 second point, in particular destination device, in relation to the switch device 100, 100′
22 another second point, in particular second destination device, in relation to the switch device 100, 100′
24 yet another second point, in particular third destination device, in relation to the switch device 100, 100′
30 virtual channel, in particular first virtual channel
32 further virtual channel, in particular eighth virtual channel
40 first port, in particular first input port, for receiving data
40
a output signal of the first port 40
42 second port, in particular second input port, for receiving data
42
a output signal of the second port 42
50 first port, in particular first output port, for sending data
52 second port, in particular second output port, for sending data
60 virtual channel arbiter unit, in particular first virtual channel arbiter unit, assigned to the virtual channel 30
60
a output signal of the virtual channel arbiter unit 60
62 second virtual channel arbiter unit assigned to the single virtual channel 30
62
a output signal of the second virtual channel arbiter unit 62
64 further virtual channel arbiter unit assigned to the further virtual channel 32,
in particular eighth virtual channel arbiter unit assigned to the eighth virtual channel 32
64
a output signal of the further virtual channel arbiter unit 64
70 virtual channel buffer unit, in particular first virtual channel buffer unit, assigned to the virtual channel 30
70
a output signal of the virtual channel buffer unit 70
74 further virtual channel buffer unit assigned to the further virtual channel 32,
in particular eighth virtual channel buffer unit assigned to the eighth virtual channel 32
74
a output signal of the further virtual channel buffer unit 74
80 output buffer unit, in particular first output buffer unit, assigned to the virtual channel 30
80
a output signal of the output buffer unit 80
82 second output buffer unit assigned to the single virtual channel 30
82
a output signal of the second output buffer unit 82
90 output arbiter unit
90
a output signal of the output arbiter unit
200 communication network or communication system
N arbitrary number or undefined number
Number | Date | Country | Kind |
---|---|---|---|
04104984.2 | Oct 2004 | EP | regional |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/IB05/53302 | 10/7/2005 | WO | 10/3/2007 |