The present invention relates to data processing in general, and, more particularly, to data structures and queues.
There are many applications in data processing systems and telecommunications for multichannel queues whose channels can be resized and whose overall size is compact, and the need exists for a multichannel queue that can be resized hitlessly (i.e., without losing any data, repeating data, or introducing garbage data).
The present invention provides for a queue:
To accomplish this, the illustrative embodiment comprises a group of doubly-linked lists, one for each channel's storage. One set of links indicates the node where the next datum is to be written and the other set of links indicates the node where the next datum is to be read. By bifurcating each channel's queue into a set of write links and read links, the illustrative embodiment can resize a channel during operation hitlessly.
Each node's storage in each data link comprises a plurality of words, which enables the linked lists to have fewer links in them than they would if each node's storage merely comprised one word. This adds to the compact nature of the illustrative embodiment.
There are two devices employed to enable the queue to be compact. First, each node's storage in each data link comprises a plurality of words, which enables the linked lists to have fewer links in them than they would if each node's storage merely comprised one word. And second, the illustrative embodiment shares its storage capacity among all its channels so that as one channel's storage requirements decrease, a portion of its storage capacity can be allocated to one or more other channels.
The illustrative embodiment comprises: a first memory comprising 2N individually-addressable words; a second memory comprising 2M individually-addressable M-bit words, wherein each of the M-bit words is (1) a pointer into the second memory and (2) at least a portion of a pointer into the first memory; and a third memory comprising 2M individually-addressable M-bit words, wherein each of the M-bit words is (1) a pointer into the third memory and (2) at least a portion of a pointer into the first memory; wherein M and N are positive integers and N≧M.
At any one instant, incoming data stream 102 comprises j time-division multiplexed channels, wherein j is a positive integer and 1≦j≦S/D. Each word in incoming data stream 102 is uniquely associated with exactly one of the j channels. The number of channels in incoming data stream 102 can change over time, and the illustrative embodiment is capable of handling these changes hitlessly. In accordance with the illustrative embodiment, j=128. It will be clear to those skilled in the art, after reading this disclosure, how to make and use alternative embodiments of the present invention for any value of j.
In accordance with the illustrative embodiment, the number of words arriving at queue 101 per second within each channel can be different for each channel, subject to the following constraint:
wherein sc is the number of words per second in channel c, wherein c ε {1, . . . , j}. Furthermore, the number of words arriving at queue 101 per second within each channel can also change over time. The illustrative embodiment is capable of handling the disparity in the number of words per channel and changes in the number of words per second per channel hitlessly.
The length of time that the words in channel c can be held in queue 101 is independent of sc but is subject to the following constraint:
wherein dc is the delay for channel c in queue 101.
In accordance with the illustrative embodiment, outgoing data stream 103 comprises j channels, and the words within each channel must be transmitted in outgoing data stream 103 in the same order that they are received from incoming data stream 102. In other words, the integrity of the sequence of words within each channel must be preserved, but the integrity of the sequence of words across channels need not be preserved. It will be clear to those skilled in the art, however, after reading this specification, how to make and use alternative embodiments of the present invention in which the integrity of the sequence of words within each channel and across channels is preserved.
Processor 201 is an appropriately-programmed general-purpose processor that is capable of performing the functionality described below and with respect to the accompanying figures. In particular, processor 201 is capable of:
Data memory 202 is a random-access read & write memory that comprises 2N individually-addressable W-bit words, wherein N is a positive integer. Data memory 202 is where processor 201 stores the words received from incoming data stream 102 while they are awaiting transmission on outgoing data stream 103. In accordance with the illustrative embodiment, N=14, but it will be clear to those skilled in the art, after reading this disclosure, how to make and use alternative embodiments of the present invention for any value of N.
Data memory 202 is logically partitioned into 2M blocks of 2P words, wherein M is a positive integer and N≧M, and wherein P is a non-negative integer equal to N−M. The purpose of partitioning data memory 202 into blocks is to reduce the size of write link memory 204 and read link memory 206, which would be larger if data memory 202 were not partitioned into blocks.
Write pointer memory 203 is a random-access read & write memory that comprises 2H individually-addressable N-bit words, wherein H is a positive integer and j≦2H. Location c, wherein c ε {0, . . . j−1}, stores a pointer that points to the location in data memory 202 where the next word for channel c is to be stored. In accordance with the illustrative embodiment, H=7, but it will be clear to those skilled in the art, after reading this disclosure, how to make and use alternative embodiments of the present invention for any value of H.
In accordance with the illustrative embodiment, each N-bit word in write pointer memory 203 is a composite of a M-bit word and a P-bit word as depicted in Table 1.
Write link memory 204 is a random-access read & write memory that comprises 2M individually-addressable M-bit words. Each word in write-link memory 204 is a pointer in a linked list that is uniquely associated with one channel. When the number of channels and the depth of a queue is stable, its linked list is a circular linked-list. When the number of channels or the depth of the queue is unstable—its linked list is temporarily not a circular linked list. In particular, location m, wherein m ε {0, . . . 2M−1}, stores a pointer in a linked list that (1) points to the next link in the list, and (2) the next block in data memory 201 for writing words associated with that channel.
Read pointer memory 205 is a random-access read & write memory that comprises 2H individually-addressable N-bit words. Location c stores a pointer that points to the location in data memory 202 where the next word for channel c is to be read from. In accordance with the illustrative embodiment, each N-bit word in read pointer memory 205 is a composite of a M-bit word and a P-bit word as depicted in Table 1.
Read link memory 206 is a random-access read & write memory that comprises 2M individually-addressable M-bit words. Each word in read-link memory 206 is a pointer in a linked list that is uniquely associated with one channel. When the number of channels and the depth of a queue is stable, its linked list is a circular linked-list. When the number of channels or the depth of the queue is unstable—its linked list is temporarily not a circular linked list. The topology of the linked lists in read link memory 206 always follow the topology of the linked lists in write link memory 204, which is partially what enables the illustrative embodiment to be resizable without losing data. In particular, location m, wherein m ε {0, . . . 2M−1}, stores a pointer in a linked list that (1) points to the next link in the list, and (2) the next block in data memory 201 for reading words associated with that channel.
At task 301, the illustrative embodiment learns that it must provide a queue for channel c, and processor 201 allocates one or more blocks in data memory 202 for that queue. In accordance with the illustrative embodiment, processor 201 is told how many blocks in data memory 202 to (at least initially) allocate to queue c. It will be clear to those skilled in the art, after reading this disclosure, how to make and use alternative embodiments of the present invention in which processor 201 automatically and dynamically allocates blocks in data memory 202 to the respective buffers based on, for example, the frequency and severity of overflow and underflow events. Task 301 is described in detail below and with respect to
At task 302, the illustrative embodiment uses queue c. In accordance with the illustrative embodiment, processor 201 uses queue c. Task 302 is described in detail below and with respect to
At task 303, the illustrative embodiment learns that it no longer needs to provide a queue for channel c, and processor 201 de-allocates the blocks associated with that queue in data memory 202 for use by other channels. Task 303 is described in detail below and with respect to
At task 401, processor 201 begins the process of creating queue c with Bc blocks of memory, wherein Bc is a positive integer, by allocating Bc blocks in data memory 202 that are not being used. Processor 201 accomplishes this by consulting a data structure of used blocks as illustrated in Table 2.
The blocks can be, but need not be, contiguous in data memory 202. In accordance with the illustrative embodiment, the data structure of used blocks is stored in processor 201's scratch pad memory, but it will be clear to those skilled in the art how to store it in other formats and in other places, such as an extra bit on write link memory 204. When processor 201 has located Bc unused blocks, it marks them as used in the data structure of used blocks.
At task 402, processor 201 constructs a circular linked list using the Bc blocks allocated in task 401 in write link memory 204. For example, suppose that blocks 0×007, 0×042, 0×134 were allocated for a new queue for channel c=0×2F in task 402. As part of task 402, processor 201 could construct the circular linked list in write link memory 204 by writing 0×042 in memory location 0×007, 0×134 in memory location 0×042, and 0×007 in memory location 0×134, as depicted in Table 3 and
In accordance with the illustrative embodiment, the linked list is not written into read link memory 206 at this time, but it will be clear to those skilled in the art, after reading this disclosure, that it can be written into read link memory 206 at this time or at another time before it is used.
At task 403, processor 201 primes location c in write pointer memory 203, as depicted in Table 4, and location c in read pointer memory 203, as depicted in Table 5, with an N-bit word that is a composite of the address of a link in the circular link list constructed in task 402 and a P-bit word equal to 0×0, as depicted in Table 1. The illustrative linked list is also depicted in
After the completion of task 403, queue c is ready for operation. The linked list in read link memory 206 will be constructed, link by link, as described in detail below, as processor 201 progressively fills the data blocks in data memory 202. For example, when processor 201 has completed filling data block 0×042, processor 201 will write 0×134 into read link 0×042, as depicted in
The doubly-links data structure, with separate read and write link structures depicted in
At task 501, processor 201 receives a W-bit word, called word_in, from incoming data stream 102, determines that it is within channel c, and stores it in queue c. Task 501 is described in detail below and with respect to
At task 502, processor 201 removes a word from queue c and transmits it in channel c in outgoing data stream 103. Task 502 is described in detail below and with respect to
At task 503, processor 201 increases the size (i.e., depth) of queue c by adding a data block in data memory 202 to the queue. When multiple data blocks are to be added to the queue, task 503 is performed once for each block. It will be clear to those skilled in the art, however, after reading this disclosure, how to make and use embodiments of the present invention in which the size of a queue is increased by any number of data blocks at a time.
Task 503 is performed when:
At task 504, processor decreases the size of queue c by deleting a data block in data memory 202 from the queue. When multiple data blocks are to be deleted from the queue, task 504 is performed once for each block. It will be clear to those skilled in the art, however, after reading this disclosure, how to make and use embodiments of the present invention in which the size of a queue is decreased by any number of data blocks at a time.
Task 504 is performed when:
At task 601, processor 201 marks the data blocks currently used in queue c as available for use in the data structure of used blocks as illustrated in Table 2. In accordance with the illustrative embodiment, nothing else needs to be done to de-allocate queue c. The values associated with queue c in data memory 202, write-pointer memory 203, write-link memory 204, read-pointer memory 205, and read-link memory 206 will be ignored by processor 201 until they are needed again and then they will be overwritten.
At task 701, processor 201 retrieves the pointer into data memory 202 for word_in. This is accomplished by setting an N-bit variable, write_pointer, equal to the contents of location c in write pointer memory 203.
At task 702, processor 201 writes the word to be buffered into data memory 202 at the location pointed to by the variable write_pointer.
At task 703, processor 201 tests if the variable write_pointer is at the boundary of a data block. This can be determined for example, by checking if the P least significant bits of the variable write_pointer are “1”. If it is, then control passes to task 705; otherwise control passes to task 704.
At task 704, processor 201 increments write_pointer by one so that write_pointer points to the next location in the current data block in data memory 202.
At task 705, processor 201 prepares to update the write pointer to be based on the next link in the linked list stored in write link memory 204. This is accomplished by setting the most significant N-P bits of write_pointer equal to the contents of write link memory 204 at the location pointed to by the most significant N-P bits of write_pointer, and by setting the least significant P bits of write_pointer equal to 0×0.
At task 706, processor 201 updates the linked list for queue c in read link memory 206 to ensure that it is consistent and synchronized with the linked list for queue c in write link memory 204. This is accomplished by setting the contents of read link memory 206 at the location pointed to by the most significant N-P bits of write_pointer equal to the most significant N-P bits of write_pointer.
At task 707, processor 201 writes the variable write_pointer back into write pointer memory 203 so that it can be used for the next word to be buffered for channel c. To accomplish this, processor 201 sets the contents of write pointer memory 203 at the location pointed to by c equal to the variable write_pointer.
At task 801, processor 201 retrieves the pointer into data memory 202 where word_out is stored. This is accomplished by setting an N-bit variable, read_pointer, equal to the contents of location c in read pointer memory 205.
At task 802, processor 201 reads word_out from data memory 202 using the variable read_pointer. This is accomplished by setting word_out to the contents of data memory 202 at the location pointed to by the variable read_pointer.
At task 803, processor 201 tests if the read_pointer is at the boundary of a data block. This can be determined for example, by checking if the P least significant bits of the variable read_pointer are “1”. If it is, then control passes to task 805; otherwise control passes to task 804.
At task 804, processor 201 increments read_pointer by one so that read_pointer points to the next location in the current data block in data memory 202.
At task 805, processor 201 prepares the new read pointer, which is based on the next link in the linked list stored in read link memory 206. This is accomplished by setting the most significant N-P bits of read_pointer equal to the contents of read link memory 206 at the location pointed to by the most significant N-P bits of read_pointer, and by setting the least significant P bits of read_pointer equal to 0×0.
At task 806, processor 201 writes the variable read_pointer back into read pointer memory 205 so that it can be used for the next word for be removed from queue c. To accomplish this, processor 201 sets the contents of read pointer memory 205 at the location pointed to by c equal to the variable read_pointer.
At task 901, processor 201 chooses the new data block in data memory 202 to insert into queue c by consulting the data structure of used blocks, as depicted in Table 2. Any currently unused data block will suffice, and the name of that data block is represented by the M-bit variable new_data_block. When the data block is chosen, it is marked as used in the data structure of used blocks. In accordance with the example, the new data block has address 0×354 (i.e., new_data_block=0×354).
At task 902, processor 201 chooses a data block in queue c to insert the new_data_block after. Any data block in queue c will suffice, and the name of that data block is represented by the M-bit variable modified_data_block. In accordance with the example, the data block to insert the new block after is 0×134 (i.e., modified_data_block=0×134) as shown in
At task 903, processor 201 sets the contents of the location pointed to by new_data_block in write link memory 204 to the contents of the location pointed to by modified_data_block in write link memory 204. This is the first task in inserting the new data block into queue c. In accordance with the example,
At task 904, processor 201 performs the second task in inserting the new data block into queue c. To accomplish task 904, processor 201 sets the contents of the location pointed to by modified_data_block in write link memory 204 equal to new_data_block. In accordance with the example,
Read link memory 206 is not modified within task 503 to reflect the addition of the new data block, but is updated in task 805 when it occurs. In other words, when data block 0×134 is next filled, processor 201 will copy the contents of location 0×134 in write link memory 204 (i.e., 0×354) into location 0×134 in read link memory 206. In accordance with the example,
At task 1001, processor 201 chooses a data block in queue c. Any data block will suffice, and the name of that data block is represented by the M-bit variable parent_data_block. In accordance with the example, parent_data_block equals 0×007.
At task 1002, processor 201 determines the name of the data block that follows parent_data_block in queue c by using parent_data_block as an index into write link memory 204. The name of the data block that follows parent_data_block in queue c is represented by the M-bit variable child_data_block. It is the data block pointed to by the variable child_data_block that will be removed from queue c. In accordance with the example, child_data_block equals 0×042.
At task 1003, processor 201 performs the first task in removing the child data block from queue c by setting the contents of parent_data_block in write link memory 204 equal to the contents of child_data_block in write link memory 204.
At task 1004, processor 201 waits until the data block in data memory 202 pointed to by child_data_block has been read (for the last time as part of queue c), and then marks child_data_block in the data structure of used data blocks as available for use. In the worst case, processor 201 must wait for Y+1 words to be read from queue c before re-using child_data_block, wherein Y is a positive integer that represents the length of queue c in words before task 306 is initiated.
It is to be understood that the above-described embodiments are merely illustrative of the present invention and that many variations of the above-described embodiments can be devised by those skilled in the art without departing from the scope of the invention. It is therefore intended that such variations be included within the scope of the following claims and their equivalents.