Extended length counter chains in FPGA logic

Information

  • Patent Application
  • 20020012415
  • Publication Number
    20020012415
  • Date Filed
    October 08, 2001
    23 years ago
  • Date Published
    January 31, 2002
    22 years ago
Abstract
A synchronous counter, the inventive counter is synchronized to a clock, e.g., a master clock of an FPGA, and includes a first counter that increments in response to the master clock, a resynchronizer that receives counter bits from the first counter and, when appropriate, generates an increment signal, and a second counter, clocked by the master clock, that increments in response to the increment signal. In a preferred embodiment, the resynchronizer is an n bit AND gate (where the first counter is an n-bit counter) that ANDs at least selected ones of the counter bits and a latch, e.g., a flip-flop, that latches the output of the AND gate. Thus, small counter chains are linked together using flip-flops clocked at the master clock rate, i.e., the same rate as the counter chains, to form a counter chain of any length that will function at the master clock rate. Accordingly, counter chains of unlimited size that can be implemented in a field programmable logic array (FPGA) and that can run at the maximum clock rate of the FPGA can be realized.
Description


BACKGROUND OF THE INVENTION

[0001] 1. Field of the Invention


[0002] The present invention relates to gate array logic. More specifically, the present invention relates to counter chains that may be implemented in field programmable gate array logic.


[0003] 2. Description of the Related Art


[0004] The maximum length of prior art counter chains was limited by the carry-forward ripple delay through the chain. Typical field programmable logic arrays (FPGAs) include variable length counter chains with a serial carry look-ahead output. These variable length counter chains are linked together with the carry look-ahead output of one counter chain stage being passed to a carry input of the next counter chain stage. When the individual stage delay, as multiplied by the number of stages in a counter, exceeded the period between clocks, the counter would no longer count correctly. Further, even if these counters include fast look-ahead logic, there remains the fundamental counter chain length limitation that the overall carry delay, increased by each stage, must not exceed the clock period. So, for example, on a typical currently available FPGA, the longest counter chain supported with a basic clock rate of 80 Megahertz, the maximum number of counter stages is about 17 or 18 stages.


[0005] Accordingly, there is a need for counter chains that may be of any length without regard to the carry-forward ripple delay.



SUMMARY OF THE INVENTION

[0006] The present invention is a synchronous counter synchronized to a master clock. The master clock may be a clock on an FPGA chip. The counter includes a first counter that increments in response to the master clock. A resynchronizer receives counter bits from the first counter and, when appropriate, generates an increment signal. A second counter, clocked by the master clock, increments in response to the increment signal. The resynchronizer is an n bit AND gate (where the first counter is an n-bit counter) that ANDs at least selected ones of the counter bits of the first counter, and a latch clocked by the master clock for latching the output of the AND gate. Thus, small counter chains are linked together using flip-flops clocked at the master clock rate, i.e., the same rate as the counter chains, to form a counter chain of any length that will function at the master clock rate. Accordingly, the present invention encompasses counter chains of unlimited size that can be implemented in a field programmable logic array (FPGA) and that can run at the maximum clock rate of the FPGA.







BRIEF DESCRIPTION OF THE DRAWINGS

[0007] The sole FIGURE depicts a counter including a look ahead resynchronizing stage according to a preferred embodiment of the present invention.







DESCRIPTION OF THE INVENTION

[0008] Illustrative embodiments and exemplary applications will now be described with reference to the accompanying drawings to disclose the advantageous teachings of the present invention.


[0009] While the present invention is described herein with reference to illustrative embodiments for particular applications, it should be understood that the invention is not limited thereto. Those having ordinary skill in the art and access to the teachings provided herein will recognize additional modifications, applications, and embodiments within the scope thereof and additional fields in which the present invention would be of significant utility.


[0010] The sole FIGURE depicts a counter including a look ahead resynchronizing stage according to a preferred embodiment of the present invention. In this example, two small n bit counter chains 100, 102 are linked together by a resynchronizing stage that includes a flip-flop 104 and an AND gate 106. The n bit counter chains count from 0 to N-1, where N=2n.


[0011] Flip-flop 104 is clocked at the same rate as the counter chains, i.e. at the master clock rate. AND gate 106 (or a circuit providing an equivalent function) ANDs all but the least significant of the n counter bits and passes the result to the data input of flip-flop 104. The output 108 of flip-flop 104 is passed to the enable input of second n bit counter 102. Although counters 100, 102 are shown in this example to be identical n bit counters, this is by way of example only and not intended as a limitation. Also, although the exemplary embodiment includes two counters 100, 102 synchronized by a resynchronizer, any number of counters may be linked using a resynchronizer between linked pairs without departing from the spirit or scope of the invention.


