The present invention generally relates to SONET/SDH network elements and in particular, to an apparatus and method for reducing jitter in SPE data transmitted to a switch fabric.
In a synchronous optical network (SONET) network element (NE), incoming synchronous payload envelope (SPE) data are loaded into buffers upon arrival. When a switch fabric requests SPE data for a channel, the SPE data is retrieved from the channel's buffer, and loaded into a cell payload data unit (PDU) for transmission to and across the switch fabric. If there is insufficient SPE data in the buffer to fill the cell PDU, then nothing is sent to the switch fabric at that time. Since the stream of incoming SPE data arrives asynchronous with the switch fabric operation, such a retrieval and cell loading mechanism may cause undesirable jitter in the SPE data stream received on the outgoing side of the switch fabric.
Accordingly, one object of the present invention is an apparatus for reducing jitter in SPE data transmitted to a switch fabric.
Another object is a method for reducing jitter in SPE data transmitted to a switch fabric.
These and additional objects are accomplished by the various aspects of the present invention, wherein briefly stated, one aspect of the invention is an apparatus for reducing jitter in SPE data transmitted to a switch fabric, comprising: a buffer, and means for transmitting SPE data contained in the buffer along with a length of the SPE data to a switch fabric following each request received from the switch fabric for the SPE data.
Another aspect is an apparatus for reducing jitter in SPE data transmitted to a switch fabric, comprising: a buffer, and a processor programmed for retrieving SPE data from the buffer in response to each request received from a switch fabric for the SPE data, and determining a length of the retrieved SPE data so that the length is available to be provided with the SPE data to the switch fabric.
Another aspect is an apparatus for reducing jitter in SPE data transmitted to a switch fabric, comprising: buffers allocated to channel numbers, and means for receiving read requests and channel numbers from a switch fabric, retrieving SPE data from buffers allocated to the channel numbers, and determining lengths of the retrieved SPE data so that the lengths are available to be provided along with their corresponding SPE data to the switch fabric.
Yet another aspect is a method for reducing jitter in SPE data transmitted to a switch fabric, comprising: receiving a read request from a switch fabric, retrieving SPE data from a buffer corresponding to the read request, determining a length of the SPE data, and transmitting the SPE data and length to the switch fabric at a transmission rate.
Additional objects, features and advantages of the various aspects of the present invention will become apparent from the following description of its preferred embodiment, which description should be taken in conjunction with the accompanying drawing.
The following description and claimed invention are applicable to both synchronous optical network (SONET) and synchronous digital hierarchy (SDH) network elements and components. Accordingly, to simplify the following description and claims, it is to be understood that the term SONET, as used herein, shall be interpreted as including both SONET and SDH.
Incoming data streams carrying STS-1 and STS-Nc channels, where N<=12, do not have to be frame-synchronous with another for them to be processed. Streams that are carrying part of an STS-Nc channel, where N>12, however, should be frame-synchronous with one another in order for them to be processed properly. Thus, four STS-12 streams carrying an STS-48c channel should be frame synchronous, and in the case of an STS-192c channel, all sixteen STS-12 streams should be frame-synchronous. After passing over the inter-chip interconnect and through the RX line interface 201, such frame-synchronous streams may lose their frame alignment. Frame aligner 202 frame-realigns these streams using a small alignment FIFO for each STS-12 stream.
Pointer interpreter 203 interprets the H1 and H2 pointer bytes in the overhead sections of SONET frames to generate STS frame timing signals that identify the start of each synchronous payload envelope (SPE) and provide SPE valid timing in the frames. In addition, the pointer interpreter 203 interprets the H3 pointer byte in the overhead sections of SONET frames to detect ingress positive and negative frequency adjustments on the channels. The pointer interpreter 203 then forwards the sixteen STS-12 streams, the SPE frame timing, and the positive and negative frequency adjustment information to an RX SPE processor 204.
The RX SPE processor 204 uses the STS frame timing signals to extract the SPE out of the STS-12 streams, and store them in receive (RX) channel payload buffers 205. In order to properly extract STS-48c and STS-192c channels out of the STS-12 streams, the STS-12 streams are passed through a time slot interchange before storing in the RX channel payload buffers 205. The time slot interchange reorders the bytes read off the STS-12 streams according to the STS-N multiplexing rules, which require an STS-12 channel to be interleaved 4-byte chunks at a time. STS-12 streams carrying STS-1 and STS-Nc channels, where N<=12, bypass the time slot interchange.
The RX channel payload buffers 205 include a payload buffer assigned to each channel. Each STS-1 has a 64-byte buffer assigned to it. For concatenated payloads, a proportional number of STS-1 buffers are concatenated to form the channel payload buffer. In addition to storing the channel SPE data, an indication of the start of each SPE is also stored in the channel payload buffer.
A read request interface 206 receives channel read requests from the switch fabric 105, stores them in a 32-deep FIFO, and forwards the channel read requests one-by-one to the RX SPE processor 204. The switch fabric 105 generates the channel read requests based on its time slot configuration for various channels. The channel read request takes the form of an 8-bit channel identification and a 1-bit channel read request valid signal transmitted through a 125 MHz bus coupling the line card 101 to the switch fabric 105.
A segmentation engine in the RX SPE processor 204 receives the channel read request forwarded by the read request interface 206, segments the requested channel's SPE data from the channel payload buffer into a PDU of a time division multiplexed (TDM) cell, and inserts the TDM cell into the PDU of a protocol independent cell (PIC). The segmentation engine also determines the length of the SPE data loaded into the TDM cell PDU by conventional counter means, and stores the length along with additional control information in the PIC header to facilitate reassembly of the SPE data stream back into SPE form on the egress side of the switch fabric 105. The PIC is then sent to the switch fabric 105 in a CSIX frame through the transmit CSIX interface 207, which is responsible for transferring all ingress cell traffic to the switch fabric 105 across the industry standard CSIX interface.
Each PIC has a 4-byte header and 64-byte PDU, and each TDM cell has a 1-byte header and 63-byte PDU. Since a TDM cell PDU can carry data belonging to two consecutive SPE's, a start-of-SPE indicator and a next SPE pointer are provided in the TDM header to accommodate such occurrence. Since the TDM PDU is 63-bytes, the maximum number of SPE data bytes that can be loaded into a PIC for transmission to the switch fabric 105 is 63-bytes. The actual number is variable, however, since the number of SPE data bytes read and put into a TDM cell PDU by the segmentation engine depends upon how many SPE data bytes are in the requested channel buffer at the time of the channel read request from the switch fabric 105.
Thus, if there are only 32 bytes of SPE data at the time the switch fabric 105 makes its read request, only 32 bytes of SPE data are loaded in the TDM cell PDU, and the length of the SPE data is indicated as 32 bytes in the PIC header. It may also be possible that the channel payload buffer from which SPE data is being requested is empty when the switch fabric 105 makes its read request. This situation might occur, for example, if the bandwidth allocated to the requested channel by the switch fabric 105 is far in excess of what is needed. In this case, an empty cell containing an all zero payload is loaded into the TDM PDU and the length of the SPE data is indicated as 0 bytes in the PIC header.
By facilitating variable length SPE data payloads in the TDM PDU being transmitted, no opportunity is wasted to transmit SPE data to the switch fabric 105. This is useful to prevent loss of SPE data through buffer overflow and minimizes jitter in the SPE data transmitted to the switch fabric 105.
Although the switch fabric 105 controls its communications with line cards 101˜104, it operates asynchronously with the external communications of the line cards 101˜104.
Although the various aspects of the present invention have been described with respect to a preferred embodiment, it will be understood that the invention is entitled to full protection within the full scope of the appended claims.