1. Field of the Invention
The present invention relates to random access memory (RAM). More particularly, the present invention relates to RAM blocks suitable for use in field programmable gate array (FPGA) architectures.
2. The Prior Art
Modern FPGAs generally contain blocks of RAM. Each RAM block has address and data inputs, data outputs, a write enable input and often also a read enable input. When read enable is deasserted, the outputs of the RAM block are held in the previous state. This avoids adding any delay to the read path, or consuming dynamic power to disable it. Deasserting read enable may also be used to power down some circuitry, such as sense amplifiers.
Since the RAM blocks in an FPGA of necessity have a fixed capacity, customers who need higher RAM capacity must gang multiple RAM blocks together. For instance, an FPGA may provide RAM blocks capable of storing 8 Kbits in either a 4K-word×2-bit or 1K-word×8-bit format. In a design to be programmed into the FPGA that requires a RAM that is arranged as 4K words×8 bits, it is required that four RAM blocks be combined.
One way to combine RAM blocks to achieve the desired capacity is to configure the four blocks in 4K-word×2 bit format, with each block producing 2 of the 8 output bits. This provides the minimal delay as no extra logic is required in the speed path. However since all RAM blocks must be enabled for every read operation, the dynamic power will be that of four RAM blocks.
An alternative way to combine RAM blocks to achieve the desired capacity is shown in
The total dynamic power in the configuration shown in
The prior art circuit of
U.S. Pat. No. 6,049,487 discloses and claims RAM arrays having multiple read enables, but only in combination with tristate outputs and an output enable scheme. Tri-state signals are disadvantageous in state-of-the-art FPGAs due to their greater complexity and the possibility of conflicting drivers.
A random-access memory block for a field programmable gate array includes a random-access memory array having address inputs, a data input, a data output and including a plurality of storage locations. At least two programmably invertible enable inputs are provided. Hardwired decoding logic inside the RAM block is coupled to the at least two programmably invertible enable inputs to selectively enable the random-access memory array. A gate is coupled to the output of the random-access memory array and is configured to pass the output of the random-access memory array only if the random-access memory is enabled for a read operation, and otherwise generate a preselected logic state.
According to one aspect of the present invention, a random-access memory block includes a random-access memory array having address inputs, a data input, a data output and including a plurality of storage locations. At least two programmably invertible enable inputs are each coupled to a different memory address line. Hardwired decoding logic inside the RAM block is coupled to the programmably invertible enable inputs. A block-enable register is coupled to the output of the decoding logic. A data-input register is coupled to the data input of the random-access memory array. A memory address register has inputs coupled to an address bus and outputs coupled to the address inputs of the random-access memory array. A gate is coupled to the output of the block-enable register, the output of a write-enable register (if desired) and the output of the random-access memory array.
According to another aspect of the present invention, a method for operating a random access memory in a field programmable gate array includes enabling the random access memory block only when it is uniquely selected and a read operation is requested, and generating output data at an output of the random access memory block only when it is uniquely selected and a read operation is requested, otherwise generating a preselected logic state at the output of the random access memory block.
Persons of ordinary skill in the art will realize that the following description of the present invention is illustrative only and not in any way limiting. Other embodiments of the invention will readily suggest themselves to such skilled persons.
Modern FPGAs generally contain RAM blocks. Since the RAM blocks each have a fixed capacity, customers who need higher-capacity RAMs must gang multiple RAM blocks together. The object of this invention is to allow this to be done in a manner that is power efficient yet with minimal delay through the RAM with any required soft gates implemented in the surrounding programmable logic.
Referring now to
The present invention as shown in
According to another aspect of the present invention, instead of holding the previous output values when a block is disabled, or tristating them, as in prior-art FPGA RAM block designs, the output values are forced to a known logic state, for example all zero. By doing this, the 2N-input multiplexer of the RAM block of
These two features of the RAM block of the present invention may slightly increase the delay of a single RAM block used in isolation as compared to a stand-alone RAM block. But, as will be appreciated by persons of ordinary skill in the art, employing these features will eliminate at least an entire level of soft logic when RAMs are ganged together as contemplated by the present invention.
Referring now to
A first hardwired XOR gate 54 has one of its inputs coupled to address line A10 at input en0 of RAM block 52 and the other one of its inputs coupled to a configuration signal invert0. A second hardwired XOR gate 56 has one of its inputs coupled to address line A11 at input en1 of RAM block 52 and the other one of its inputs coupled to a configuration signal invert1. Depending on which RAM block the RAM block 52 is designated as in a ganged RAM block arrangement according to the present invention, neither, either or both of inputs invert0 and invert1 may be set to invert the logic level at neither, one, or both address inputs A10 and A11 as shown in Table 1. If the input invert0 (or input invert1) is set to logic zero, the input at the respective enable input en0 or en1 passes uninverted through XOR gate 54 (or 56). If, on the other hand, the input invert0 (or input invert1) is set to logic one, the input at the respective enable input en0 or en1 becomes inverted through XOR gate 54 (or 56). The states of the invert0 and invert1 inputs to XOR gates 54 and 56 are set by programmable switches in the FPGA during FPGA programming.
As previously disclosed herein, the states of the outputs of the individual RAM blocks in a ganged RAM block arrangement according to the present invention are forced to a known state when the RAM block is not outputting data. In a synchronous RAM, the block-enable must be registered at the input, just like data and address and write- and/or read-enable. The output of the block-enable input register combined with write- and/or read-enable can simply gate data-outputs by AND gates. This is one illustrative example of circuitry that can be used to implement this function, but there are many other implementations possible to force output data to zero deeper inside the read logic. The output should stay zero until the next valid read-access.
Referring now to
Referring now to
In circuits 60 and 80 of
Referring now to
The embodiment shown in
One advantage of the implementations using AND gates just before the data outputs is that this minimizes the dynamic power necessary to force the outputs to zero since the capacitances internal to the RAM of the memory array need not be discharged.
Where feasible, it may be advantageous to support either of two modes when the RAM is disabled. In a first mode, the outputs are held at the previous values as in the prior art. In a second mode, the outputs are forced to a known state as described and shown with reference to
Referring now to
The output of AND gate 116 drives the “0” data input of multiplexer 120. The output of memory array 112 drives the “1” data input of multiplexer 120. The select input of multiplexer 120 is driven by a configuration or mode signal at line 122. This signal can be set to a fixed value during device programming or can be driven by a mode control signal generated by other logic in the integrated circuit. Thus, in the event that the select input of multiplexer 120 is set to pass the “1” data input, the output of memory array block 112 is maintained at the output. In the event that the select input of multiplexer 120 is set to pass the “0” input, the output of the RAM block is set to a known state responsive to AND gate 116.
While embodiments and applications of this invention have been shown and described, it would be apparent to those skilled in the art that many more modifications than mentioned above are possible without departing from the inventive concepts herein. The invention, therefore, is not to be restricted except in the spirit of the appended claims.
Number | Name | Date | Kind |
---|---|---|---|
4435805 | Hsieh et al. | Mar 1984 | A |
5231588 | Agrawal et al. | Jul 1993 | A |
5408434 | Stansfield | Apr 1995 | A |
5689195 | Cliff et al. | Nov 1997 | A |
6049487 | Plants et al. | Apr 2000 | A |
6233646 | Hahm | May 2001 | B1 |
6363517 | Levi et al. | Mar 2002 | B1 |
6430736 | Levi et al. | Aug 2002 | B1 |
7111110 | Pedersen | Sep 2006 | B1 |
7804719 | Chirania et al. | Sep 2010 | B1 |
20020057621 | Heile | May 2002 | A1 |
20020064255 | Mohammadian et al. | May 2002 | A1 |
20020188921 | Shau | Dec 2002 | A1 |
20030081477 | Tran | May 2003 | A1 |
20030189861 | Aikawa | Oct 2003 | A1 |
20030212935 | Roark et al. | Nov 2003 | A1 |
20040123195 | Rohrbaugh et al. | Jun 2004 | A1 |
20040232942 | Kundu et al. | Nov 2004 | A1 |
20050108674 | Darringer et al. | May 2005 | A1 |
20050210343 | Mastro et al. | Sep 2005 | A1 |
20050231237 | Chang | Oct 2005 | A1 |
20080270651 | Kreiner et al. | Oct 2008 | A1 |
20100031075 | Kapil | Feb 2010 | A1 |
20100188894 | Rao et al. | Jul 2010 | A1 |
20100230825 | von Kaenel | Sep 2010 | A1 |
20110060546 | Miller et al. | Mar 2011 | A1 |
20130007679 | Mendel et al. | Jan 2013 | A1 |
Entry |
---|
R. Tessier, V. Betz, D. Neto, and T. Gopalsamy, “Power-Aware RAM Mapping for FPGA Embedded Memory Blocks,” in the Proceedings of the ACM/SIGDA International Symposium on Field Programmable Gate Arrays, Feb. 22-24, 2006, Monterey, CA, 10 pages. |
Number | Date | Country | |
---|---|---|---|
20130111119 A1 | May 2013 | US |