The present invention relates to buffering data and more particularly to buffering data that may be skewed.
In certain communication protocols, data in different physical channels may leave a transmitter at the same time and be received by a receiver at different times, causing misalignment or skew of the data. Although data may leave the transmitter at the same time, due to routing length differences, driver strengths and temperature, data on the different lanes can be received at a destination at different times, causing misalignment.
In the InfiniBand™ protocol (as set forth in the InfiniBand™ Architecture Specification Release 1.1, Nov. 6, 2002), when higher bandwidths are desired, multiple X1 lanes are combined to increase the rate at which data packets are sent. Such multiple lane modes may include an X4 mode and an X12 mode. When data is sent in X4 mode, four X1 lanes are combined and data is sent byte striped across the 4 lanes.
As an example of byte striping, a first byte may be sent on a first lane, a second byte sent on a second lane, a third byte sent on a third lane, a fourth byte sent on a fourth lane, a fifth byte sent on the first lane, and so on. In an X4 mode, data may be skewed in that data in lane 2 or lane 3, for example, is received before data from lane 0. Thus a need exists to deskew data that is misaligned during communication.
In various embodiments, data from multiple channels may be deskewed to realign the data so that a downstream receiver may receive correctly aligned bytes from channel to channel. In one embodiment, such deskewing may be performed by a deskew logic block. While discussed herein with respect to an embodiment for the InfiniBand™ protocol, other embodiments may be used in connection with other protocols such as a Peripheral Component Interconnect (PCI) Express architecture, PCI-SIG PCI Express Base Specification Rev. 1.0 (published Jul. 22, 2000) or another such protocol. Embodiments may be suitable for other serial protocols having multiple lanes, and other point-to-point protocols.
Deskewing in accordance with one embodiment of the present invention may be performed to realign individual lane data such that a downstream receiver may have correctly aligned bytes from lane to lane. In certain embodiments, skew of up to six symbol times between four lanes in an X4 mode of an InfiniBand™ system may be removed. Embodiments may be used for both X1 mode and X4 mode transmissions, although the scope of the present invention is not limited in this respect.
Referring now to
As shown in
Referring to
Similarly, buffer and logic 110 receives comma_lane_interrupt signals for each of the lanes. Also, buffer and logic 110 receives a LBB_force_align signal, which may be controlled by software to start a deskew operation.
In one embodiment, buffer and logic 110 may include four register files and associated multiplexers (not shown in
In one embodiment, each of the deskew state machines may use a training sequence one ordered-set (TS1) and a training sequence two ordered-set (TS2) to deskew the lanes. In such an embodiment, each lane deskew state machine may detect the presence of a comma character contained in the front of the training sequence. When a comma character is detected on a particular lane deskew state machine, a counter which may be located, for example, in logic 110, may be initiated to track the number of cycles from the detection of the comma character until commas are detected on all of the lanes.
In this embodiment, once commas are detected on all four lanes, reading of all the data is allowed. If the count becomes greater than six for any particular lane and all of the lanes have not yet detected commas, the deskew operation may be invalidated and begun again.
While discussed in the above embodiment as being activated by a comma character, embodiments of the present invention are not so limited. For example, any predetermined code (i.e., any number, character, symbol, or other identifier) may be used to begin a count of cycles. Further, in other embodiments such a predetermined code need not be part of a training sequence, and may instead be part of any desired data packet.
In the embodiment shown in
In one embodiment after reset, all lanes may be popped on every cycle. This may be done because during a first portion of link training (i.e., polling and configure_debounce), data is examined to find a TS1 sequence on any lane. In such an embodiment, read and write pointers in logic 110 may be offset by 2, so that initial read/write pointers are not equal.
After an initial portion of a link training state machine occurs, a deskew operation may be performed if an X4 mode or auto X4 mode is present. During this operation, each lane may be popped independently until a comma is seen on that lane. Then a stop and wait state may be entered until a comma character is seen on all lanes. In one embodiment, the first lane to detect a comma may start a counter in logic 110. If the counter reaches a predetermined number of cycles without being reset, the deskewing operation may be repeated, in certain embodiments. For example, in one embodiment, if the counter reaches a count of six, meaning six symbols have passed, the deskew operation may be deemed to be unsuccessful and may be begun again.
Alternately, if all lanes see a comma before the counter reaches the predetermined count, then a valid signal may be asserted, indicating that the link has been successfully deskewed. In the embodiment of
Once the link is deskewed, it may be monitored to confirm that it remains deskewed. For example, in one embodiment the link may be monitored by confirming that when a comma character is seen, it is seen on all lanes simultaneously. If not, the link has become skewed and a deskew operation may be performed again.
In an embodiment implementing an InfiniBand™ protocol, since SKP characters may not be written into buffer 110, it may become empty after a period of time. To prevent the emptying of buffer 110, read operations may be qualified, in certain embodiments. For example, in one embodiment, a buffer depth count may be set at a predetermined value for all lanes before the lanes can be read. For example in one embodiment, the buffer depth count may be set to be greater than or equal to two. In such an embodiment, if SKP characters or other situations cause a buffer depth to be two or less, data may be stalled until such a depth is reached. In certain embodiments, as a safety measure all register files may be written to assert errors if the buffers are either underflowed or overflowed.
Referring now to
As shown in
After reset, the deskew state machine may try to align incoming data. For example either a try_X4_align or a try_X1_align signal may be provided to the lane 0 deskew state machine 120. When a first TS1 sequence is detected on any lane, data may be popped until a comma character is seen in this lane, as represented by state 220 (pop_ln0). If a comma symbol is already present, control may directly pass to state 230 (wait_all_lanes). When a comma is detected in lane 0, control may pass to state 230 in which the deskew state machine waits until all lanes detect a comma. Also, a comma_ln0_interrupt signal and an en_window_ln0 signal may be asserted to indicate that a comma is present on lane 0 and to enable the counter within logic 110. For example, a counter or timer may be used to determine whether commas are detected in each lane prior to meeting a predetermined count or expiration of a predetermined time period. If a timeout occurs (or under software control), a signal (force_realign) may be asserted to send the deskew state machine back to state 210, to begin a deskew operation again.
If a comma is detected in all configured lanes before a timeout occurs, the link is thus aligned, as represented by aligned state 240 (ln0_aligned). Also, a comma_all_config_lanes signal may be asserted to the deskew state machines, and deskew data for lane 0 (i.e., deskew_data (7:0) ) may be sent to lane 0 deskew state machine 120. If after such alignment the link falls into misalignment, the force_realign signal may be activated to cause the state machine to return to state 210 and begin the deskew operation again.
Referring now to
As shown in
Referring now to
As shown in
Switch fabric 440 may include, in various embodiments switches, routers or other connecting devices. In the embodiment of
As shown in
Embodiments may be implemented in a computer program that may be stored on a storage medium having instructions to program a system to perform the embodiments. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic RAMs and static RAMs, erasable programmable read-only memories (EPROMs), electrically erasable programmable read-only memories (EEPROMs), flash memories, magnetic or optical cards, or any type of media suitable for storing electronic instructions. Other embodiments may be implemented as software modules executed by a programmable control device, such as a processor or a custom-designed state machine.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.