The present invention relates to a reconfigurable logic device.
Reconfigurable (programmable or writable) semiconductor devices such as FPGAs (field-programmable gate arrays) are widely used due to the flexibility imparted by the rewriting capabilities thereof (Patent Document 1, for example).
Typical island-style FPGAs are constituted by logic elements CLBs (configurable logic blocks), switch elements SBs and CBs, and input/output elements IOBs.
Logic elements CLBs can be programmed to realize a combinatorial circuit, and each of the CLBs is constituted by a data flip-flop (DFF), LUT (lookup table), and the like. A k-input LUT (k-LUT) uses a 2k amount of SRAM (static random access memory) cells to realize a function of k variables. Truth tables of the desired logic functions are held in the SRAM and output is performed by referring to the truth tables in response to input, for example.
In order to generate signal routes between the CLBs, which cause the logic function parts to link to one another, the switch elements CBs and SBs are provided between the CLBs, and these switch elements can switch the signal routes. The switch elements CBs are set between logic blocks LB and wiring channels, and the switch elements SBs perform configuration between vertical and horizontal wiring lines at the intersection points of the wiring lines in the vertical and horizontal directions.
The input/output elements IOBs are configuration elements that serve as an interface between the input/output of the device and the logic elements LBs.
The applicants and inventors of the present invention have developed an “MPLD (memory-based programmable logic device)” (registered trademark) that realizes circuit configurations with memory cell units. Patent Document 1 below, for example, discloses an MPLD. The MPLD is connected to memory arrays called MLUTs (multi-lookup tables). MLUTs store truth table data and are constituted by wiring elements and logic elements. The MLUTs, when arranged in an array and connecting with the MPLD, realize a function that is approximately the same as an FPGA. Furthermore, the MPLD uses the MLUTs as both logic elements and wiring elements via the truth table data, thereby imparting flexibility to the logic regions and wiring regions (Patent Document 2, for example), which differs from an FPGA, which has specialized switching circuits for connection between the memory cell units.
Patent Document 1: Japanese Translation of PCT International Application Publication No. 2002-538652
Patent Document 2: WO 2007/060763
As described above, the FPGA is a reconfigurable device, but has a larger area than an ASIC (application-specific integrated circuit). This is because the wiring lines and switches occupy approximately 70 to 80% of the total area of the FPGA. The logic elements and the wiring elements of the FPGA are also realized by differing devices, which restricts reconfiguration of the FPGA.
An embodiment of the present invention provides a programmable logic device having a small area and enhanced reprogramming characteristics.
Aspects to solve the above-mentioned problems are described by the items below.
1. A reconfigurable logic device for forming a plurality of logic circuits in accordance with configuration data, including:
2. The reconfigurable logic device according to item 1,
3. The reconfigurable logic device according to item 1 or 2,
4. The reconfigurable logic device according to any one of items 1 to 3, wherein each of the plurality of multi-lookup table units includes:
5. The reconfigurable logic device according to any one of items 1 to 4, wherein the reconfigurable logic multiplexer in each of the plurality of multi-lookup table units selects and outputs the configuration data held by the holding unit in accordance with the data inputted from the data input lines.
6. The reconfigurable logic device according to any one of items 1 to 5, wherein at least some of the data input lines of one of the respective multi-lookup tables units are connected to at least some of the data output lines of the multi-lookup table units adjacent thereto.
7. The reconfigurable logic device according to any one of items 1 to 6, wherein the configuration memory includes a plurality of memories, one of the plurality of memories being provided for each data output direction.
8. The reconfigurable logic device according to any one of items 1 to 7, wherein the configuration memory in each of the plurality of multi-lookup table units includes a clock transition detecting unit that generates a clock at a moment when an address to be outputted to the configuration memory is received, and
9. The reconfigurable logic device according to any one of items 1 to 8,
10. The reconfigurable logic device according to any one of items 1 to 9,
11. A method of controlling a reconfigurable logic device that forms a plurality of logic circuits in accordance with configuration data, the reconfigurable logic device having a plurality of multi-lookup table units, each of the multi-lookup table units including a rewritable configuration memory that stores configuration data for the multi-lookup table unit, data input lines, data output lines, and a reconfigurable logic multiplexer connected to the rewritable configuration memory, wherein the multi-lookup table units that are adjacent to one another are connected through the data input lines and the data output lines of the respective multi-lookup table units, the method including:
12. The method according to item 11,
13. The method according to item 11 or 12, wherein the configuration memory in each of the plurality of multi-lookup table units includes a clock transition detecting unit that generates a clock at a moment when an address to be outputted to the configuration memory is received, and
14. A non-transitory storage medium that stores instuctions executable by a processor, the instructions being for controlling a reconfigurable logic device having a plurality of multi-lookup table units, each of the multi-lookup table units including a rewritable configuration memory that stores configuration data for the multi-lookup table unit, data input lines, data output lines, and a reconfigurable logic multiplexer connected to the rewritable configuration memory, wherein the multi-lookup table units that are adjacent to one another are connected through the data input lines and the data ouput lines of the respective multi-lookup table units, the instructions causing the processor to perform the following:
A semiconductor device according to the present embodiment can provide a small area and enhanced reprogramming characteristics.
The following will be described below in the stated order with reference to the drawings: [1] a reconfigurable logic device, [2] an MLUT array, [3] an MLUT, [4] page control, [5] configuration data, and [6] a truth table data generation method.
[1] Reconfigurable Logic Device
The MRLD is a device having functions that are approximately the same as an FPGA, but the structure of the MRLD differs from the FPGA. An FPGA is constituted by CLBs, switch blocks, connection blocks, and the like, and the allocation between logic resources and wiring resources is fixed. In contrast, the MRLD greatly differs from an FPGA in that the MRLD has an array of MLUTs that can be used as both logic elements and wiring elements and in that the MLUTs are directly connected to one another.
An MRLD 20 shown in
The logic operations of the MRLD 20 use the data input DI and data output DO signals represented by the respective bold lines. The data input DI is used as the input signal of the logic circuit. The data output DO is used as the output signal of the logic circuit (described later with
The logic that is realized by logical operation of the MRLD 20 is realized by truth table data stored in the MLUTs 30. Several of the MLUTs 30 operate as logic elements as combinatorial circuits having AND circuits, adders, or the like. Other MLUTs function as connective elements that respectively connect the MLUTs 30 realizing the combinatorial circuits to one another. The rewriting of the truth table data for the MRLD 20 to realize the logic elements and connective elements is performed by writing operation to the configuration memory of the respective MLUTs 30.
The writing operation of the MRLD 20 is performed with a write address AD and write data WD, and the read operation is performed with a read address AD and read data RD.
The write address AD identifies memory cells within the MLUTs 30. The write address AD identifies a 2m number n of memory cells with an m amount of signal lines. The write address AD is used both for memory read operation and write operation and selects the relevant memory cells via the m amount of signal lines after decoding by the decoder 12. It should be noted that, in the present embodiment, the decoding of the logical operation address DI is performed by a decoder within the MLUT 30, as described later.
The decoder 12, in accordance with control signals such as a read enable signal re and a write enable signal we, decodes the write address AD and outputs the decoded address n to the MLUT 30. The decoded address n is used as an address for identifying the memory cell within the configuration memory of the MLUT 30.
The input/output unit 14 writes the write data WD in accordance with the write enable signal we, and outputs the read data RD in accordance with the read enable signal re.
[2] MLUT Array
The alternately arranged MLUTs having a plurality of data lines and bit lines allow for multi-bit data processing and can also limit the flow direction of data in the input and output direction, thereby facilitating the creation of logic libraries.
The respective MLUTs 30 can execute a large number of differing logical functions. Each of the MLUTs 30 has a configuration memory 40 and a reconfigurable logic multiplexer 50. The logical function executed by each of the MLUTs 30 is determined by the configuration data stored in the configuration memory 40 of the corresponding MLUT. The MLUT 30 has an input for configuration data, and an output for configuration data for output to the reconfigurable logic multiplexer 50. The configuration data is loaded into the configuration memory 40 from outside the MRLD 20 via the address lines and data lines.
The reconfigurable logic multiplexer 50 has a data input, data output, and a configuration input for receiving configuration data, and controls the connection state between the data input and output in response to these. In accordance with the configuration data, the reconfigurable logic multiplexer 50 outputs, to the data output line, data that has been logically operated pertaining to the data input.
[3] MLUT
[3.1] Configuration Memory
The configuration memory 40, in accordance with clock A0, reads data via a sense amp (not shown) from the memory cells identified by the addresses and outputs the data to the register unit 60, which has a number of registers corresponding to the relevant bits (256 bits in the example in
The memory cell array 110 has an n×2m amount of memory cells (and corresponding storage elements), and the amount of memory cells are provided at the nodes of the n×2m amount of word lines and the n amount of bit lines (hereinafter also referred to as “data lines”).
When the address decoder 120 receives address signals from the m amount of address signal lines in synchronization with the clock generated by the A0 clock transition detecting unit, the address decoder 120 decodes these address signals, outputs a word line select signal as a decode signal and a data line select signal selected at the data input/output unit 140 to the 2m amount of word lines WL, and causes the data read/write processes relative to the corresponding memory cells to be performed.
The data input/output unit 140 has a write amp and a sense amp. If the write amp receives rising edge timing and write data of the write enable (WE) from outside, for example, then the write amp transmits the signal level of the write data to the m amount of data lines b,/b and writes the data to the memory cells. When the data input/output unit 140 receives rising edge timing of the read enable (RE) from outside, the sense amp outputs the signal level of the m amount of data lines b,/b to outside, thereby outputting read data.
It should be noted that the configuration memory shown in
The signal S4 generated as the clock signal is output from the AND circuit 230. The AND circuit 230 receives the input and output of the delay circuit 240B; therefore, if the signal level of both differs, the AND circuit 230 outputs a “high” signal level. This enables detection of address transition.
Signal S5 is a delay signal output from the delay circuit 240C, and waits for an enable signal of the LAT 270 and receives a clock.
Signal S6 is a signal extension of signal S5 and is a pulse generation of the enable signal. The NOR circuit 210A outputs signal S7, which is a NOR computational value of signals S5 and S6. The signal S7 serves as the enable signal of the D latch 270. Signal S8 is signal S5 that has been inverted by the inverter 260A and is used as the clock for the latch of the address signal at the FF 250. The signal S9 is used as an enable signal of the configuration memory; signal S10 is used as a clock (atd_clk) for the configuration memory; and signal S11 is used as an address for the configuration memory. In this manner, the signal S1, which is address A0, generates the clock signal S10; thus, a synchronous SRAM can be used as the configuration memory.
[3.2] Reconfigurable Logic Multiplexer
The number of reconfigurable logic multiplexers 50 is equal to the amount of data wiring line routes. The MLUT 30 has reconfigurable logic multiplexers 52A, 52B, 52C, and 52D, for example.
In accordance with the configuration data held in the register unit 60, the multiplexers cause the data inputs to connect with the data outputs, and these connective paths are reconfigurable by the configuration data. This operation involves selecting and outputting “input signals” by setting the data held in the register unit 60 as the “input signals” and setting the data inputs as the “select control signals.”
A. Implementation of Logic Functions
In the example shown in
B. Implementation of Wiring Functions
The respective reconfigurable logic multiplexers use the data inputs as select signals to select any of the plurality of truth table data in accordance with the data inputs. The respective configurable logic multiplexers realize desired wiring routes that connect the data inputs from the data input lines to the data outputs for the data output lines. There are a plurality of the reconfigurable logic multiplexers; one for each combination of data input line direction and data output line direction. The reconfigurable logic multiplexers 52A, 52B, 52C, and 52D are provided for, respectively, the wiring route from the left side input to the left side output, the wiring route from the left side input to the right side output, the wiring route from the right side input to the right side output, and the wiring route from the right side input to the left side output, for example. If the reconfigurable logic multiplexer 52A is selected by the data input rather than the reconfigurable logic multiplexer 52B, for example, then the input signal (configuration data) selected by the reconfigurable logic multiplexer 52B in accordance with the data input is “0” and is the logical sum of the signal of 52A and the signal of 52C; therefore, the signal from left to the left is prioritized, which forms a signal path from left to left. The input signal (configuration data) selected by the reconfigurable logic multiplexer 52A in accordance with the data input has a prescribed logic value, which is output to the left.
The configuration data will be explained in detail later with
As described above, the reconfigurable logic multiplexer 50 is provided in accordance with the wiring routes, and having the configuration data selecting the logical computation values and wiring allows the multiplexer to operate like a logical computation circuit and/or a switch.
The outputs of the bi-directional multiplexers were logically added with the other outputs in the same direction, and this principle is the same for the quad-directional arrangement. Due to there being four directions, however, there are four logical sums. In the case of the data outputs OutC0 to OutC3, for example, these serve as the logical sums for the outputs of the reconfigurable logic multiplexers 52C, 52E, and 52G. Making the data of the reconfigurable logic multiplexers 52E and 52G “0” allows the output of 52E to be output upwards.
[4] Page Control
The MLUT 30 shown in
It should be noted that
In a conventional MPLD, the state machine of the MPLD needs to be defined by the truth table data. Thus, it was necessary to provide truth table data that defined a plurality of prescribed states in accordance with prescribed parameters. The state machine constituted by the MLUT had to become a control circuit, and had to also generate logic circuits, unlike a data pass, and have arrangement wiring.
The MLUT 30 shown in
The MRLD can use semiconductor design prototypes relevant to specialized compact SRAMs and conventional large-capacity memory devices even without undergoing manufacturing. When forming the MRLD with chips, memory IP (intellectual property) is used, but in the micro-memories required by conventional MLUTs, the area of the address decoder, sense amp, and the like is large, and the component ratio of the memory itself is 50% or less. This adds to overhead and results in poor efficiency. With a large-capacity memory, the ratio with respect to the address decoder, sense amp and the like decreases, which increases memory usage efficiency. Therefore, the large-capacity memory is effective for MRLD chips, as in the current case.
[5] Configuration Data
The configuration data in the example in
As described above, the outputs of the reconfigurable logic multiplexer are logically added; thus, making the configuration data of routes with no signal outputs “0” creates configuration data such that desired logical computations are output as a result.
[6] Truth Table Data Generation Method
The truth table data of the reconfigurable semiconductor device is generated by an information processing device that executes a software program for logical composition.
The functions of the logic elements and/or connective elements are constructed by the truth table data being read by the semiconductor device 20 and a specific method of collaboration between truth table data and the hardware resources. Furthermore, the truth table data can be surmised to be data having a structure showing logical constructions that are referred to as “truth tables.”
The embodiments described above are merely illustrative, and the combination, modification, and variations of the constituting elements of the respective above-mentioned aspects are obvious for a person with ordinary skill in the art; indeed, a person with ordinary skill in the art could perform various types of modifications to the above-mentioned embodiments without departing from the scope of the invention as described in the claims and the principles of the present invention.
20 MRLD
30 MLUT
40 configuration memory
50 reconfigurable logic multiplexer
60 register unit
200 clock transition detecting unit
300 MLUT array
Number | Date | Country | Kind |
---|---|---|---|
2013-076506 | Apr 2013 | JP | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2014/059703 | 4/2/2014 | WO | 00 |
Publishing Document | Publishing Date | Country | Kind |
---|---|---|---|
WO2014/163099 | 10/9/2014 | WO | A |
Number | Name | Date | Kind |
---|---|---|---|
6150838 | Wittig et al. | Nov 2000 | A |
6208163 | Wittig et al. | Mar 2001 | B1 |
6389579 | Phillips | May 2002 | B1 |
7183796 | Leijten-Nowak | Feb 2007 | B2 |
7251672 | Leijten-Nowak | Jul 2007 | B2 |
7486109 | Sasao | Feb 2009 | B2 |
7592834 | Agrawal | Sep 2009 | B1 |
8082284 | Leijten-Nowak | Dec 2011 | B2 |
8117247 | Taylor | Feb 2012 | B1 |
8138788 | Honda | Mar 2012 | B2 |
20030122578 | Masui et al. | Jul 2003 | A1 |
20090154282 | Satoh | Jun 2009 | A1 |
20090290444 | Satoh | Nov 2009 | A1 |
20120007635 | Hironaka et al. | Jan 2012 | A1 |
20150280717 | Sato | Oct 2015 | A1 |
20150286762 | Sato | Oct 2015 | A1 |
Number | Date | Country |
---|---|---|
2002-538652 | Nov 2002 | JP |
2003-198361 | Jul 2003 | JP |
2006-313999 | Nov 2006 | JP |
2009-194676 | Aug 2009 | JP |
2010-239325 | Oct 2010 | JP |
0051239 | Aug 2000 | WO |
2007060763 | May 2007 | WO |
Entry |
---|
Written Opinion (PCT/ISA/237) issued in PCT/JP2014/059703 mailed in Sep. 2014. |
International Search Report (ISR) issued in PCT/JP2014/059703 mailed in Sep. 2014. |
Number | Date | Country | |
---|---|---|---|
20160036447 A1 | Feb 2016 | US |