[0012] Essentially, the resynchronizer stage captures the output of the first n bit counter 100 when it reaches the count of 2n-2, i.e., one count state before the normal rollover point of 2n-1. Thus, by clocking a resynchronizing flip-flop at this point, the counter carry string is anticipated and the flip-flop output 108 is synchronized to the main clock 110. The flip-flop output 108 enables the second n bit counter 102 for a single clock period. During that clock period, the second n bit counter is incremented once and disabled in the next clock period, when the clock 112 resets flip-flop 104. Thus, the entire counter chain counts normally, even though the carry delay for the n bit counters may exceed the clock period.


[0013] For comparison, a prior art counter and a counter according to the preferred embodiment of the present invention were implemented on a commercially available FPGA chip, a Flex 8000 chip from Altera. The fastest prior art counter was limited to 32 stages at a maximum chip clock rate of 20 MHz. However, the 32 bit counter of the present invention exhibited no failures with the chip clock speed extended to 80 MHz


[0014] Accordingly, the present invention is applicable to all counter designs for FPGA's or similar devices that incorporate long counter strings. The present invention allows the use of cheaper and slower devices than could otherwise be used with a ripple carry type counter.


[0015] Thus, the present invention has been described herein with reference to a particular embodiment for a particular application. Those having ordinary skill in the art and access to the present teachings will recognize additional modifications, applications and embodiments within the scope thereof.


[0016] It is therefore intended by the appended claims to cover any and all such applications, modifications and embodiments within the scope of the present invention.


[0017] Accordingly,


Claims
  • 1. A synchronous counter comprising: a first counter for receiving a clock signal and incrementing a first counter in response thereto; a resynchronizer for receiving counter bits from the first counter and generating an increment signal in response thereto; and a second counter for incrementing a second count in response to the increment signal and the clock signal.
  • 2. A synchronous counter as in claim 1 wherein the resynchronizer comprises: an AND gate that ANDs at least selected ones of the counter bits and a latch that latches a result from the AND gate.
  • 3. A synchronous counter as in claim 2 wherein the first counter is an n bit counter and the AND gate ANDs the n most significant counter bits.
  • 4. A synchronous counter as in claim 3 wherein an output of the latch is coupled to an enable input of the second counter.
  • 5. A synchronous counter as in claim 4 wherein the second counter is an n bit counter.
  • 6. A synchronous counter as in claim 5 wherein the carry propagation delay through the first counter exceeds the period of the clock.
  • 7. A synchronous counter as in claim 6 wherein the synchronous counter is a counter of a field programmable gate array (FPGA) and the clock is a master clock for the FPGA.
  • 8. A synchronous counter as in claim 1 wherein the resynchronizer comprises: a logic gate that logically combines at least selected ones of the counter bits and produces an output representative of the result and a latch that latches the output of the logic gate.
  • 9. A synchronous counter as in claim 8 wherein the latch comprises a flip-flop.
  • 10. A synchronous counter as in claim 8 wherein the logic gate comprises an AND gate.
  • 11. A synchronous counter as in claim 9 wherein the logic gate comprises an AND gate.
  • 12. A synchronous counter comprising: first counting means for incrementing in response to a clock, wherein a carry propagation delay through the first counting means exceeds the period of the clock; resynchronizing means for anticipating a carry from the first counting means and for generating an increment signal responsive to the anticipated carry and the clock; and second counting means for incrementing in response to the increment signal and the master clock.
  • 13. A synchronous counter as in claim 12 wherein the means for resynchronizing comprises: means for combining at least selected counter bits from the first counting means and for producing a result prior to the occurrence of a carry; and means for latching the result.
  • 14. A synchronous counter as in claim 13 wherein the first counting means is an n-bit counter, and the combining means combines the n most significant counter bits to produce the result.
  • 15. A synchronous counter as in claim 14 wherein the increment signal is the result.
  • 16. A synchronous counter as in claim 15 wherein the second counting means is an n-bit counter.
  • 17. A synchronous counter as in claim 12 wherein the carry propagation delay through the first counting means exceeds the period of the clock.
  • 18. A synchronous counter as in claim 12 wherein the synchronous counter is a counter of a field programmable gate array (FPGA) and the clock is a master clock for the FPGA.
  • 19. A synchronous counter as in claim 12 wherein the resynchronizing means comprises: a logic gate that logically combines at least selected ones of the counter bits and produces an output representative of the result; and a latch that latches the output of the logic gate.
  • 20. A synchronous counter as in claim 19 wherein the latch comprises a flip-flop. gate.
Divisions (1)
Number Date Country
Parent 09481093 Jan 2000 US
Child 09973147 Oct 2001 US