This invention relates to processing packets in a computer network. More particularly, this invention relates to techniques for accelerated page link list processing.
A packet processing device usually needs to buffer packets into a packet memory (PM) while the device processes them. The size of some packets (for example Ethernet packets) is not known in advance so the device needs to start storing the packet into the packet memory without knowing how large the packet is. Moreover, packets arrive at the device in an interleaved fashion, so the device is simultaneously storing several incoming packets into the packet buffer
The state of the art solution to store the packet in the device's memory is to assign multiple chunks (called pages) of packet memory to each packet, rather than a single big chunk. With this scheme, the packet is not stored consecutively in the packet memory, but rather is scattered in one or more pages throughout the packet memory. Therefore, a memory manager needs to maintain a linked list of all the pages that a particular packet uses in the packet memory; this linked list is traversed when the packet is read out of the packet memory for transmission.
The state of all the pages in the packet processor device is maintained by the memory manager. A packet has an associated descriptor that in its basic form is the pointer to the first page. With this initial pointer, all the pages used by the packet can be retrieved in the same order they were used by traversing the link list built from the next page pointers in the different page states.
Moreover, in a state of the art packet processing device, incoming packets are stored into the packet memory by a specialized direct-access memory (DMA) block (henceforth named Receive DMA or RDMA), and outgoing packets are retrieved from the packet memory by another DMA block (henceforth named Transmit DMA or TDMA).
The sequence of events is the following:
It is important to note that in order to request the state of the next page, the TDMA needs to have received the state of the current page (which contains the pointer to the next page). Therefore, there is a potentially large latency (in clock cycles) from the time the TDMA requests page state until it can request the next page state.
This latency can become an issue depending on the size of the page and the speed (bits per second) of the egress port. The higher the speed of the port:
The page size is limited by the packet memory utilization: the larger the page size, the lower the packet memory utilization becomes because the percentage of a page that is not used increases with its size. This memory inefficiency becomes more prominent for small-size packets. Reducing the unused portion of the buffer memory by having smaller pages enables a smaller packet buffer, thus saving precious on-chip area for other packet processing functions.
Not meeting wire speed on an egress port is very undesirable because it translates into under run errors. An under run error occurs when a packet has started to be transmitted on a port and the driver of the packet data to the port (in this case the TDMA) fails to provide some of the data of the packet at the rate that is dictated by the speed of the port. When an under run error on a packet occurs, the receiving party discards the packet, and the same packet usually needs to be retransmitted again, causing performance degradation on the network.
Consequently, it is a strong requirement to meet the wire speed of the egress ports (so no under run errors occur), but it is non-trivial to achieve this goal given the implementation challenges of a high page state return rate and and/or a large page size.
A packet processor has a packet memory manager configured to store a page walk link list, receive a descriptor and initiate a page walk through the page walk link list in response to the descriptor and without a prompt from transmit direct memory access circuitry. The packet memory manager is configured to receive an indicator of a single page packet and read a new packet in response to the indicator without waiting to obtain page state associated with the page of the single page packet.
A packet processor has a packet memory manager configured for cut-through operation so as to guarantee that the state of a first page of a packet is written by the time the descriptor of the packet is received. A first latency is applied to a second page of the packet, where the first latency is the difference between the latency of a packet processor ingress port to fill a full page with packet data and the maximum latency of a control block issuing a descriptor. A second latency is applied to each additional page of the packet, where the second latency is the latency of the packet processor ingress port to fill a full page with packet data.
The invention is more fully appreciated in connection with the following detailed description taken in conjunction with the accompanying drawings, in which:
Like reference numerals refer to corresponding parts throughout the several views of the drawings.
An embodiment of the invention reduces the latency between two consecutive page state requests (or equivalently increases the rate of page requests) by moving the walk of the page state link list from the TDMA to the memory manager. Since the memory manager is the owner of the link list, once it has read the state of a particular page it can immediately start reading the state of the next page without waiting for the TDMA to request it.
An exemplary sequence of events is as follows:
Note that the rate of page states has increased since now the latency between two page states is just Latency B. Moreover, the latency that the TDMA 302 sees for the first page state also has been reduced. In the baseline approach, this latency was
Latency BT+Latency B+Latency BT
The foregoing approach can be improved in the case of small-size packets that fit in a single page. In this case, the page state return rate has to be very high in order to meet the port wire speed. Because the packet is small, the port speed may dictate that the next page (corresponding to the next packet) needs to be available at the TDMA faster than the maximum rate of 1/(Latency of the memory manager). This is because the TDMA processes the data in the page faster since there is less data in each page.
The reason for the maximum rate in the foregoing example is shown in
For the particular case of small-size packets (where the whole packet fits in a page), the TDMA reads less data per each page state it gets from the memory manager. Consequently, the TDMA needs to obtain the page states at a higher rate. In this scenario, the maximum rate of 1/(Latency of the memory manager) may not be enough for an under run-free operation depending on the packet size and the port speed.
A solution to this problem is for the control block to provide additional information to the memory manager that indicates how many pages the packet has. In the case of single-page packets, this information is just a single bit (single-page packet) as shown with line 500 in
Now the memory manager 304 knows that the descriptor corresponds to a packet that uses a single page only, and can start the reading of the next page (that corresponds to the next packet) right away after reading the current page without waiting to obtain the result. This is depicted in
For a stream of small packets, the rate of page states to the TDMA has increased (i.e., its latency has been reduced to the Latency of the memory manager), and the effective rate is now the rate at which the TDMA can accept descriptors from the control block. Timeline 600 of
Note that it is assumed here that descriptors corresponding to packets to be sent on a particular egress port need to be processed in the same order that the control block provides them. This is a requirement if the packets correspond to the same ‘flow’, but it is not needed otherwise. Therefore, a different approach to solving the page-state rate would be to include the packet flow information, and allow parallel processing of packets that belong to different flows. However, besides increasing the complexity of the implementation, the fundamental issue still remains if the stream of small-size packets corresponds to packets of the same flow.
Packet processing devices may wait to start the transmission of a packet until all pages of the packet have been received, or may decide to start its transmission while pages are still being received. The first option, called store-and-forward, is used in the case where the device should not send the packet if the packet has incurred an error while it has been received by the device or when the content of the packet may be modified based on packet data that still has not been received.
The second option, called cut-through, is used in low latency devices where the packet data is sent as soon as the processing of the packet commences. Future errors in receiving the packet data will be made known to the TDMA, which will tag the packet with a bad Frame Check Sequence (FCS) field. Note that cut-through mode only applies to those packets that are received by an ingress port that has a speed that is higher or the same as the egress port to which the switched packet will be transmitted.
In cut-through mode there is a race condition when accessing a page state in which the memory manager may read a page state before that state has been written. This race condition is depicted in
Thereafter, the memory manager may read the state of the next page (page B) at t3, which is before page B's state is written at t4 (when all the data is received). Therefore, there is a race condition: the memory manager reads the state of page B before the state is updated, causing a functional error in the device due to stale state being read.
A solution to this problem comprises delaying the reading of page B by a certain delay (shown as ‘delay 1st’ in
Therefore, this ‘delay 1st’ value needs to take into account the latency from the time page A's state has been written until the descriptor is sent to the memory manager. This latency mainly includes the time spent being processed in the control block. This ‘delay 1st’ latency should then be:
Latency to fill a page−Max(Latency in control block)
The latency to fill a page is dependent on the speed of the ingress port. Usually the speed of both ingress and egress ports are the same. The case where the ingress port is slower than the egress port is not applicable to cut-through mode. For the case when the egress port is slower, the speed is determined by the egress port. Therefore, in any case the speed information needed by the memory manager to obtain the proper delay value can be derived from the egress port information in the descriptor provided by the control block.
This is shown in
Once page B has been read, a different delay needs to be applied to read the rest of the pages. This delay corresponds to the time it takes for the ingress port to fill a full page with packet data. This delay is labeled as ‘delay rest’ in
An embodiment of the present invention relates to a computer storage product with a non-transitory computer readable storage medium having computer code thereon for performing various computer-implemented operations. The media and computer code may be those specially designed and constructed for the purposes of the present invention, or they may be of the kind well known and available to those having skill in the computer software arts. Examples of computer-readable media include, but are not limited to: magnetic media, optical media, magneto-optical media and hardware devices that are specially configured to store and execute program code, such as application-specific integrated circuits (“ASICs”), programmable logic devices (“PLDs”) and ROM and RAM devices. Examples of computer code include machine code, such as produced by a compiler, and files containing higher-level code that are executed by a computer using an interpreter. For example, an embodiment of the invention may be implemented using JAVA®, C++, or other object-oriented programming language and development tools. Another embodiment of the invention may be implemented in hardwired circuitry in place of, or in combination with, machine-executable software instructions.
The foregoing description, for purposes of explanation, used specific nomenclature to provide a thorough understanding of the invention. However, it will be apparent to one skilled in the art that specific details are not required in order to practice the invention. Thus, the foregoing descriptions of specific embodiments of the invention are presented for purposes of illustration and description. They are not intended to be exhaustive or to limit the invention to the precise forms disclosed; obviously, many modifications and variations are possible in view of the above teachings. The embodiments were chosen and described in order to best explain the principles of the invention and its practical applications, they thereby enable others skilled in the art to best utilize the invention and various embodiments with various modifications as are suited to the particular use contemplated. It is intended that the following claims and their equivalents define the scope of the invention.
This application is a continuation of U.S. patent application Ser. No. 14/142,643 filed on Dec. 27, 2013, which claims priority to U.S. Provisional Patent Application Ser. No. 61/873,291, filed Sep. 3, 2013, the contents of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
6088758 | Kaufman | Jul 2000 | A |
7113985 | Narad et al. | Sep 2006 | B2 |
7133922 | She et al. | Nov 2006 | B1 |
7336606 | Romano et al. | Feb 2008 | B2 |
7689774 | O'Connell et al. | Mar 2010 | B2 |
7818389 | Chiang et al. | Oct 2010 | B1 |
8019825 | Johnston et al. | Sep 2011 | B1 |
8612711 | Griffin | Dec 2013 | B1 |
8645494 | Altman | Feb 2014 | B1 |
20020138700 | Holmberg | Sep 2002 | A1 |
20050034136 | Engstrom et al. | Feb 2005 | A1 |
20080051113 | Willey | Feb 2008 | A1 |
20080250208 | O'Connell et al. | Oct 2008 | A1 |
20090175286 | Naven et al. | Jul 2009 | A1 |
20100042755 | Fuente et al. | Feb 2010 | A1 |
20110085570 | Kotha et al. | Apr 2011 | A1 |
20110167170 | Kovvali et al. | Jul 2011 | A1 |
Number | Date | Country | |
---|---|---|---|
61873291 | Sep 2013 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14142643 | Dec 2013 | US |
Child | 14676791 | US |