 
                 Patent Grant
 Patent Grant
                     7337275
 7337275
                    This application relates to free list and ring data structure management.
A network processor may buffer data packets dynamically by storing received data in linked memory buffers. After the data associated with a particular buffer have been transmitted, that buffer may be returned to a pool, called a “free list,” where available buffers are stored.
A network processor may also buffer data packets using statically allocated, e.g., predefined memory buffers. A ring data structure includes such predefined memory locations. A pointer may be used to track the insertion location of the ring data structure. Another pointer may be used to track the removal location of the ring data structure.
Managing a large number of pools and buffers efficiently may be an important factor in the operation and cost of network processors.
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
    
Referring to 
Referring to 
As shown in 
The receive buffer 20 is configured to buffer data packets received from the source 12 of data packets. Each data packet may contain a real data portion representing the actual data being sent to the destination, a source data portion representing the network address of the source of the data, and a destination data portion representing the network address of the destination of the data. The receive pipeline 21 is coupled to the output of the receive buffer 20. The receive pipeline 21 also is coupled to a receive ring 22, which may have a first-in-first-out (FIFO) data structure. The receive ring 22 is coupled to the queue manager 27.
The receive pipeline 21 is configured to process the data packets from the receive buffer 20 and store the data packets in data buffers included in memory addresses 38 in the second memory 32. The receive pipeline 21 makes requests 23 to the queue manager 27 through the receive ring 22 to append a buffer to the end of a queue.
Once the data packets are processed by the receive pipeline 21, the receive pipeline may generate enqueue requests 23 directed to the queue manager 27. The receive pipeline 21 may include multi-threaded programming engines working in a pipelined manner. The engines receive packets, classify them, and store them on an output queue based on the classification. This receive processing determines an output queue for each packet. By pipelining, the programming engine may perform the first stage of execution of an instruction and, when the instruction passes to the next stage, a new instruction may be started. The processor does not have to lie idle while waiting for the first instruction to be completed. Therefore, pipelining may lead to improvements in system performance. An enqueue request represents a request to append a buffer descriptor that describes a newly received buffer to the last buffer descriptor in a queue of buffer descriptors 48 in the first memory 30. The receive pipeline 21 may buffer several packets before generating an enqueue request. Consequently, the total number of enqueue requests generated may be reduced.
The transmit scheduler 24 is coupled to the queue manager 27 through the receive ring 22 and is responsible for generating dequeue requests 25 based on specified criteria. Such criteria may include the time when the number of buffers in a particular queue of buffers reaches a predetermined level. The transmit scheduler 24 determines the order of packets to be transmitted. A dequeue request 25 represents a request to remove the first buffer from the queue 48. The transmit scheduler 24 also may include scheduling algorithms for generating dequeue requests 25 such as “round robin”, priority-based or other scheduling algorithms. The transmit scheduler 24 may be configured to use congestion avoidance techniques such as random early detection (RED) which involves calculating statistics for the packet traffic. The transmit scheduler maintains a bit for each queue signifying whether the queue is empty.
The queue manager 27, which in one implementation is provided by a single multi-threaded programming engine, processes enqueue requests from the receive pipeline 21 as well as dequeue requests from the transmit scheduler 24. The queue manager 27 allows for dynamic memory allocation by maintaining linked list data structures for each queue.
The queue manager 27 includes software components configured to manage a cache of data structures that describe the queues (“queue descriptors”). As shown in 
Referring to 
The queue manager 27 may alternately service enqueue and dequeue requests. For single-buffer packets, an enqueue request references a tail pointer of an entry in the data store portion 44b. A dequeue request references a head pointer of an entry in the data store portion 44b. Because the cache includes valid updated queue descriptors, the need to lock access to a queue descriptor may be eliminated when near simultaneous enqueue and dequeue operations to the same queue are required. Therefore, the atomic accesses and latency that accompany locking may be avoided.
The data store portion 44b maintains a list of a certain number of the most recently used (MRU) queue descriptors 46. Each queue descriptor includes pointers to a corresponding MRU queue of buffer descriptors 48. In one implementation, the number of MRU queue descriptors 46 in the data store portion 44b is sixteen. Each MRU queue descriptor 46 is referenced by a set of pointers 45 residing in the tag portion 44a. In addition, each MRU queue descriptor 46 may be associated with a unique identifier so that it may be identified easily.
Referring to 
A buffer descriptor is a data structure that describes a buffer. A buffer descriptor may include an address field, a cell count field and an end of packet (EOP) bit. The address field includes the memory address of a data buffer. Because each data buffer may be further divided into cells, the cell count field includes information about a buffer's cell count. The EOP bit is set to signify that a buffer is the last buffer in a packet.
Referring back to 
As shown, for example, in 
Referring again to 
Each enqueue request includes an address 38 of the data buffer associated with the corresponding data packet. In addition, each enqueue or dequeue request includes an identifier specifying either an uncached queue descriptor 50 or a MRU queue descriptor 46 associated with the data buffer included in memory address 38.
Referring to 
The buffer descriptor pointer 55c associated with buffer descriptor C is changed from a NULL value and is set 102 to point to the subsequent buffer descriptor D. That is accomplished by setting the buffer descriptor pointer 55c to the address of the buffer descriptor D. The buffer descriptor D points to the data buffer in memory address 38d that stores the received data packet, as indicated by line 53d.
Once the buffer descriptor pointer 55c has been set, the tail pointer 50b is set 104 to point to buffer descriptor D as indicated by dashed line 61. That is accomplished by setting the tail pointer 50b to the address of the buffer descriptor D. Since buffer descriptor D is now the last buffer descriptor in the queue 48a, the value of the buffer descriptor pointer 55d is NULL. Moreover, the value in the count field 50c is updated to “4” to reflect the number of buffer descriptors in the queue 48a. As a result, the buffer descriptor D is added to the queue 48a by using the queue descriptor 46a residing in the data store portion 44b.
If the enqueue command 13 includes a queue identifier specifying a queue descriptor which is not among the MRU queue descriptors 46, the queue manager 27 replaces a particular MRU queue descriptor 46 with the specified queue descriptor. As a result, the specified queue descriptor and the corresponding uncached queue of buffer descriptors are referenced by the data store portion 44b. In addition, for an enqueue command, the newly referenced queue of buffer descriptors 52 associated with the specified queue descriptor is updated to point to the memory address of the particular data buffer included in memory address 38 storing the received data packet. The MRU queue descriptor 46 may be updated quickly and efficiently because the queue descriptor is already in the data store portion 44b.
Referring to 
Referring to 
The head pointer 50a is set 202 to point to the next buffer descriptor B in the queue 48a as indicated by the dashed line 64. That may be accomplished by setting the head pointer 50a to the address of buffer B descriptor. The value in the count field 50c is updated to “4”, reflecting the remaining number of buffer descriptors (B through E). As a result, the data buffer included in memory address 38a is retrieved from the queue 48a by using the queue descriptor 46a residing in the data store portion 44b.
The queue manager 27 may receive 204 subsequent dequeue requests 25 associated with the same queue descriptor. It is assumed, for example, that the queue manager 27 receives a further dequeue request 25 associated with the queue descriptor 46a. Referring to 
In some situations, however, the queue descriptor 46a currently occupying an entry of the data store portion 44b is not associated with the data buffer in memory address 38b. In that case, the processor 18 performs 208 a replacement task similar to the one discussed above. Once the replacement task has been completed, operations associated with the dequeue request are performed as discussed above.
The cache of queue descriptors may be implemented in a distributed manner such that the tag portion 44a resides in the memory controller 34 and the data store portion 44b resides in the first memory 30. Data buffers included in memory addresses 38 that are received from the receive buffer 20 may be processed quickly. For example, the second of a pair of dequeue commands may be started once the head pointer for that queue descriptor is updated as a result of the first dequeue memory read of the head pointer. Similarly, the second of a pair of enqueue commands may be started once the tail pointer for that queue descriptor is updated as a result of the first enqueue memory read of the tail pointer. In addition, using a queue of buffers, such as a linked list of buffers, allows for a flexible approach to processing a large number of queues. Data buffers may be quickly enqueued to the queue of buffers and dequeued from the queue of buffers.
Entries of the data store portion 44b of the cache which are not used to store information describing the structure of a queue of data buffers may be used to store (1) information describing the structure of a free list as non-cached or permanently-resident entries; (2) information describing the structure of a memory ring as non-cached or permanently-resident entries, (3) information describing the structure of a journal as permanently resident entries or (4) any combination of these uses. Permanently-resident entries are entries that will not be removed to make space for new entries.
A free list functions as a pool of currently unused buffers. Free lists may be used for buffer storage by systems that dynamically allocate memory. Such systems allocate available free storage from a free list for newly received data. An entry is taken from the pool as needed when a packet or cell is received. An entry is returned to the pool when the packet or cell is transmitted or discarded. When a free list is implemented using a linked list data structure, a new buffer may be taken from the front of the queue of currently unused buffers using the dequeue command. Similarly, a buffer whose usage is terminated may be added to the end of the queue of currently unused buffers using the enqueue command.
Alternatively, when a free list is implemented using a stack data structure, a new buffer may be removed for newly received data from the stack using a pop command. A buffer whose usage may be terminated may be added to the stack using a push command. Because a stack is a last-in, first-out (LIFO) data structure, buffers are removed in the reverse order from that in which they are added to the stack. The buffer most recently added to the stack is the first buffer removed.
As shown in 
The entries 146 of the data store portion used to store queue descriptors describing a structure of a free list may be non-cached or permanently resident entries. Therefore, for each queue descriptor describing a structure of a free list desired to be stored, the fetch replacement task may be performed only once at system initialization to load them into a subset 146 of the entries of the data store portion of the queue.
When the data contained in a buffer has been transmitted, the present usage of the buffer is terminated and the buffer is returned to the free list to replenish the pool of currently unused buffers. A processing engine thread, such as a thread providing a queue manager 27, may generate an enqueue command directed to the memory controller that references a free list entry 146.
Referring to 
Each buffer in the free list 148a, such as a first buffer V, contains a buffer pointer 155v that points to a next ordered buffer W. The buffer pointer 155y associated with the last buffer Y has a value set to NULL to indicate that it is the last buffer in the queue 148a.
In the example illustrated in 
Once the buffer pointer 155y has been set, the tail pointer 150b is set to point to buffer Z as indicated by dashed line 161. This may be accomplished by setting the tail pointer 150b to the address of the buffer Z. Moreover, the value in the count field 150c is updated to “5” to reflect the number of buffers in the free list 148a. As a result, the buffer Z is added to the free list 148a by using the queue descriptor 146a residing in the data store portion 44b.
When a store and forward processor receives a new data packet, the system allocates a buffer from the free list.
Referring to 
Referring to 
As discussed above, enqueue operations that reference information describing the structure of a free list in the cache are used to return buffers to that free list. Dequeue operations that reference information describing the structure of a free list in the cache are used to remove buffers from that free list. Using the present technique, the processor may manage a large number of free lists in an efficient and low cost manner by using hardware (e.g., a memory controller, CAM) already present to perform other tasks.
Entries of the data store portion 44b of the cache which are not used to store information describing the structure of a queue of data buffers also may be used to manage a ring data structure. Because a ring data structure includes a block of contiguous memory addresses that is of a predefined size and location, it may be used for static memory allocation.
Referring to 
A context of a programming engine may issue a put command to cause data to be written to a ring data structure. The put command specifies a length field and a head pointer, where the length field is specified as a number of words.
Referring to 
A context of a programming engine may issue a get command to cause data to be read from a ring data structure. The get command specifies a length field and a tail pointer, where the length field is specified as a number of words.
Referring to 
Because a network processor may include multiple programming engines each of which may execute multiple threads or contexts, observing how code is executing on any individual programming engine thread and tracking the progress of different programming engine threads with respect to one another may be useful to help debug applications running on the network processor.
The present technique defines and implements a set of journaling commands that provide a way to observe how code is executing during system operation. The technique uses entries of the data store portion 44b of the cache that are not used to store information describing the structure of a queue of data buffers. These entries are used to manage a ring data structure implemented as a journal. Each of these entries includes information describing a structure of a ring. As discussed earlier in connection with 
Although an executing program may generate messages that provide useful information about the state of an executing context when predetermined locations of the program are reached, the number of instructions used to support a journal should be minimal. Otherwise, the system resources used to support the journal may interfere with the system's real-time programming needs. Hence, the amount of information in the journal should be balanced against the number of instructions and cycles necessary to provide this information.
A context of a programming engine may issue a journal command. The journal command is defined to move a number of words specified by the length field from a memory register to the journal, where each word may include thirty-two bits of journaling information. The journal command may be used to store a number of words from a memory register to the journal when predetermined checkpoints in a program are reached.
The journal_tag command is defined to move a number of words specified by the length field from a memory register to the journal. Each word includes thirty-two bits of journaling information, comprising four bits of programming engine identification, three bits of thread identification and twenty-five bits of journaling information. Hence, the journal_tag command may include the data information provided by the journal command and also may include information about which programming engine and which context of that programming engine issued the journal_tag command.
The fast_journal command is defined to move the command address field from a memory register to the journal. Because all commands have an address field, the fast_journal command provides information about which command or checkpoint was reached in the program that is being debugged.
The fast_journal_tag command is defined to move the command address field from a memory register to the journal, where each word may include four bits of programming engine identification, three bits of context identification, and twenty-five bits of command address to indicate what command was issued. Therefore, the fast_journal_tag command may include the data information provided by the fast_journal command and also may include information about which programming engine and which context of that programming engine issued the command.
The present technique can provide a method of implementing elaborate tracking systems in an efficient and low cost manner by using hardware already present for performing other tasks. One implementation includes sixteen programming engines with eight contexts each. The implementation also includes sixty-four data store portion entries per SRAM channel, sixteen of which are used to store information describing the structure of a queue of data buffers. Because as many as forty-eight data store portion entries may be available per SRAM channel to store information describing the structure of a journal, the present technique may support multiple journals. Other implementations may differ in some respects.
After writing to all memory locations of a journal that implements a ring data structure, the tail pointer wraps around to the start address of the journal to continue writing data. If the ring data structure is completely written, subsequent journal write operations will overwrite the data previously written. Only the most recent data will be present in the ring. The put command, discussed earlier, returns a ring full notification to the programming engine context that issued the put command, using a status bit to indicate there is insufficient memory available to write the specified length of words to the ring. In contrast, all journal commands are completed because there is no need to wait if the insert pointer exceeds the remove pointer.
Various features of the system may be implemented in hardware, software, or a combination of hardware and software. For example, some aspects of the system may be implemented in storage media, having instructions stored thereon, executed by a machine or in computer programs executing on programmable computers or processors. Each program may be implemented in a high level procedural or object-oriented programming language to communicate with a computer system. Furthermore, each such computer program may be stored on a storage medium, such as read-only-memory (ROM) readable by a general or special purpose programmable computer, for configuring and operating the computer when the storage medium is read by the computer to perform the tasks described above.
Other implementations are within the scope of the following claims.
| Number | Name | Date | Kind | 
|---|---|---|---|
| 3373408 | Ling | Mar 1968 | A | 
| 3478322 | Evans | Nov 1969 | A | 
| 3792441 | Wymore et al. | Feb 1974 | A | 
| 3881173 | Larsen et al. | Apr 1975 | A | 
| 3913074 | Homberg et al. | Oct 1975 | A | 
| 3940745 | Sajeva | Feb 1976 | A | 
| 4023023 | Bourrez et al. | May 1977 | A | 
| 4045782 | Anderson et al. | Aug 1977 | A | 
| 4130890 | Adam | Dec 1978 | A | 
| 4189767 | Ahuja | Feb 1980 | A | 
| 4392758 | Bowles et al. | Jul 1983 | A | 
| 4400770 | Chan et al. | Aug 1983 | A | 
| 4514807 | Nogi | Apr 1985 | A | 
| 4523272 | Fukunaga et al. | Jun 1985 | A | 
| 4569016 | Hao et al. | Feb 1986 | A | 
| 4724521 | Carron et al. | Feb 1988 | A | 
| 4742451 | Bruckert et al. | May 1988 | A | 
| 4745544 | Renner et al. | May 1988 | A | 
| 4777587 | Case et al. | Oct 1988 | A | 
| 4833657 | Tanaka | May 1989 | A | 
| 4866664 | Burkhardt, Jr. et al. | Sep 1989 | A | 
| 4868735 | Moller et al. | Sep 1989 | A | 
| 4992934 | Portanova et al. | Feb 1991 | A | 
| 5008808 | Fries et al. | Apr 1991 | A | 
| 5073864 | Methvin et al. | Dec 1991 | A | 
| 5113516 | Johnson | May 1992 | A | 
| 5140685 | Sipple et al. | Aug 1992 | A | 
| 5142676 | Fried et al. | Aug 1992 | A | 
| 5142683 | Burkhardt, Jr. et al. | Aug 1992 | A | 
| 5155831 | Emma et al. | Oct 1992 | A | 
| 5155854 | Flynn et al. | Oct 1992 | A | 
| 5165025 | Lass | Nov 1992 | A | 
| 5166872 | Weaver et al. | Nov 1992 | A | 
| 5168555 | Byers et al. | Dec 1992 | A | 
| 5173897 | Schrodi et al. | Dec 1992 | A | 
| 5247671 | Adkins et al. | Sep 1993 | A | 
| 5255239 | Taborn et al. | Oct 1993 | A | 
| 5263169 | Genusov et al. | Nov 1993 | A | 
| 5274770 | Yeoh et al. | Dec 1993 | A | 
| 5347648 | Stamm et al. | Sep 1994 | A | 
| 5357617 | Davis et al. | Oct 1994 | A | 
| 5363448 | Koopman, Jr. et al. | Nov 1994 | A | 
| 5367678 | Lee et al. | Nov 1994 | A | 
| 5390329 | Gaertner et al. | Feb 1995 | A | 
| 5392391 | Caulk, Jr. et al. | Feb 1995 | A | 
| 5392411 | Ozaki | Feb 1995 | A | 
| 5392412 | McKenna | Feb 1995 | A | 
| 5404464 | Bennett | Apr 1995 | A | 
| 5404482 | Stamm et al. | Apr 1995 | A | 
| 5428809 | Coffin et al. | Jun 1995 | A | 
| 5432918 | Stamm | Jul 1995 | A | 
| 5436626 | Fujiwara et al. | Jul 1995 | A | 
| 5442756 | Grochowski et al. | Aug 1995 | A | 
| 5448702 | Garcia, Jr. et al. | Sep 1995 | A | 
| 5450351 | Heddes | Sep 1995 | A | 
| 5450603 | Davies | Sep 1995 | A | 
| 5452437 | Richey et al. | Sep 1995 | A | 
| 5459842 | Begun et al. | Oct 1995 | A | 
| 5463625 | Yasrebi | Oct 1995 | A | 
| 5467452 | Blum et al. | Nov 1995 | A | 
| 5481683 | Karim | Jan 1996 | A | 
| 5487159 | Byers et al. | Jan 1996 | A | 
| 5517628 | Morrison et al. | May 1996 | A | 
| 5517648 | Bertone et al. | May 1996 | A | 
| 5541920 | Angle et al. | Jul 1996 | A | 
| 5542070 | LeBlanc et al. | Jul 1996 | A | 
| 5542088 | Jennings, Jr. et al. | Jul 1996 | A | 
| 5544236 | Andruska et al. | Aug 1996 | A | 
| 5550816 | Hardwick et al. | Aug 1996 | A | 
| 5557766 | Takiguchi et al. | Sep 1996 | A | 
| 5568617 | Kametani | Oct 1996 | A | 
| 5574922 | James | Nov 1996 | A | 
| 5574939 | Keckler et al. | Nov 1996 | A | 
| 5592622 | Isfeld et al. | Jan 1997 | A | 
| 5600812 | Park | Feb 1997 | A | 
| 5606676 | Grochowski et al. | Feb 1997 | A | 
| 5610864 | Manning | Mar 1997 | A | 
| 5613071 | Rankin et al. | Mar 1997 | A | 
| 5613136 | Casavant et al. | Mar 1997 | A | 
| 5623489 | Cotton et al. | Apr 1997 | A | 
| 5627829 | Gleeson et al. | May 1997 | A | 
| 5630130 | Perotto et al. | May 1997 | A | 
| 5640538 | Dyer et al. | Jun 1997 | A | 
| 5644623 | Gulledge | Jul 1997 | A | 
| 5649109 | Griesmer et al. | Jul 1997 | A | 
| 5649157 | Williams | Jul 1997 | A | 
| 5652583 | Kang | Jul 1997 | A | 
| 5659687 | Kim et al. | Aug 1997 | A | 
| 5659722 | Blaner et al. | Aug 1997 | A | 
| 5680641 | Sidman | Oct 1997 | A | 
| 5689566 | Nguyen | Nov 1997 | A | 
| 5692167 | Grochowski et al. | Nov 1997 | A | 
| 5699537 | Sharangpani et al. | Dec 1997 | A | 
| 5701435 | Chi | Dec 1997 | A | 
| 5717760 | Satterfield | Feb 1998 | A | 
| 5717898 | Kagan et al. | Feb 1998 | A | 
| 5721870 | Matsumoto | Feb 1998 | A | 
| 5724563 | Hasegawa | Mar 1998 | A | 
| 5742587 | Zornig et al. | Apr 1998 | A | 
| 5742782 | Ito et al. | Apr 1998 | A | 
| 5742822 | Motomura | Apr 1998 | A | 
| 5745913 | Pattin et al. | Apr 1998 | A | 
| 5751987 | Mahant-Shetti et al. | May 1998 | A | 
| 5761507 | Govett | Jun 1998 | A | 
| 5761522 | Hisanaga et al. | Jun 1998 | A | 
| 5781774 | Krick | Jul 1998 | A | 
| 5784649 | Begur et al. | Jul 1998 | A | 
| 5784712 | Byers et al. | Jul 1998 | A | 
| 5790813 | Whittaker | Aug 1998 | A | 
| 5796413 | Shipp et al. | Aug 1998 | A | 
| 5797043 | Lewis et al. | Aug 1998 | A | 
| 5809235 | Sharma et al. | Sep 1998 | A | 
| 5809530 | Samra et al. | Sep 1998 | A | 
| 5812799 | Zuravleff et al. | Sep 1998 | A | 
| 5812839 | Hoyt et al. | Sep 1998 | A | 
| 5812868 | Moyer et al. | Sep 1998 | A | 
| 5813031 | Chou et al. | Sep 1998 | A | 
| 5815714 | Shridhar et al. | Sep 1998 | A | 
| 5815799 | Barnes et al. | Sep 1998 | A | 
| 5819080 | Dutton et al. | Oct 1998 | A | 
| 5828746 | Ardon | Oct 1998 | A | 
| 5828863 | Barrett et al. | Oct 1998 | A | 
| 5829033 | Hagersten et al. | Oct 1998 | A | 
| 5832215 | Kato et al. | Nov 1998 | A | 
| 5832258 | Kiuchi et al. | Nov 1998 | A | 
| 5835755 | Stellwagen, Jr. | Nov 1998 | A | 
| 5835928 | Auslander et al. | Nov 1998 | A | 
| 5854922 | Gravenstein et al. | Dec 1998 | A | 
| 5860158 | Pai et al. | Jan 1999 | A | 
| 5886992 | Raatikainen et al. | Mar 1999 | A | 
| 5887134 | Ebrahim | Mar 1999 | A | 
| 5890208 | Kwon | Mar 1999 | A | 
| 5892979 | Shiraki et al. | Apr 1999 | A | 
| 5893162 | Lau et al. | Apr 1999 | A | 
| 5905876 | Pawlowski et al. | May 1999 | A | 
| 5905889 | Wilhelm, Jr. | May 1999 | A | 
| 5915123 | Mirsky et al. | Jun 1999 | A | 
| 5933627 | Parady | Aug 1999 | A | 
| 5937187 | Kosche et al. | Aug 1999 | A | 
| 5938736 | Muller et al. | Aug 1999 | A | 
| 5940612 | Brady et al. | Aug 1999 | A | 
| 5940866 | Chisholm et al. | Aug 1999 | A | 
| 5946487 | Dangelo | Aug 1999 | A | 
| 5948081 | Foster | Sep 1999 | A | 
| 5951679 | Anderson et al. | Sep 1999 | A | 
| 5958031 | Kim | Sep 1999 | A | 
| 5961628 | Nguyen et al. | Oct 1999 | A | 
| 5970013 | Fischer et al. | Oct 1999 | A | 
| 5978838 | Mohamed et al. | Nov 1999 | A | 
| 5978874 | Singhal et al. | Nov 1999 | A | 
| 5983274 | Hyder et al. | Nov 1999 | A | 
| 5996068 | Dwyer, III et al. | Nov 1999 | A | 
| 6002881 | York et al. | Dec 1999 | A | 
| 6009505 | Thayer et al. | Dec 1999 | A | 
| 6009515 | Steele, Jr. | Dec 1999 | A | 
| 6012151 | Mano | Jan 2000 | A | 
| 6014729 | Lannan et al. | Jan 2000 | A | 
| 6023742 | Ebeling et al. | Feb 2000 | A | 
| 6029170 | Garger et al. | Feb 2000 | A | 
| 6029228 | Cai et al. | Feb 2000 | A | 
| 6047334 | Langendorf et al. | Apr 2000 | A | 
| 6058168 | Braband | May 2000 | A | 
| 6058465 | Nguyen | May 2000 | A | 
| 6067585 | Hoang | May 2000 | A | 
| 6070231 | Ottinger | May 2000 | A | 
| 6072781 | Feeney et al. | Jun 2000 | A | 
| 6073215 | Snyder | Jun 2000 | A | 
| 6076129 | Fenwick et al. | Jun 2000 | A | 
| 6076158 | Sites et al. | Jun 2000 | A | 
| 6079008 | Clery, III | Jun 2000 | A | 
| 6079014 | Papworth et al. | Jun 2000 | A | 
| 6085215 | Ramakrishnan et al. | Jul 2000 | A | 
| 6085294 | Van Doren et al. | Jul 2000 | A | 
| 6088783 | Morton | Jul 2000 | A | 
| 6092127 | Tausheck | Jul 2000 | A | 
| 6092158 | Harriman et al. | Jul 2000 | A | 
| 6092175 | Levy et al. | Jul 2000 | A | 
| 6112016 | MacWilliams et al. | Aug 2000 | A | 
| 6115811 | Steele, Jr. | Sep 2000 | A | 
| 6134665 | Klein et al. | Oct 2000 | A | 
| 6141348 | Muntz | Oct 2000 | A | 
| 6141689 | Yasrebi | Oct 2000 | A | 
| 6141765 | Sherman | Oct 2000 | A | 
| 6144669 | Williams et al. | Nov 2000 | A | 
| 6145054 | Mehrotra et al. | Nov 2000 | A | 
| 6145123 | Torrey et al. | Nov 2000 | A | 
| 6157955 | Narad et al. | Dec 2000 | A | 
| 6160562 | Chin et al. | Dec 2000 | A | 
| 6173349 | Qureshi et al. | Jan 2001 | B1 | 
| 6182177 | Harriman | Jan 2001 | B1 | 
| 6195676 | Spix et al. | Feb 2001 | B1 | 
| 6199133 | Schnell | Mar 2001 | B1 | 
| 6201807 | Prasanna | Mar 2001 | B1 | 
| 6212542 | Kahle et al. | Apr 2001 | B1 | 
| 6212602 | Wicki et al. | Apr 2001 | B1 | 
| 6212604 | Tremblay | Apr 2001 | B1 | 
| 6212611 | Nizar et al. | Apr 2001 | B1 | 
| 6216220 | Hwang | Apr 2001 | B1 | 
| 6223207 | Lucovsky et al. | Apr 2001 | B1 | 
| 6223238 | Meyer et al. | Apr 2001 | B1 | 
| 6223277 | Karguth | Apr 2001 | B1 | 
| 6223279 | Nishimura et al. | Apr 2001 | B1 | 
| 6230119 | Mitchell | May 2001 | B1 | 
| 6230261 | Henry et al. | May 2001 | B1 | 
| 6233599 | Nation et al. | May 2001 | B1 | 
| 6247025 | Bacon | Jun 2001 | B1 | 
| 6247040 | Born et al. | Jun 2001 | B1 | 
| 6247086 | Allingham | Jun 2001 | B1 | 
| 6249829 | Bloks et al. | Jun 2001 | B1 | 
| 6256713 | Audityan et al. | Jul 2001 | B1 | 
| 6272616 | Fernando et al. | Aug 2001 | B1 | 
| 6275505 | O Loughlin, et al. | Aug 2001 | B1 | 
| 6278289 | Guccione et al. | Aug 2001 | B1 | 
| 6279113 | Vaidya | Aug 2001 | B1 | 
| 6289011 | Seo et al. | Sep 2001 | B1 | 
| 6298370 | Tang et al. | Oct 2001 | B1 | 
| 6307789 | Wolrich et al. | Oct 2001 | B1 | 
| 6311256 | Halligan et al. | Oct 2001 | B2 | 
| 6324624 | Wolrich et al. | Nov 2001 | B1 | 
| 6345334 | Nakagawa et al. | Feb 2002 | B1 | 
| 6347344 | Baker et al. | Feb 2002 | B1 | 
| 6351808 | Joy et al. | Feb 2002 | B1 | 
| 6356962 | Kasper et al. | Mar 2002 | B1 | 
| 6357016 | Rodgers et al. | Mar 2002 | B1 | 
| 6360262 | Guenthner et al. | Mar 2002 | B1 | 
| 6366978 | Middleton et al. | Apr 2002 | B1 | 
| 6373848 | Allison et al. | Apr 2002 | B1 | 
| 6378124 | Bates et al. | Apr 2002 | B1 | 
| 6381668 | Lunteren | Apr 2002 | B1 | 
| 6389449 | Nemirovsky et al. | May 2002 | B1 | 
| 6393483 | Latif et al. | May 2002 | B1 | 
| 6401149 | Dennin et al. | Jun 2002 | B1 | 
| 6408325 | Shaylor | Jun 2002 | B1 | 
| 6415338 | Habot | Jul 2002 | B1 | 
| 6426940 | Seo et al. | Jul 2002 | B1 | 
| 6427196 | Adiletta et al. | Jul 2002 | B1 | 
| 6430626 | Witkowski et al. | Aug 2002 | B1 | 
| 6430646 | Thusoo et al. | Aug 2002 | B1 | 
| 6434145 | Opsasnick et al. | Aug 2002 | B1 | 
| 6449289 | Quicksall | Sep 2002 | B1 | 
| 6457078 | Magro et al. | Sep 2002 | B1 | 
| 6463072 | Wolrich et al. | Oct 2002 | B1 | 
| 6480943 | Douglas et al. | Nov 2002 | B1 | 
| 6490642 | Thekkath et al. | Dec 2002 | B1 | 
| 6496925 | Rodgers et al. | Dec 2002 | B1 | 
| 6505229 | Turner et al. | Jan 2003 | B1 | 
| 6505281 | Sherry | Jan 2003 | B1 | 
| 6513089 | Hofmann et al. | Jan 2003 | B1 | 
| 6523108 | James et al. | Feb 2003 | B1 | 
| 6529999 | Keller et al. | Mar 2003 | B1 | 
| 6532509 | Wolrich et al. | Mar 2003 | B1 | 
| 6539439 | Nguyen et al. | Mar 2003 | B1 | 
| 6552826 | Adler et al. | Apr 2003 | B2 | 
| 6560667 | Wolrich et al. | May 2003 | B1 | 
| 6570877 | Kloth et al. | May 2003 | B1 | 
| 6577542 | Wolrich et al. | Jun 2003 | B2 | 
| 6577625 | Chiou et al. | Jun 2003 | B1 | 
| 6581124 | Anand | Jun 2003 | B1 | 
| 6584522 | Wolrich et al. | Jun 2003 | B1 | 
| 6587905 | Correale et al. | Jul 2003 | B1 | 
| 6587906 | Wolrich et al. | Jul 2003 | B2 | 
| 6606704 | Adiletta et al. | Aug 2003 | B1 | 
| 6625654 | Wolrich et al. | Sep 2003 | B1 | 
| 6628652 | Chrin et al. | Sep 2003 | B1 | 
| 6629237 | Wolrich et al. | Sep 2003 | B2 | 
| 6631430 | Wolrich et al. | Oct 2003 | B1 | 
| 6631462 | Wolrich et al. | Oct 2003 | B1 | 
| 6633938 | Rowlands et al. | Oct 2003 | B1 | 
| 6643726 | Patkar et al. | Nov 2003 | B1 | 
| 6654836 | Misra et al. | Nov 2003 | B1 | 
| 6661794 | Wolrich et al. | Dec 2003 | B1 | 
| 6661795 | Adas et al. | Dec 2003 | B1 | 
| 6667920 | Wolrich et al. | Dec 2003 | B2 | 
| 6668311 | Hooper et al. | Dec 2003 | B2 | 
| 6668317 | Bernstein et al. | Dec 2003 | B1 | 
| 6671761 | Kim | Dec 2003 | B2 | 
| 6671827 | Guilford et al. | Dec 2003 | B2 | 
| 6678248 | Haddock et al. | Jan 2004 | B1 | 
| 6681300 | Wolrich et al. | Jan 2004 | B2 | 
| 6684361 | Tong et al. | Jan 2004 | B2 | 
| 6694380 | Wolrich et al. | Feb 2004 | B1 | 
| 6697923 | Chen et al. | Feb 2004 | B2 | 
| 6724767 | Chong et al. | Apr 2004 | B1 | 
| 6725313 | Wingard et al. | Apr 2004 | B1 | 
| 6728845 | Adiletta et al. | Apr 2004 | B2 | 
| 6738831 | Wolrich et al. | May 2004 | B2 | 
| 6754662 | Li | Jun 2004 | B1 | 
| 6754795 | Chen et al. | Jun 2004 | B2 | 
| 6781992 | Rana et al. | Aug 2004 | B1 | 
| 6785843 | McRae et al. | Aug 2004 | B1 | 
| 6823399 | Horiguchi et al. | Nov 2004 | B2 | 
| 6826180 | Bergantino et al. | Nov 2004 | B1 | 
| 6847645 | Potter et al. | Jan 2005 | B1 | 
| 6868476 | Rosenbluth et al. | Mar 2005 | B2 | 
| 6889319 | Rodgers et al. | May 2005 | B1 | 
| 6941438 | Wolrich et al. | Sep 2005 | B2 | 
| 6958973 | Chen et al. | Oct 2005 | B1 | 
| 7028118 | Smith et al. | Apr 2006 | B2 | 
| 7051329 | Boggs et al. | May 2006 | B1 | 
| 7089379 | Sharma et al. | Aug 2006 | B1 | 
| 7216204 | Rosenbluth et al. | May 2007 | B2 | 
| 7225281 | Rosenbluth et al. | May 2007 | B2 | 
| 20010043614 | Viswanadham et al. | Nov 2001 | A1 | 
| 20020053017 | Adiletta et al. | May 2002 | A1 | 
| 20020056037 | Wolrich et al. | May 2002 | A1 | 
| 20030012198 | Kaganoi et al. | Jan 2003 | A1 | 
| 20030041216 | Rosenbluth et al. | Feb 2003 | A1 | 
| 20030041228 | Rosenbluth et al. | Feb 2003 | A1 | 
| 20030046488 | Rosenbluth et al. | Mar 2003 | A1 | 
| 20030065862 | Wyland | Apr 2003 | A1 | 
| 20030078950 | Abernathy et al. | Apr 2003 | A1 | 
| 20030105899 | Rosenbluth et al. | Jun 2003 | A1 | 
| 20030145155 | Wolrich et al. | Jul 2003 | A1 | 
| 20030145159 | Adiletta et al. | Jul 2003 | A1 | 
| 20030191866 | Wolrich et al. | Oct 2003 | A1 | 
| 20040034743 | Wolrich et al. | Feb 2004 | A1 | 
| 20040039895 | Wolrich et al. | Feb 2004 | A1 | 
| 20040054880 | Bernstein et al. | Mar 2004 | A1 | 
| 20040071152 | Wolrich et al. | Apr 2004 | A1 | 
| 20040073728 | Wolrich et al. | Apr 2004 | A1 | 
| 20040073778 | Adiletta et al. | Apr 2004 | A1 | 
| 20040098496 | Wolrich et al. | May 2004 | A1 | 
| 20040109369 | Wolrich et al. | Jun 2004 | A1 | 
| 20040139290 | Wolrich et al. | Jul 2004 | A1 | 
| 20040205747 | Bernstein et al. | Oct 2004 | A1 | 
| 20050132132 | Rosenbluth et al. | Jun 2005 | A1 | 
| 20050185437 | Wolrich et al. | Aug 2005 | A1 | 
| Number | Date | Country | 
|---|---|---|
| 0 379 709 | Aug 1990 | EP | 
| 0 464 715 | Jan 1992 | EP | 
| 0 633 678 | Jan 1995 | EP | 
| 0 745 933 | Dec 1996 | EP | 
| 0 809 180 | Nov 1997 | EP | 
| 0 953 897 | Nov 1999 | EP | 
| 1 191 445 | Mar 2002 | EP | 
| 59111533 | Jun 1984 | JP | 
| WO9415287 | Jul 1994 | WO | 
| WO9738372 | Oct 1997 | WO | 
| WO 0033195 | Jun 2000 | WO | 
| WO 0115718 | Mar 2001 | WO | 
| WO 0116697 | Mar 2001 | WO | 
| WO 0116698 | Mar 2001 | WO | 
| WO 0116702 | Mar 2001 | WO | 
| WO 0116703 | Mar 2001 | WO | 
| WO 0116713 | Mar 2001 | WO | 
| WO 0116714 | Mar 2001 | WO | 
| WO 0116715 | Mar 2001 | WO | 
| WO 0116716 | Mar 2001 | WO | 
| WO 0116718 | Mar 2001 | WO | 
| WO 0116722 | Mar 2001 | WO | 
| WO 0116758 | Mar 2001 | WO | 
| WO 0116769 | Mar 2001 | WO | 
| WO 0116770 | Mar 2001 | WO | 
| WO 0116782 | Mar 2001 | WO | 
| WO 0118646 | Mar 2001 | WO | 
| WO 0141530 | Jun 2001 | WO | 
| WO 0148596 | Jul 2001 | WO | 
| WO 0148599 | Jul 2001 | WO | 
| WO 0148606 | Jul 2001 | WO | 
| WO 0148619 | Jul 2001 | WO | 
| WO 0150247 | Jul 2001 | WO | 
| WO 0150679 | Jul 2001 | WO | 
| Number | Date | Country | |
|---|---|---|---|
| 20040034743 A1 | Feb 2004 | US |