USRE40904E1 - Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer - Google Patents
Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer Download PDFInfo
- Publication number
- USRE40904E1 USRE40904E1 US10/412,827 US41282703A USRE40904E US RE40904 E1 USRE40904 E1 US RE40904E1 US 41282703 A US41282703 A US 41282703A US RE40904 E USRE40904 E US RE40904E
- Authority
- US
- United States
- Prior art keywords
- output
- register
- input
- address
- adder
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Expired - Lifetime
Links
- 239000000872 buffer Substances 0.000 title claims abstract description 114
- 230000004048 modification Effects 0.000 description 5
- 238000012986 modification Methods 0.000 description 5
- 230000008859 change Effects 0.000 description 4
- 239000003607 modifier Substances 0.000 description 3
- 230000004075 alteration Effects 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 230000006872 improvement Effects 0.000 description 2
- 238000013507 mapping Methods 0.000 description 2
- 238000000034 method Methods 0.000 description 2
- 241001504505 Troglodytes troglodytes Species 0.000 description 1
- 230000006978 adaptation Effects 0.000 description 1
- 238000004519 manufacturing process Methods 0.000 description 1
- 239000011159 matrix material Substances 0.000 description 1
- 230000008569 process Effects 0.000 description 1
- 230000004044 response Effects 0.000 description 1
- 238000001228 spectrum Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F5/00—Methods or arrangements for data conversion without changing the order or content of the data handled
- G06F5/06—Methods or arrangements for data conversion without changing the order or content of the data handled for changing the speed of data flow, i.e. speed regularising or timing, e.g. delay lines, FIFO buffers; over- or underrun control therefor
- G06F5/10—Methods or arrangements for data conversion without changing the order or content of the data handled for changing the speed of data flow, i.e. speed regularising or timing, e.g. delay lines, FIFO buffers; over- or underrun control therefor having a sequence of storage locations each being individually accessible for both enqueue and dequeue operations, e.g. using random access memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
- G06F9/30—Arrangements for executing machine instructions, e.g. instruction decode
- G06F9/34—Addressing or accessing the instruction operand or the result ; Formation of operand address; Addressing modes
- G06F9/355—Indexed addressing
- G06F9/3552—Indexed addressing using wraparound, e.g. modulo or circular addressing
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2205/00—Indexing scheme relating to group G06F5/00; Methods or arrangements for data conversion without changing the order or content of the data handled
- G06F2205/10—Indexing scheme relating to groups G06F5/10 - G06F5/14
- G06F2205/106—Details of pointers, i.e. structure of the address generators
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
- G06F7/60—Methods or arrangements for performing computations using a digital non-denominational number representation, i.e. number representation without radix; Computing devices using combinations of denominational and non-denominational quantity representations, e.g. using difunction pulse trains, STEELE computers, phase computers
- G06F7/72—Methods or arrangements for performing computations using a digital non-denominational number representation, i.e. number representation without radix; Computing devices using combinations of denominational and non-denominational quantity representations, e.g. using difunction pulse trains, STEELE computers, phase computers using residue arithmetic
Definitions
- the invention relates to the field of digital buffers and, more particularly, to the generation of addresses for accessing digital buffers. Even more particularly, the invention relates to the generation of addresses for accessing circular buffers.
- Digital information processors frequently employ digital memory buffers to temporarily store information en route to another device such as an input/output device or processor.
- a buffer may be constructed of dedicated hardware registers wired together or it may simply be a dedicated section of a larger memory.
- Such digital information buffers can take many forms.
- One such form is known as a circular buffer.
- the addresses for accessing locations in the buffers typically are generated by modifying the contents of a pointer register which is external to the buffer area which points to an address location within the buffer. When that address is needed on the address bus, it is output from the pointer address and the pointer is incremented (or decremented) by a predetermined amount so as to be ready for the next instruction cycle which accesses the circular buffer.
- means must be provided for “wrapping” the address around when the increment (or decrement) causes the address in the pointer register to fall without the bounds of the buffer.
- means must be provided for causing the address generator for the buffer to generate modulo addresses with the modulus being the length of the buffer.
- U.S. Pat. No. 4,800,524 The apparatus described in U.S. Pat. No. 4,800,524 comprises three registers external to the buffer, including (1) an L register which contains the length of the buffer, (2) an A register which contains the last address accessed in the buffer (this is the pointer register) and (3) an M buffer which contains an increment (or decrement) value to be added (or subtracted) from the A register.
- the apparatus also comprises two separate adder/subtractors, the first of which generates an absolute buffer address which is simply the contents of the A register added to the contents of the M register and a second adder/subtractor which generates a wrapped address by either adding (if M is positive) or subtracting (if M is negative) from the absolute address generated by the first adder the length of the buffer. Additional logic selects either the absolute address or the wrapped address responsive to the carry bits from the first and second adders. If the carry bits indicate that the absolute address generated is outside the boundaries of the buffer, the wrapped address is used and placed in the A register ready for the next access. Otherwise, the absolute address is selected and placed in the A register.
- It is another object of the present invention is to provide an address generator for a circular buffer which is substantially faster than software address generators.
- the address generator of the present invention comprises four registers.
- the registers are as follows:
- the Base or Length registers can be replaced by an End register, E, which contains the highest address in the buffer.
- the circuit buffer when the circuit buffer is accessed by an instruction, the contents of the Index register are placed on the address bus and then the Index register is modified so as to be ready for the next access.
- the modify value, M is positive, adder/subtracters calculate the value of I+M (the absolute address) as well as I+M ⁇ L, (the wrap address).
- the output of the adder/subtractor which calculates I+M ⁇ L is compared to the output of register B.
- the output of the adder/subtractor which calculates I+M and the output of the adder/subtracter which calculates I+M ⁇ L are also placed as first and second inputs to a multiplexer.
- the output of the multiplexer is coupled to the input of the I register so as to select one of those two values as the new index value. If I+M ⁇ L is greater than or equal to B, the comparator controls the multiplexer to select the I+M ⁇ L input as the value to be loaded into the index register. Otherwise, the comparator controls the multiplexer to select the I+M input.
- any of these embodiments can be further modified for a system in which the modifier M is a negative value or where M may be positive or negative.
- FIG. 1 shows an, exemplary circular buffer.
- FIG. 2 shows a first embodiment of the address generator of the present invention.
- FIG. 3 shows a second embodiment of the address generator of the present invention.
- FIG. 4 shows a third embodiment of the address generator of the present invention.
- FIG. 5 shows a fourth embodiment of the address generator of the present invention.
- FIG. 1 illustrates a typical circular buffer incorporated as part of a larger memory.
- the base address of the buffer is the lowest numbered address in the buffer. In the example in FIG. 1 this is address 20 , represented as B in FIG. 1 .
- the highest address in the buffer is designated as the end address which in FIG. 1 is address 39 and is indicated as E.
- a pointer into the buffer typically comprises a register containing the address of the next location in the buffer to be accessed. This register will hereinafter be termed the index register, I.
- the index pointer is incremented or decremented a predetermined number of addresses so as to be prepared for the next access into the circular buffer.
- the number of address spaces which the index pointer is incremented or decremented will hereinafter be referred to as the modify amount and is represented in FIG. 1 as M. It is common for the modify amount to be a fixed number which never changes. However, there are applications in which the modifier amount, M, may be varied.
- the index pointer in a circular buffer, means must be provided for wrapping the index pointer around when the increment amount would cause the index pointer to exceed the bounds of the buffer. For instance, in FIG. 1 , the index pointer is shown as pointing at address 35 . If the increment amount M, is 3, then the pointer will be updated to point to address number 38 . However, on the next increment of 3, the index pointer would normally point to address 41 which is beyond the bounds of the buffer. Accordingly, means must be provided for ensuring that when the increment of the index pointer causes it to exceed the end address of the buffer, it is wrapped around to the base of the buffer. For instance, on the next increment of the index pointer, the index pointer should point to address 21 rather than address 41 .
- FIG. 2 shows an address generator according to the present invention for generating addresses for a circular buffer such as the buffer shown in FIG. 1 .
- FIG. 2 shows an embodiment of the invention in which the increment, M, is always positive or always negative, as is typical. However, other embodiments in which the modifier can be positive or negative are possible and are described later herein.
- the address generator of the preferred embodiment of the present invention comprises four registers, termed L, M, I and B.
- the L register 12 is initialized by loading it with the length of the circular buffer.
- the M register 19 is loaded with a increment (or decrement) value.
- the B register 14 is loaded with the base address of the circular buffer, i.e., the lowest numbered address if M is positive, or the highest numbered address if M is negative.
- the I register which essentially comprises the pointer into the circular buffer, is automatically loaded with the base address when the base address is loaded into the B register.
- OR-gate 16 assures that when a B register write enable instruction (B WREN 78 ) is issued, the I register is also write enabled such that both the B and the I registers receive the base address being placed on the data bus 18 .
- the buffer pointer i.e., the I register
- the buffer pointer is incremented the same amount every time. Accordingly, a number can be permanently stored in the M register 19 .
- a multiplexer 20 is provided. Under the control of a processor (not shown), to avoid unnecessary obfuscation, multiplexer 20 can select as the increment either the data placed on the data bus by the processor or the output of the M register 19 .
- the contents of the I register 16 are placed onto the address bus 26 in response to a processor instruction such as the I WREN signal 28 in FIG. 2 .
- the logic in the address generator of the present invention will then modify the contents of the I register so that it will be ready for the next access into the circular buffer. Accordingly, an instruction cycle instructing the I register to output its contents onto the address bus initiates the sequence to be described herein for modifying the contents of the I register.
- the contents of the I register are output onto the data bus, they are also fed into one input of an adder 22 .
- the other input of the adder is coupled to the output of the multiplexer 20 which contains the selected increment, M 0
- the value I+M is output from the adder 22 and fed to one input of adder/subtractor 27 .
- adder/subtractor 27 accepts the output of the L register which contains the length of the buffer. In the case where M is always positive, the adder/subtractor is set up to subtract L from I+M. However, if M is negative, then the adder/subtractor is set up to add the value of L to I+M.
- the value of I+M ⁇ L is compared with the base address, B, of the circular buffer by comparator 30 , as shown in FIG. 2 .
- the output of comparator 30 is the control signal to multiplexer 32 .
- Multiplexer 32 receives at input A the value of I+M ⁇ L output from adder/subtractor 27 and at input B the value of I+M output from adder 22 .
- the comparator determines if I+M ⁇ L is greater than or equal to B. If so, the comparator 30 outputs a signal which instructs the multiplexer to place at its output the value at its A input, I+M ⁇ L. Otherwise, the comparator instructs the multiplexer 32 to place at its output, the value at its B input, I+M.
- the output of the multiplexer is fed back to the input of the I register and represents the new pointer address which will be stored in the I register.
- the purpose of the above-described operation of adder 22 , adder/subtractor 27 , comparator 30 and multiplexer 32 is explained as follows.
- the value of I+M output from adder 22 represents the new absolute value of the pointer (i.e., the old pointer value plus the increment M, regardless of whether it is within the bounds of the buffer). If the absolute value is within the range of the buffer, then no “wrapping around” is necessary and it can be placed directly into the I register. However, if it is beyond the range of the buffer, then the length of the buffer, L, must be subtracted from the absolute value in order to “wrap around” the address to modulo style. Adder/subtractor 27 calculates I+M ⁇ L whether it will be needed or not.
- comparator 30 determines if I+M ⁇ L is greater than or equal to the base address, B. If so, then I+M must have been beyond the range of the buffer and the comparator causes multiplexer 32 to place in the I register the value of I+M ⁇ L, rather than the value of I+M.
- the adder/subtractor 27 calculates the value of I+M (M being negative)+L instead of I+M ⁇ L, and the B register contains the highest numbered, rather than lowest numbered, address in the buffer. Accordingly, the comparator operation also must be modified so that, if the value as its A input, I+M+L, is less than or equal to the value at its B input, the highest address in the buffer, B, then it instructs the multiplexer 30 to select I+M+L. Otherwise it selects its other input, I+M.
- adder/subtractor 27 and the comparator 30 perform slightly different operations. However, from a manufacturing standpoint, it is desirable to produce a single address generator which can be used in applications where M is positive or negative, rather than producing a separate device for each situation. Accordingly, in the preferred embodiment, adder/subtractor 27 and comparator 30 are designed to perform the separate above-described functions responsive to the sign bit of the contents of the M register. Accordingly, not only is the address generator capable of handling both of these situations (where M is positive or where M is negative), but, with a small amount of additional circuitry, it will also function properly where the sign of M can change during operation as discussed below.
- the description of the invention above has been limited to situations where M is either known to be positive or negative, there are applications where the offset, M, can change from positive to negative during operation.
- M can change from positive to negative during operation.
- the direction of movement in the circular buffer can change.
- the present invention can be adapted to handle such situations.
- One possible adaptation would be to provide a further adder which adds the contents of the B register and the L register to derive the highest numbered address in the buffer and a further multiplexer responsive to the sign bits of M for selecting either the output of the B register (defined herein as the lowest address in the buffer) or the output of the additional adders as an input to the comparator 30 .
- the adder/subtracter is also responsive to the sign bit of the register for subtracting L from I+M, when the sign bit of M is positive or adding L to the I+M value, when the sign bit is negative.
- the comparator also is responsive to the sign bit. In the case where M is positive, if the comparator determines that its A input, I+M ⁇ L, is greater than or equal to its B input, the base address, B, then it instructs the multiplexer 32 to select its A input, I+M ⁇ L.
- the comparator output must be modified such that when the A input of the comparator, I+M+L, is less than or equal to the B input of the comparator, B+L, then the multiplexer must be instructed to select its A input, I+M, and its B input, I+M+L otherwise.
- the speed of the calculation of the address can be further increased with a slight modification to the circuitry shown in FIG. 2 .
- valid data does not appear at the output of adder/subtractor 27 until it receives the value of I+M from adder 22 .
- the comparator 30 must wait through the propagation delay of adder 22 plus the propagation delay of adder/subtractor 27 .
- the circuitry in FIG. 2 can be modified as shown in FIG. 3 , to avoid the need for the comparator to wait through this double propagation delay by providing another register and a different adder/subtracter 29 which has at its inputs the outputs of the B and L registers and calculates B ⁇ L.
- comparator 30 can compare I+M with B ⁇ L rather than comparing I+M ⁇ L with B.
- the former comparison is essentially the same as the latter, the value L simply being moved to the other side of the equation.
- the propagation delay through to the apparatus is reduced because the calculation of B ⁇ L occurs simultaneously with the calculation of I+M rather than sequentially afterwards.
- one could easily avoid the need for a second adder/subtracter by utilizing only one adder/subtracter and storing in a register the results of one of the addition/subtraction operations.
- FIGS. 4 and 5 Additional alternate embodiments of the invention are shown in FIGS. 4 and 5 .
- FIGS. 2 and 3 illustrate embodiments utilizing registers containing the base address and length information noted in the first alternative.
- FIGS. 4 and 5 illustrate alternate embodiments of the invention which utilize registers containing the information noted in the second and third alternatives.
- the L register is replaced by an E register 40 containing the end address of the buffer.
- Much of the logic of this embodiment is similar to the embodiment of FIG. 2 ; therefore, similar numbers are used for similar components.
- Adder/subtractor 28 and comparator 30 are replaced by adder/subtractor 42 and comparator respectively.
- adder/subtractor 42 requires inputs from the E register, B register and adder 22 .
- Adder/subtractor 42 calculates I+M ⁇ E+B, regardless of the sign of M (assuming that the B register is initialized with the lowest address in the buffer when M is positive, and with the highest address when M is negative).
- comparator 44 compares I+M ⁇ B+E to B. If I+M ⁇ E+B is less than or equal to B, then comparator 44 controls multiplexer 32 to select its A input, having the value I+M ⁇ E+B. Otherwise, multiplexer 32 is controlled by comparator 44 to select its B input, having the value I+M.
- the adder/subtractor 42 still calculates I+M ⁇ E+B and the comparator still compares I+M ⁇ E+B with the contents of the B register, but now must determine if I+M ⁇ E+B is less than or equal to B. If so, comparator 44 instructs multiplexer 32 to select its A input, the value I+M ⁇ E+B. Otherwise, multiplexer 32 is controlled by comparator 44 to select its B input, the value I+M. Minor modifications are necessary if M may be either positive or negative during operation.
- FIG. 5 shows another embodiment utilizing an L register 12 , E register 45 , I register 16 and M register 19 .
- the FIG. 5 embodiment is substantially similar to the embodiments shown in FIG. 2 , except that comparator 30 is replaced by comparator 50 .
- Adder/subtractor 28 remains the same as in FIG. 2 and calculates I+M ⁇ L, if M is positive, or I+M+L, if M is negative, just as in the FIG. 2 embodiment.
- Comparator 50 compares the value of I+M output from adder 22 , with the contents of the E register. When M is positive, If I+M is less than or equal to E (which is the highest address, when M is positive), the comparator controls multiplexer 32 to select its B input, I+M.
- the multiplexer selects its A input, I+M ⁇ L.
- the comparator 50 determines if I+M is greater than or equal to the end address E (which is the lowest numbered address, when M is negative) and, if so, controls multiplexer 32 to select its B input, I+M. Otherwise, it selects its A input, I+M+L.
- the base address is derived from the contents loaded into the L and E registers and automatically loaded into the I register.
- Subtracter 70 receives at its inputs the output of the L register 12 and the E register 45 , subtracts L from E, and outputs that value to the input of the I register during the initial register loading process only. Since, in the embodiment shown in FIGS. 4 and 5 , the I register is enabled by the E WREN signal 78 , the L register must be loaded before the E register in order for the subtracter to place the correct value in the I register. Alternate embodiments are possible. For example, as with FIG. 3 it is possible to use adder/subtractor 28 to replace the additional subtracter 70 , by switching adder/subtractor 28 to calculate and load the I register with the base value at the time of register initialization.
- FIG. 4 can also be modified for situations in which M may alternate between a positive and negative value.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Software Systems (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Complex Calculations (AREA)
- Supply And Installment Of Electrical Components (AREA)
Abstract
The invention comprises a hardware constructed address generator for a circular buffer which can be of any size and be in any position in memory. The address generator calculates both an absolute value and a wrapped value and selects one in accordance with whether the wrapped value falls within the boundaries of the buffer.
Description
This application is a continuation of application Ser. No. 07/368,365, filed Nov. 2, 1990, now abandoned.
The invention relates to the field of digital buffers and, more particularly, to the generation of addresses for accessing digital buffers. Even more particularly, the invention relates to the generation of addresses for accessing circular buffers.
Digital information processors frequently employ digital memory buffers to temporarily store information en route to another device such as an input/output device or processor. A buffer may be constructed of dedicated hardware registers wired together or it may simply be a dedicated section of a larger memory. Such digital information buffers can take many forms. One such form is known as a circular buffer. In circular buffers, the addresses for accessing locations in the buffers typically are generated by modifying the contents of a pointer register which is external to the buffer area which points to an address location within the buffer. When that address is needed on the address bus, it is output from the pointer address and the pointer is incremented (or decremented) by a predetermined amount so as to be ready for the next instruction cycle which accesses the circular buffer. In circular buffers, means must be provided for “wrapping” the address around when the increment (or decrement) causes the address in the pointer register to fall without the bounds of the buffer. In other words, means must be provided for causing the address generator for the buffer to generate modulo addresses with the modulus being the length of the buffer.
In circular buffers, software techniques are generally used for the modulo address generation. These software address mapping techniques, however, require several instruction cycles to perform the necessary address comparisons, arithmetic operations and replacement of the pointer register contents. Such software address mapping is not fast enough for certain types of uses. Applications such as digital filters, Fast Fourier transforms, matrix manipulations and other common digital signal processing routines require a very rapid generation of memory references. Accordingly, software modulo address generation can significantly decrease the speed of fast signal processing apparatus. Accordingly, addressing schemes implemented in hardware are sometimes desirable.
One such hardware implemented system is disclosed in U.S. Pat. No. 4,800,524. The apparatus described in U.S. Pat. No. 4,800,524 comprises three registers external to the buffer, including (1) an L register which contains the length of the buffer, (2) an A register which contains the last address accessed in the buffer (this is the pointer register) and (3) an M buffer which contains an increment (or decrement) value to be added (or subtracted) from the A register. The apparatus also comprises two separate adder/subtractors, the first of which generates an absolute buffer address which is simply the contents of the A register added to the contents of the M register and a second adder/subtractor which generates a wrapped address by either adding (if M is positive) or subtracting (if M is negative) from the absolute address generated by the first adder the length of the buffer. Additional logic selects either the absolute address or the wrapped address responsive to the carry bits from the first and second adders. If the carry bits indicate that the absolute address generated is outside the boundaries of the buffer, the wrapped address is used and placed in the A register ready for the next access. Otherwise, the absolute address is selected and placed in the A register. The invention disclosed in the U.S. Pat. No. 4,800,524 patent is limited, however, in that in order for the system of examining the carry bits to work, the lower K bits of the buffer's base address (lowest address) must be zero, where K is the number of bits required to represent the length of the buffer and the length of the buffer must be a power of two. These limitations can be extremely inconvenient in certain applications.
It is one object of the present invention to provide an improved address generator for a circular buffer.
It is a further object of the present invention to provide an address generator for a circular buffer which places no restrictions on the size or the position in memory of the circular buffer.
It is another object of the present invention is to provide an address generator for a circular buffer which is substantially faster than software address generators.
The address generator of the present invention comprises four registers. In one preferred embodiment, the registers are as follows:
- 1) Base register, B, containing the lowest numbered address in the buffer,
- 2) an Index pointer register, I, containing the next address to be accessed in the buffer,
- 3) a Modify register, M, which is loaded with the increment (or decrement) value, and
- 4) a Length register, L, containing the length of the buffer.
In alternate embodiments, the Base or Length registers, but not both, can be replaced by an End register, E, which contains the highest address in the buffer.
In the preferred embodiment, when the circuit buffer is accessed by an instruction, the contents of the Index register are placed on the address bus and then the Index register is modified so as to be ready for the next access. When the modify value, M, is positive, adder/subtracters calculate the value of I+M (the absolute address) as well as I+M−L, (the wrap address). The output of the adder/subtractor which calculates I+M−L is compared to the output of register B. The output of the adder/subtractor which calculates I+M and the output of the adder/subtracter which calculates I+M−L are also placed as first and second inputs to a multiplexer. The output of the multiplexer is coupled to the input of the I register so as to select one of those two values as the new index value. If I+M−L is greater than or equal to B, the comparator controls the multiplexer to select the I+M−L input as the value to be loaded into the index register. Otherwise, the comparator controls the multiplexer to select the I+M input.
Alternate embodiments are possible where either the Length register or the Base register is replaced by an End register which contains the end value (i.e., the highest numbered address) of the buffer. Slight modification to the adder/subtracter circuitry would be necessary. In addition, any of these embodiments can be further modified for a system in which the modifier M is a negative value or where M may be positive or negative.
As stated above, in a circular buffer, means must be provided for wrapping the index pointer around when the increment amount would cause the index pointer to exceed the bounds of the buffer. For instance, in FIG. 1 , the index pointer is shown as pointing at address 35. If the increment amount M, is 3, then the pointer will be updated to point to address number 38. However, on the next increment of 3, the index pointer would normally point to address 41 which is beyond the bounds of the buffer. Accordingly, means must be provided for ensuring that when the increment of the index pointer causes it to exceed the end address of the buffer, it is wrapped around to the base of the buffer. For instance, on the next increment of the index pointer, the index pointer should point to address 21 rather than address 41.
In most circular buffer applications, the buffer pointer, i.e., the I register, is incremented the same amount every time. Accordingly, a number can be permanently stored in the M register 19. In situations where the increment, M, may vary, a multiplexer 20 is provided. Under the control of a processor (not shown), to avoid unnecessary obfuscation, multiplexer 20 can select as the increment either the data placed on the data bus by the processor or the output of the M register 19.
The contents of the I register 16 are placed onto the address bus 26 in response to a processor instruction such as the IWREN signal 28 in FIG. 2. The logic in the address generator of the present invention will then modify the contents of the I register so that it will be ready for the next access into the circular buffer. Accordingly, an instruction cycle instructing the I register to output its contents onto the address bus initiates the sequence to be described herein for modifying the contents of the I register.
As the contents of the I register are output onto the data bus, they are also fed into one input of an adder 22. The other input of the adder is coupled to the output of the multiplexer 20 which contains the selected increment, M0 The value I+M is output from the adder 22 and fed to one input of adder/subtractor 27. At its other input, adder/subtractor 27 accepts the output of the L register which contains the length of the buffer. In the case where M is always positive, the adder/subtractor is set up to subtract L from I+M. However, if M is negative, then the adder/subtractor is set up to add the value of L to I+M.
If M is positive, then the value of I+M−L is compared with the base address, B, of the circular buffer by comparator 30, as shown in FIG. 2. The output of comparator 30 is the control signal to multiplexer 32. Multiplexer 32 receives at input A the value of I+M−L output from adder/subtractor 27 and at input B the value of I+M output from adder 22. The comparator determines if I+M−L is greater than or equal to B. If so, the comparator 30 outputs a signal which instructs the multiplexer to place at its output the value at its A input, I+M−L. Otherwise, the comparator instructs the multiplexer 32 to place at its output, the value at its B input, I+M. The output of the multiplexer is fed back to the input of the I register and represents the new pointer address which will be stored in the I register.
The purpose of the above-described operation of adder 22, adder/subtractor 27, comparator 30 and multiplexer 32 is explained as follows. The value of I+M output from adder 22 represents the new absolute value of the pointer (i.e., the old pointer value plus the increment M, regardless of whether it is within the bounds of the buffer). If the absolute value is within the range of the buffer, then no “wrapping around” is necessary and it can be placed directly into the I register. However, if it is beyond the range of the buffer, then the length of the buffer, L, must be subtracted from the absolute value in order to “wrap around” the address to modulo style. Adder/subtractor 27 calculates I+M−L whether it will be needed or not. Obviously, if I+M is within the buffer range, then subtracting the length, L, of the buffer from the absolute address will cause the address to be less than the base address of the buffer, thus indicating that “wrapping” is unnecessary. However, if I+M is beyond the bounds of the buffer, then I+M−L will be greater than or equal to the base address, B, of the buffer. Accordingly, comparator 30 determines if I+M−L is greater than or equal to the base address, B. If so, then I+M must have been beyond the range of the buffer and the comparator causes multiplexer 32 to place in the I register the value of I+M−L, rather than the value of I+M.
If M is negative, the operation is slightly modified. In this situation, the adder/subtractor 27 calculates the value of I+M (M being negative)+L instead of I+M−L, and the B register contains the highest numbered, rather than lowest numbered, address in the buffer. Accordingly, the comparator operation also must be modified so that, if the value as its A input, I+M+L, is less than or equal to the value at its B input, the highest address in the buffer, B, then it instructs the multiplexer 30 to select I+M+L. Otherwise it selects its other input, I+M.
As described above, depending on the sign of M, the adder/subtractor 27 and the comparator 30 perform slightly different operations. However, from a manufacturing standpoint, it is desirable to produce a single address generator which can be used in applications where M is positive or negative, rather than producing a separate device for each situation. Accordingly, in the preferred embodiment, adder/subtractor 27 and comparator 30 are designed to perform the separate above-described functions responsive to the sign bit of the contents of the M register. Accordingly, not only is the address generator capable of handling both of these situations (where M is positive or where M is negative), but, with a small amount of additional circuitry, it will also function properly where the sign of M can change during operation as discussed below.
Although the description of the invention above has been limited to situations where M is either known to be positive or negative, there are applications where the offset, M, can change from positive to negative during operation. For example, in the fast generation of phase values in high speed spread spectrum systems, the direction of movement in the circular buffer can change. Similarly, in phase locked loop situations, the direction of the offset can change. The present invention can be adapted to handle such situations. One possible adaptation would be to provide a further adder which adds the contents of the B register and the L register to derive the highest numbered address in the buffer and a further multiplexer responsive to the sign bits of M for selecting either the output of the B register (defined herein as the lowest address in the buffer) or the output of the additional adders as an input to the comparator 30. The adder/subtracter is also responsive to the sign bit of the register for subtracting L from I+M, when the sign bit of M is positive or adding L to the I+M value, when the sign bit is negative. The comparator also is responsive to the sign bit. In the case where M is positive, if the comparator determines that its A input, I+M−L, is greater than or equal to its B input, the base address, B, then it instructs the multiplexer 32 to select its A input, I+M−L. However, if M is negative, the comparator output must be modified such that when the A input of the comparator, I+M+L, is less than or equal to the B input of the comparator, B+L, then the multiplexer must be instructed to select its A input, I+M, and its B input, I+M+L otherwise.
The speed of the calculation of the address can be further increased with a slight modification to the circuitry shown in FIG. 2. As shown in FIG. 2 , valid data does not appear at the output of adder/subtractor 27 until it receives the value of I+M from adder 22. In other words, to obtain I+M±L for comparison with B, the comparator 30 must wait through the propagation delay of adder 22 plus the propagation delay of adder/subtractor 27. The circuitry in FIG. 2 can be modified as shown in FIG. 3 , to avoid the need for the comparator to wait through this double propagation delay by providing another register and a different adder/subtracter 29 which has at its inputs the outputs of the B and L registers and calculates B±L. Then comparator 30 can compare I+M with B±L rather than comparing I+M±L with B. The former comparison is essentially the same as the latter, the value L simply being moved to the other side of the equation. In this embodiment the propagation delay through to the apparatus is reduced because the calculation of B±L occurs simultaneously with the calculation of I+M rather than sequentially afterwards. Of course, one could easily avoid the need for a second adder/subtracter by utilizing only one adder/subtracter and storing in a register the results of one of the addition/subtraction operations.
Additional alternate embodiments of the invention are shown in FIGS. 4 and 5 . In order to define the circular buffer, one must know 1) its base address and its length (as is provided in the FIG. 2 embodiment described above, 2) its end address and its length, or 3) its base address and end address. FIGS. 2 and 3 illustrate embodiments utilizing registers containing the base address and length information noted in the first alternative. FIGS. 4 and 5 illustrate alternate embodiments of the invention which utilize registers containing the information noted in the second and third alternatives.
In the FIG. 4 embodiment, the L register is replaced by an E register 40 containing the end address of the buffer. Much of the logic of this embodiment is similar to the embodiment of FIG. 2 ; therefore, similar numbers are used for similar components. Adder/subtractor 28 and comparator 30 are replaced by adder/subtractor 42 and comparator respectively. In this embodiment, adder/subtractor 42 requires inputs from the E register, B register and adder 22. Adder/subtractor 42 calculates I+M−E+B, regardless of the sign of M (assuming that the B register is initialized with the lowest address in the buffer when M is positive, and with the highest address when M is negative).
When M is positive, comparator 44 compares I+M−B+E to B. If I+M−E+B is less than or equal to B, then comparator 44 controls multiplexer 32 to select its A input, having the value I+M−E+B. Otherwise, multiplexer 32 is controlled by comparator 44 to select its B input, having the value I+M. When M is negative, the adder/subtractor 42 still calculates I+M−E+B and the comparator still compares I+M−E+B with the contents of the B register, but now must determine if I+M−E+B is less than or equal to B. If so, comparator 44 instructs multiplexer 32 to select its A input, the value I+M−E+B. Otherwise, multiplexer 32 is controlled by comparator 44 to select its B input, the value I+M. Minor modifications are necessary if M may be either positive or negative during operation.
In the embodiment of FIG. 5 , additional circuitry is necessary to automatically load the I register with the base address at initialization, compared with the previously discussed embodiments since, in this embodiment, there is no base register. Accordingly, the base address is derived from the contents loaded into the L and E registers and automatically loaded into the I register. Subtracter 70 receives at its inputs the output of the L register 12 and the E register 45, subtracts L from E, and outputs that value to the input of the I register during the initial register loading process only. Since, in the embodiment shown in FIGS. 4 and 5 , the I register is enabled by the EWREN signal 78, the L register must be loaded before the E register in order for the subtracter to place the correct value in the I register. Alternate embodiments are possible. For example, as with FIG. 3 it is possible to use adder/subtractor 28 to replace the additional subtracter 70, by switching adder/subtractor 28 to calculate and load the I register with the base value at the time of register initialization.
The embodiment of FIG. 4 can also be modified for situations in which M may alternate between a positive and negative value.
Having thus described a few particular embodiments of the invention, various alterations, modifications and improvements will readily occur to those skilled in the art. Such alterations, modifications and improvements as are made obvious by this disclosure are intended to be part of this description though not expressly stated herein, and are intended to be within the spirit and scope of the invention. Accordingly, the foregoing description is by way of example only, and not limiting. The invention is limited only as defined in the following claims and equivalents thereto.
Claims (18)
1. An apparatus for generating target addresses within a circular buffer extending in a memory between bounds defined by a base address and an end address, the base address being any predetermined location in the memory, responsive to the next previous address, I, accessed within said circular buffer, I, and a specified offset, M, comprising:
a first register for storing the previous address accessed within said buffer, I;
a second register means for storing information which defines the position and size of said circular buffer in memory, said second register means comprising an L register for storing the length of the circular buffer, L, and a B register for storing the base address of the circular buffer, B;
a third register for storing a specific offset value, M
a first logic circuit for generating an absolute address by calculating the value of I+M, wherein M is positive and said first logic circuit comprises an adder having a first input connected to accept the output of said first register, a second input connected to accept the output of said third register and an output which provides the sum of the values applied to first and second inputs;
a second logic circuit for generating a wrapped address by modifying the value I+M by the length of the buffer, said second logic circuit comprising a subtracter having a first input coupled to the output of said L register, a second input coupled to the output of said adder and an output which is the difference between the inputs, I+M−L;
a comparator for comparing one of the absolute address and wrapped address with a boundary of said circular buffer to determine whether one of said absolute address and said wrapped address is between the bounds of the circular buffer, said comparator having a first input coupled to the output of said subtracter, I+M−L, a second input coupled to the output of said B register, B, and an output which in a first state when said first input is greater than or equal to said second input and in a second state otherwise; and
means for loading said first register with the one of the absolute address and the wrapped address which is within the bounds of the circular buffer, said means for loading comprising a multiplexer having a first input coupled to the output of said adder, I+M, a second input coupled to the output of said subtractor, I+M−L, and a third input coupled to the output of said comparator and having an output coupled to the input of said I register, said output being the value at said first input responsive to said comparator output being in said second state and being the value at said second input responsive to said comparator output being in said first state.
2. The apparatus as set forth in claim 1 18 further comprising a third register for storing a standard offset value.
3. The apparatus as set forth in claim 2 18 further comprising an M register for storing M and wherein said first logic means circuit comprises an adder having a first input connected to accept the output of said I first register, a second input connected to accept the output of said M register and an output which provides the sum of the values applied to first and second inputs.
4. The apparatus as set forth in claim 3 wherein M is positive and said second register means comprises an L register for storing the length of the circular buffer, L, and a B register for storing the base of the circular buffer, B.
5. The apparatus as set forth in claim 4 wherein,
said second logic circuit comprises a subtracter having a first input coupled to the output of said L register, a second input coupled to the output of said adder and an output which is the difference between the inputs, I+M−L,
said comparator has a first input coupled to the output of said subtracter, I+M−L, a second input coupled to the output of said B register, B, and an output which is in a first state when said first input is greater than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having has a first input coupled to the output of said adder, I+M, a second input coupled to the output of said subtractor, I+M−L, and a third input coupled to the output of said comparator and having an output coupled to the input of said I register, said output of said multiplexer being the value at said first input responsive to said comparator output being in said second state and being the value of at said second input responsive to said comparator output being in said first state.
6. The apparatus as set forth in claim 3 wherein M is negative and said second register means comprises an L register for storing the length of the circular buffer, L, and a B register for storing the lowest address in the circular buffer, B.
7. The apparatus as set forth in claim 6 wherein;
said second logic means circuit comprises a second adder having a first input coupled to the output of said L register, a second input coupled to the output of said adder and an output which is the sum of its inputs, I+M+L,
said comparator means has a first input coupled to the output of said second adder, I+M+L, a second input coupled to the output of said B register, B, and an output which is in a first state when said first input is less than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having has a first input coupled to the output of said first adder, I+M, a second input coupled to the output of said second adder, I+M+L, and a third input coupled to the output of said comparator, and having an output coupled to the input of said I register, said output of said multiplexer being the value at said first input responsive to said comparator output being in said second state and being output being the value at said second input responsive to said comparator output being in said first state.
8. The apparatus as set forth in claim 3 wherein M is positive and said second register comprise an E register for storing the highest address in the circular buffer and an L register for storing the length of the circular buffer.
9. The apparatus as set forth in claim 8 wherein,
said second logic means comprises subtracter means having a first input coupled to the output of said L register, a second input coupled to the output of said adder and an output which is the difference between the inputs, I+M−L,
said comparator has a first input for coupled to the output of said adder means, I+M, a second input coupled to the output of said E register, E, and an output which is in a first state when said first input is less than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having a first input coupled to the output of said subtracter, I+M−L, a second input coupled to the output of said adder, I+M, and a third input coupled to the output of said comparator, and having an output coupled to the input of said I register, said output being the value at said first input responsive to said comparator output being in said second state and said output being the value at said second input responsive to said comparator output being in said first state.
10. The apparatus as set forth in claim 3 wherein M is negative and said second register comprise an E register for storing the highest address in the circular buffer and an L register for storing the length of the circular buffer.
11. The apparatus as set forth in claim 10 wherein,
said second logic circuit comprises a second adder having a first input coupled to the output of said register, a second input coupled to the output of said adder and an output which is the sum of the inputs, I+M+L,
said comparator has a first input coupled to the output of said first adder, I+M, a second input coupled to the output of said E register, and an output which is in a first state when said first input is greater than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having a first input coupled to the output of said first adder, I+M, a second input coupled to the output of said second adder, I+M+L, and a third input coupled to the output of said comparator, and having an output coupled to the input of said I register, said output being the value at said second input responsive to said comparator output being in said second state and said output being the value at said first input responsive to said comparator output being in said first state.
12. The apparatus as set forth in claim 3 wherein M is positive and said second register means comprise an E register for storing the highest address in the circular buffer and a B register for storing the lowest address in the circular buffer.
13. The apparatus as set forth in claim 12 wherein,
said second logic means circuit comprises an adder/subtracter means having a first input coupled to the output of said E register, E, a second input coupled to the output of said B register, B, a third input coupled to the output of said adder, I+M, and an output which is the value I+M−E+B,
said comparator has a first input coupled to the output of said adder/subtracter means , I+M−E+B, a second input coupled to the output of said B register, B, and an output which is in a first state when said first input is greater than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having has a first input coupled to the output of said adder, I+M, a second input coupled to the output of said adder/subtracter, I+M−E+B, and a third input coupled to the output of said comparator and having an output coupled to the input of said I register, said output of said multiplexer being the value at said first input responsive to said comparator output being in said second state and said output being the value of at said second input responsive to said comparator output being in said first state.
14. The apparatus as set forth in claim 3 wherein M is negative and said second register comprises an E register for storing the lowest address in the circular buffer and a B register for storing the highest address in the circular buffer.
15. The apparatus as set forth in claim 14 wherein,
said second logic means circuit comprises an adder/subtracter means having a first input coupled to the output of said E register, E, a second input coupled to the output of said B register, B, a third input coupled to the output of said adder, I+M, and an output which is the value I+M−E+B,
said comparator has a first input coupled to the output of said adder/subtracter means , I+M−E+B, a second input coupled to the output of said B register, B, and an output which is in a first state when said first input is less than or equal to said second input and in a second state otherwise, and
said means for loading comprises a multiplexer having has a first input coupled to the output of said adder, I+M, a second input coupled to the output of said adder/subtractor, I+M−E+B, and a third input coupled to the output of said comparator and having an output coupled to the input of said I register, said output of said multiplexer being the value at said first input responsive to said comparator output being in said second state and said output being the value of at said second input responsive to said comparator output being in said first state.
16. The apparatus as set forth in claim 3 4 further comprising;
means for initializing the contents of the M, B and L registers, and means for automatically loading the I first register with the contents of the B register.
17. The apparatus as set forth in claim 3 further comprising,
means for initializing the second register means , and means for automatically loading the I register with the base address of the circular buffer responsive to initialization of said second register means .
18. An apparatus for generating target addresses within a circular buffer extending in a memory between bounds defined by a base address and an end address, the base address being any predetermined location in the memory, responsive to the next previous address I accessed within said buffer and a specified offset, M, said apparatus comprising:
a first register for storing the previous address, I, accessed within the circular buffer; a second register for storing information which defines the position and size of the circular buffer in memory;
a first logic circuit for generating an absolute address by calculating the value of I+M
a second logic circuit for generating a wrapped address by modifying the value I+M by the length of the circular buffer;
a comparator for comparing the wrapped address with a boundary of the circular buffer to determine which one of said absolute address and said wrapped address is between the bounds of the circular buffer; and
a multiplexer for loading said first register with the one of the absolute address and the wrapped address which is within the bounds of the circular buffer.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/412,827 USRE40904E1 (en) | 1990-11-02 | 2003-04-14 | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer |
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US60836590A | 1990-11-02 | 1990-11-02 | |
US08/115,915 US5623621A (en) | 1990-11-02 | 1993-09-01 | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer |
US10/412,827 USRE40904E1 (en) | 1990-11-02 | 2003-04-14 | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/115,915 Reissue US5623621A (en) | 1990-11-02 | 1993-09-01 | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer |
Publications (1)
Publication Number | Publication Date |
---|---|
USRE40904E1 true USRE40904E1 (en) | 2009-09-01 |
Family
ID=24436166
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/412,827 Expired - Lifetime USRE40904E1 (en) | 1990-11-02 | 2003-04-14 | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer |
Country Status (5)
Country | Link |
---|---|
US (1) | USRE40904E1 (en) |
EP (1) | EP0555382B1 (en) |
JP (1) | JPH05507378A (en) |
DE (1) | DE69118392T2 (en) |
WO (1) | WO1992008186A1 (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100174877A1 (en) * | 2009-01-07 | 2010-07-08 | Nec Electronics Corporation | Ring buffer circuit and control circuit for ring buffer circuit |
US9141569B2 (en) | 2012-12-18 | 2015-09-22 | International Business Machines Corporation | Tracking a relative arrival order of events being stored in multiple queues using a counter |
US9575822B2 (en) | 2014-08-01 | 2017-02-21 | Globalfoundries Inc. | Tracking a relative arrival order of events being stored in multiple queues using a counter using most significant bit values |
US11074184B2 (en) | 2019-04-15 | 2021-07-27 | International Business Machines Corporation | Maintaining data order between buffers |
Families Citing this family (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
FR2718262B1 (en) * | 1994-03-31 | 1996-05-24 | Sgs Thomson Microelectronics | Modulo addressing buffer memory. |
US5659700A (en) * | 1995-02-14 | 1997-08-19 | Winbond Electronis Corporation | Apparatus and method for generating a modulo address |
SE515737C2 (en) * | 1995-03-22 | 2001-10-01 | Ericsson Telefon Ab L M | Apparatus and method for handling digital signals and a processing device comprising such |
KR100236536B1 (en) * | 1997-01-10 | 1999-12-15 | 윤종용 | Modulo address generator |
GB2359641B (en) | 2000-02-25 | 2002-02-13 | Siroyan Ltd | Mapping circuitry and method |
US12101229B2 (en) * | 2020-11-23 | 2024-09-24 | Spirent Communications, Inc. | Generation of data packets for high speed network testing using range variable field modifiers |
Citations (24)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3461433A (en) * | 1967-01-27 | 1969-08-12 | Sperry Rand Corp | Relative addressing system for memories |
US3813652A (en) * | 1973-01-15 | 1974-05-28 | Honeywell Inf Systems | Memory address transformation system |
US3931611A (en) * | 1973-12-10 | 1976-01-06 | Amdahl Corporation | Program event recorder and data processing system |
US3999052A (en) * | 1975-06-18 | 1976-12-21 | International Business Machines Corporation | Upper bounds address checking system for providing storage protection for a digital data processor |
WO1979000035A1 (en) * | 1977-07-08 | 1979-02-08 | Western Electric Co | Apparatus for use with a data processor for defining a cyclic data buffer |
US4187549A (en) * | 1978-09-05 | 1980-02-05 | The United States Of America As Represented By The Secretary Of The Navy | Double precision residue combiners/coders |
US4202035A (en) * | 1977-11-25 | 1980-05-06 | Mcdonnell Douglas Corporation | Modulo addressing apparatus for use in a microprocessor |
US4251860A (en) * | 1978-10-23 | 1981-02-17 | International Business Machines Corporation | Virtual addressing apparatus employing separate data paths for segment and offset portions of a virtual address and utilizing only the offset portion to calculate virtual address |
US4408274A (en) * | 1979-09-29 | 1983-10-04 | Plessey Overseas Limited | Memory protection system using capability registers |
US4432054A (en) * | 1980-09-03 | 1984-02-14 | Hitachi, Ltd. | Loop data transmission control method and system |
US4453212A (en) * | 1981-07-13 | 1984-06-05 | Burroughs Corporation | Extended address generating apparatus and method |
US4453209A (en) * | 1980-03-24 | 1984-06-05 | International Business Machines Corporation | System for optimizing performance of paging store |
US4485435A (en) * | 1981-03-09 | 1984-11-27 | General Signal Corporation | Memory management method and apparatus for initializing and/or clearing R/W storage areas |
US4623997A (en) * | 1984-12-13 | 1986-11-18 | United Technologies Corporation | Coherent interface with wraparound receive and transmit memories |
US4627017A (en) * | 1980-10-22 | 1986-12-02 | International Business Machines Corporation | Address range determination |
JPS61289440A (en) * | 1985-06-18 | 1986-12-19 | Sony Corp | Digital signal processor |
US4722067A (en) * | 1985-03-25 | 1988-01-26 | Motorola, Inc. | Method and apparatus for implementing modulo arithmetic calculations |
US4724479A (en) * | 1984-03-29 | 1988-02-09 | Deutsche Gesselschaft fur Wiederfarbeitung von Kernbrennstoffen mbH | Shielded, highly radioactive, wet chemical cell for an atomic plant with a contrivance for drip leakage recognition and method for use in a cell of this type |
US4800524A (en) * | 1985-12-20 | 1989-01-24 | Analog Devices, Inc. | Modulo address generator |
US4809156A (en) * | 1984-03-19 | 1989-02-28 | Trw Inc. | Address generator circuit |
US4819165A (en) * | 1987-03-27 | 1989-04-04 | Tandem Computers Incorporated | System for performing group relative addressing |
US4833602A (en) * | 1987-06-29 | 1989-05-23 | International Business Machines Corporation | Signal generator using modulo means |
US4908748A (en) * | 1987-07-28 | 1990-03-13 | Texas Instruments Incorporated | Data processing device with parallel circular addressing hardware |
US4935867A (en) * | 1986-03-04 | 1990-06-19 | Advanced Micro Devices, Inc. | Signal processor memory management unit with indirect addressing using selectable offsets and modulo values for indexed address calculations |
-
1991
- 1991-11-01 EP EP92900366A patent/EP0555382B1/en not_active Expired - Lifetime
- 1991-11-01 WO PCT/US1991/008102 patent/WO1992008186A1/en active IP Right Grant
- 1991-11-01 JP JP92501267A patent/JPH05507378A/en active Pending
- 1991-11-01 DE DE69118392T patent/DE69118392T2/en not_active Expired - Lifetime
-
2003
- 2003-04-14 US US10/412,827 patent/USRE40904E1/en not_active Expired - Lifetime
Patent Citations (25)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US3461433A (en) * | 1967-01-27 | 1969-08-12 | Sperry Rand Corp | Relative addressing system for memories |
US3813652A (en) * | 1973-01-15 | 1974-05-28 | Honeywell Inf Systems | Memory address transformation system |
US3931611A (en) * | 1973-12-10 | 1976-01-06 | Amdahl Corporation | Program event recorder and data processing system |
US3999052A (en) * | 1975-06-18 | 1976-12-21 | International Business Machines Corporation | Upper bounds address checking system for providing storage protection for a digital data processor |
WO1979000035A1 (en) * | 1977-07-08 | 1979-02-08 | Western Electric Co | Apparatus for use with a data processor for defining a cyclic data buffer |
US4169289A (en) * | 1977-07-08 | 1979-09-25 | Bell Telephone Laboratories, Incorporated | Data processor with improved cyclic data buffer apparatus |
US4202035A (en) * | 1977-11-25 | 1980-05-06 | Mcdonnell Douglas Corporation | Modulo addressing apparatus for use in a microprocessor |
US4187549A (en) * | 1978-09-05 | 1980-02-05 | The United States Of America As Represented By The Secretary Of The Navy | Double precision residue combiners/coders |
US4251860A (en) * | 1978-10-23 | 1981-02-17 | International Business Machines Corporation | Virtual addressing apparatus employing separate data paths for segment and offset portions of a virtual address and utilizing only the offset portion to calculate virtual address |
US4408274A (en) * | 1979-09-29 | 1983-10-04 | Plessey Overseas Limited | Memory protection system using capability registers |
US4453209A (en) * | 1980-03-24 | 1984-06-05 | International Business Machines Corporation | System for optimizing performance of paging store |
US4432054A (en) * | 1980-09-03 | 1984-02-14 | Hitachi, Ltd. | Loop data transmission control method and system |
US4627017A (en) * | 1980-10-22 | 1986-12-02 | International Business Machines Corporation | Address range determination |
US4485435A (en) * | 1981-03-09 | 1984-11-27 | General Signal Corporation | Memory management method and apparatus for initializing and/or clearing R/W storage areas |
US4453212A (en) * | 1981-07-13 | 1984-06-05 | Burroughs Corporation | Extended address generating apparatus and method |
US4809156A (en) * | 1984-03-19 | 1989-02-28 | Trw Inc. | Address generator circuit |
US4724479A (en) * | 1984-03-29 | 1988-02-09 | Deutsche Gesselschaft fur Wiederfarbeitung von Kernbrennstoffen mbH | Shielded, highly radioactive, wet chemical cell for an atomic plant with a contrivance for drip leakage recognition and method for use in a cell of this type |
US4623997A (en) * | 1984-12-13 | 1986-11-18 | United Technologies Corporation | Coherent interface with wraparound receive and transmit memories |
US4722067A (en) * | 1985-03-25 | 1988-01-26 | Motorola, Inc. | Method and apparatus for implementing modulo arithmetic calculations |
JPS61289440A (en) * | 1985-06-18 | 1986-12-19 | Sony Corp | Digital signal processor |
US4800524A (en) * | 1985-12-20 | 1989-01-24 | Analog Devices, Inc. | Modulo address generator |
US4935867A (en) * | 1986-03-04 | 1990-06-19 | Advanced Micro Devices, Inc. | Signal processor memory management unit with indirect addressing using selectable offsets and modulo values for indexed address calculations |
US4819165A (en) * | 1987-03-27 | 1989-04-04 | Tandem Computers Incorporated | System for performing group relative addressing |
US4833602A (en) * | 1987-06-29 | 1989-05-23 | International Business Machines Corporation | Signal generator using modulo means |
US4908748A (en) * | 1987-07-28 | 1990-03-13 | Texas Instruments Incorporated | Data processing device with parallel circular addressing hardware |
Non-Patent Citations (2)
Title |
---|
English translation of Japanes patent application No. Sho 61[1986]-289440. * |
TMS320C30 Data Book, pp. 6-5, 6-6, and 6-22 through 6-25, Aug. 1988. * |
Cited By (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20100174877A1 (en) * | 2009-01-07 | 2010-07-08 | Nec Electronics Corporation | Ring buffer circuit and control circuit for ring buffer circuit |
US8510503B2 (en) * | 2009-01-07 | 2013-08-13 | Renesas Electronics Corporation | Ring buffer circuit and control circuit for ring buffer circuit |
US9141569B2 (en) | 2012-12-18 | 2015-09-22 | International Business Machines Corporation | Tracking a relative arrival order of events being stored in multiple queues using a counter |
US9189433B2 (en) | 2012-12-18 | 2015-11-17 | International Business Machines Corporation | Tracking a relative arrival order of events being stored in multiple queues using a counter |
US9823952B2 (en) | 2012-12-18 | 2017-11-21 | International Business Machines Corporation | Tracking a relative arrival order of events being stored in multiple queues using a counter |
US9575822B2 (en) | 2014-08-01 | 2017-02-21 | Globalfoundries Inc. | Tracking a relative arrival order of events being stored in multiple queues using a counter using most significant bit values |
US11074184B2 (en) | 2019-04-15 | 2021-07-27 | International Business Machines Corporation | Maintaining data order between buffers |
Also Published As
Publication number | Publication date |
---|---|
EP0555382B1 (en) | 1996-03-27 |
DE69118392D1 (en) | 1996-05-02 |
DE69118392T2 (en) | 1996-08-14 |
WO1992008186A1 (en) | 1992-05-14 |
JPH05507378A (en) | 1993-10-21 |
EP0555382A1 (en) | 1993-08-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US5623621A (en) | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer | |
US4800524A (en) | Modulo address generator | |
US5471600A (en) | Address generating circuit using a base pointer of loop area | |
US6049858A (en) | Modulo address generator with precomputed comparison and correction terms | |
USRE40904E1 (en) | Apparatus for generating target addresses within a circular buffer including a register for storing position and size of the circular buffer | |
EP0260433B1 (en) | Multi-address space control method | |
US6604169B2 (en) | Modulo addressing based on absolute offset | |
JP3199465B2 (en) | Information processing device | |
US5195177A (en) | Clipping processor | |
US5983333A (en) | High speed module address generator | |
US6785798B2 (en) | Method and system for circular addressing with efficient memory usage | |
JP2002342262A (en) | Direct memory access controller and direct memory access control method | |
US5918253A (en) | Memory address generator | |
US6047364A (en) | True modulo addressing generator | |
US6799261B2 (en) | Memory interface with fractional addressing | |
JP2954178B1 (en) | Variable cache method | |
KR19990037571A (en) | A data pointer for outputting an indirect addressing mode address in a single period and a method of providing the same | |
US5386521A (en) | Instruction prefetching circuit with a next physical address precalculating circuit | |
US4301514A (en) | Data processor for processing at one time data including X bytes and Y bits | |
US20020103979A1 (en) | Pointer register device and method for updating a pointer value | |
US20030126402A1 (en) | Device and method for information processing | |
KR100188027B1 (en) | Address generation circuit | |
JP4142299B2 (en) | Address generator for annular address buffer and integrated circuit having the same | |
US5524221A (en) | Next instruction pointer calculation system for a microcomputer | |
JP2560520B2 (en) | Advance control device |