This application is based upon and claims the benefit of priority from, the prior Japanese Patent Application Nos. 2005-330268 filed on Nov. 15, 2005 and 2006-166387 filed on Jun. 15, 2006, the entire contents of which are incorporated herein by reference.
The present invention relates to a reconfigurable logic block (RLB), a programmable logic device that is provided with an RLB, and a method of fabricating an RLB, and, in particular, to a technique of fabricating an RLB that enables a reduction in implementation area.
2. Description of the Related Art
Programmable logic devices have recently attracted attention as devices that a user can use to implement logic circuits to suit various different requirements, by electrically programming the internal circuitry thereof. Programmable logic devices (PLDs), field programmable gate arrays (FPGAs), dynamically reconfigurable processors (DRPs), or digital application processor/distributed network architecture (DAP/DNA) devices are known as examples of such programmable logic devices. In addition to being used in the trial manufacture of hardware, they are also used in themselves for configuring large-scale circuits (such as microprocessors) having various different functions.
In order to improve the capabilities of programmable logic devices, new reconfigurable logic block (RLBs) have become necessary. In other words, the RLBs that configure prior-art programmable logic devices can be considered within two frameworks: fine-grained and coarse-grained type.
More specifically, an FPGA or the like can use an RLB as the basis of a look-up table (LUT) employing the fine-grain approach, or a DRP or DAP/DNA or the like can use an RLB as the basis of an arithmetic and logical unit (ALU).
In this case, the LUT is configured of memory, making it possible to implement any desired logic circuit, the number of bits N of input signals of logic circuits that can be implemented corresponds to the number of bits of memory addresses configuring the LUT, and a one-bit signal is output as an output therefrom. Thus a logic circuit that can be implemented in one LUT is an arbitrary N-input, 1-output logic circuit. Note that this kind of LUT is represented by an N-input LUT (N-LUT) in this document.
The fine-grain approach is superior for logical operations in bit units, with methods using LUTs in RLBs, and the coarse-grain approach is superior for arithmetic operations in byte units, with method using ALUs in RLBs.
In the prior art, Japanese Unexamined Patent Publication (Kohyo) No. 2002-511173 proposes an integrated circuit in which the effective area efficiency has been improved even with standard mutual connections, by mixing arithmetic and logic cells, as a method of providing reconfigurable calculation rules that enable flexibility of software development and the capability of solutions by dedicated hardware.
In addition, Japanese Unexamined Patent Publication (Kokai) No. 10-111790 of the prior art proposes a device wherein components such as an accumulator, multiplier and adder are efficiently implemented within one compact cell, as an operation cell configured of a multiplexer and a steering logic circuit for controlling the same. The steering logic circuit receives configuration signals in accordance with the application to control the multiplexer and select a path.
Furthermore, Japanese Unexamined Patent Publication (Kokai) Nos. 11-024891 and 11-122096 of the prior art propose a programmable function block provided with a full adder and front logic, as means of providing a programmable function block that is fast and is also multi-function.
Additionally, Japanese Unexamined Patent Publication (Kokai) No. 2003-018000 of the prior art proposes a method of fabricating an LUT that is provided with a plurality of LUT units and an internal configuration control means that controls the internal configuration created by that plurality of LUT units, in an FPGA.
As described above, since a prior-art device such as an FPGA based on a fine-grained LUT is inferior for implementing an arithmetic circuit, another component such as a multiplier is mounted separately, and thus the area efficiency (implementation efficiency) of the chip is reduced by that amount.
Similarly, a device such as a DRP or DAP/DNA based on a coarse-grained type ALU has a bad area efficiency when used to configure a random logic (glue logic) circuit. More specifically, any deterioration of capabilities is avoided by having an arithmetic-logic unit that is called a data management unit (DMU) in addition to the ALU, but if this arithmetic-logic unit is not used, that in itself will be a cause of a drop in area efficiency. This makes it impossible to prevent deterioration in the area efficiency of the chip.
More specifically, since an adder circuit of the operation cell disclosed in Japanese Unexamined Patent Publication (Kokai) No. 10-111790 is configured of an two 8-LUTs, by way of example, and the two LUTs are not connected internally, the original capability thereof as an adder is insufficient from the viewpoints of both area efficiency and speed. In addition, since each RLB of the operation cell disclosed in Japanese Unexamined Patent Publication (Kokai) No. 10-111790 is configured of two 8-LUTs during logical operations, the area efficiency thereof is even worse.
The programmable function block disclosed in Japanese Unexamined Patent Publication (Kokai) No. 11-024891 by way of example is provided with a one-bit full adder and front logic within each RLB, but since carries are through external wiring during operations with a plurality of bits, problems arise in that speed overheads increase and completion of the logic cannot be ensured during logical operations.
An object of the present invention is to maintain a high area efficiency of a chip, regardless of a circuitry configured therein, and aim for both a higher speed and a lower low power consumption.
According to the present invention, there is provided a reconfigurable logic block comprising a first circuit that configures an arithmetic circuit and a second circuit that configures a circuit outside of the arithmetic circuit, wherein a plurality of different circuits are configured by changing the settings of predetermined signals in the first and second circuits.
According to the present invention, there is also provided a programmable logic device comprising a plurality of reconfigurable logic blocks arrayed in a matrix, a plurality of wires connecting the reconfigurable logic blocks, a plurality of switch blocks provided at intersections between the wires, a plurality of connection blocks provided between input-output lines of each of the reconfigurable logic blocks and the wires, and I/O blocks that perform input and output with respect to the exterior, wherein each of the reconfigurable logic blocks comprises a first circuit that configures an arithmetic circuit and a second circuit that configures a circuit outside of the arithmetic circuit; and a plurality of different circuits are configured by changing the settings of predetermined signals in the first and second circuits.
The first circuit may comprise an adder circuit, and the second circuit may comprise a canonical form of logic circuit. The first circuit may be a full-adder circuit or a half-adder circuit. The second circuit may be a Reed-Muller canonical form of logic circuit. The first circuit may comprise a plurality of adder circuits, and wirings among the plurality of adder circuits may be formed within the reconfigurable logic block.
The setting of predetermined signals in the first and second circuits may be done by fixing the predetermined signals to a first power level or a second power level. The reconfigurable logic block may further comprise a memory or signal lines for setting predetermined signals in the first and second circuits.
The memory may be a volatile memory, and data may be written to the volatile memory during an initial setting in which a power voltage is supplied to the reconfigurable logic block. The memory may be a non-volatile memory, and write processing of data may be performed beforehand with respect to the non-volatile memory before the reconfigurable logic block is activated for use in practice.
The reconfigurable logic block may comprise a plurality of hybrid cells having differing circuit configurations. The reconfigurable logic block may comprise a plurality of hybrid cells having the same circuit configuration.
Further, according to the present invention, there is provided a method of creating a reconfigurable logic block comprising a first circuit that configures an arithmetic circuit and a second circuit that configures a circuit outside of the arithmetic circuit, wherein the reconfigurable logic block comprises a different circuit that causes changes in the settings of predetermined signals in the first and second circuits.
The setting of predetermined signals in the first and second circuits may be done by fixing the predetermined signals to a first power level or a second power level. The setting of predetermined signals in the first and second circuits may be done by data stored in a memory or data distributed to a signal line. The memory may be a volatile memory, and data may be written to the volatile memory in an initial setting in which power is supplied to the reconfigurable logic block. The memory may be a non-volatile memory, and write processing of data may be performed beforehand with respect to the non-volatile memory before the reconfigurable logic block is activated for use in practice.
In addition, according to the present invention, there is also provided a method of configuring an ASIC by utilizing a method of creating a reconfigurable logic block comprising a first circuit that configures an arithmetic circuit and a second circuit that configures a circuit outside of the arithmetic circuit, wherein the reconfigurable logic block comprises a different circuit that causes changes in the settings of predetermined signals in the first and second circuits; and the setting of predetermined signals in the first and second circuits is done by fixing the predetermined signals to a first power level or a second power level.
The first circuit may comprise an adder circuit, and the second circuit may comprise a canonical form of logic circuit. The first circuit may comprise a full-adder circuit or a half-adder circuit. The second circuit may comprise a Reed-Muller canonical form of logic circuit. The first circuit may comprise a plurality of adder circuits, and wirings among the plurality of adder circuits may be formed within the reconfigurable logic block.
The present invention will be more clearly understood from the description of the preferred embodiments as set forth below with reference to the accompanying drawings, wherein:
Below, embodiments of a reconfigurable logic block (RLB), a programmable logic device having the RLB, and a method of fabricating the RLB in accordance with the present invention will be described in detail with reference to the accompanying drawings.
A block diagram of the entire configuration of a programmable logic device in which the present invention is used is shown in
As shown in
A block diagram of an example of the input-output configuration of a reconfigurable logic block (RLB) is shown in
The present invention is described below with respect to an example of an RLB having 18 inputs, 11 outputs, and 20 memory bits. In other words, the RLB 102 shown in
Note that the 18-input, 11-output, 20-memory RLB described below is just an example, and thus it should be obvious that the present invention can be applied to RLBs of various different configurations.
As shown in
In other words, the memory bits M0 to M3 in the 2-input Reed-Muller canonical form of logic circuit are allocated as follows:
F(x0,x1)=F(0,0)→M3
⊕x0{F(0,0)⊕F(1,0)}→M2
⊕x1{F(0,0)⊕F(0,1)}→M1
⊕x0·x1{F(0,0)⊕F(0,1)⊕F(1,0)⊕F(1,1)}→M0
In addition, the 2-input Reed-Muller canonical form of circuit shown in
Logic circuit diagrams of examples of the configuration of hybrid cells in RLB relating to the present invention are shown in
In
A logical circuit diagram of the configuration of an embodying example of the RLB in accordance with the present invention is shown in
In this case, as is clear from a comparison of
As shown in
This configures the combination logic portion 102a of the RLB (in other words, the RLB 102) that has a total of 18 inputs which are four X inputs X0 to X3, four Y inputs Y0 to Y3, five Z inputs Z0 to Z4, four Cin inputs Cin0 to Cin3, and one AS input AS; a total of 11 outputs which are three E outputs E0 to E2, four S outputs S0 to S3, and four Cout outputs Cout0 to Cout3; and 20 memory bits M0 to M19.
A block diagram of circuit functions that can be implemented by the RLB of
As shown in
In other words, to configure the 4-bit ALU from the combination logic portion 102a of
Concentrating on the hybrid cell 121 in this case, by way of example, since the same input signal X1 is supplied to both of the inputs X1 and Z1 and also a control terminal connected to the input Cin1 is fixed to data “1”, a selector 1211 selects and outputs the input X1 on the data “1” side (but note that since the same signal X1 is input to both inputs X1 and Z1, this is the same X1). Since a control terminal of another selector 1212 is fixed to the data “1” stored in the memory bit M17, the selector 1212 selects the carry output C0 of the hybrid cell 120. In addition, since one input of a 2-input NAND gate 1213 is fixed to the data “0” stored in the memory bit M7, the output thereof is always data “1”.
In this manner, a 4-bit ALU can be configured of the combination logic portion 102a (the RLB 102) of
In other words, to configure the four MUXes from the combination logic portion 102a shown in
In other words, to configure one 4-LUT from the combination logic portion 102a shown in
Note that in addition to the circuits shown in
As described above, the reconfigurable logic block (RLB) in accordance with the present invention or a programmable logic device provided with such an RLB makes it possible to implement various different types of LUT having pluralities of inputs, due to the provision of the memory bits M0 to M19 within the RLB 102 (the combination logic portion 102a), unlike with LUTs that use FPGAs of the prior art, by way of example. This enables configuration with an LUT of the number of signals as appropriate for the necessary circuitry, preventing any increase in implementation area. In addition, the connections between the neighboring hybrid cells 120 to 123 can be implemented by wiring within each 102, without passing through a wiring area outside of the block, enabling high-speed operation.
In other words, the RLB (programmable logic device) of this embodying example enables the configuration of cells that are similar to various different LUTs, such as one 4-LUT (see
As described above, various difference circuits can be configured as necessary with one programmable logic device, by setting the input-output signals and logic pattern in the RLB, but the present invention doesn't provide just such an RLB and programmable logic device; it can also provide an application specific integrated circuit (ASIC) or structured ASIC.
In other words, it is possible to facilitate the provision of an ASIC (or structured ASIC) having an area efficiency that is even more improved over that of a programmable logic device, by configuring circuitry that fixes the input-output signals and logic pattern in each RLB, in other words, by providing wiring corresponding to the circuitry necessary for wiring the input signals, and also by erasing the memory bits (M0 to M19) that determine the circuit functions then fixing them to levels corresponding to the input signals and the data of the memory bits (M0 to M19).
All the logic patterns that can be represented by one hybrid cell are shown in Table 1.
In other words, when CF is 1, the switching of AS enables the representation of a total of 16 patterns with two variables, 206 out of 256 different output logic patterns with three variables, or 446 out of 65536 different output logic patterns with four variables. Thus just about any circuit can be configured by one hybrid cell if there are three variables, by way of example, and the use of four variables makes it possible to create configurations with a single hybrid cell.
Furthermore, the use of carry paths and EXOR circuits makes it possible to represent multi-input logic with a plurality of hybrid cells.
Table 2 is a truth table and Table 3 shows examples of logic patterns and inputs for when devices are represented by one hybrid cell as shown in
The array of logic patterns in Table 3 can be represented by four memory bits M0 to M3 (SRAM[3:0]), based on a truth table such as that of Table 2. Note that the values of these memory bits M0 to M3 are written to the memory bits M0 to M3 in the hybrid cell of
In this case, flash electrically erasable and programmable read only memory (EEPROM) or static random access memory (SRAM) could be used as the memory, by way of example. Note that the writing of logic patterns (data) to each memory bit can be done by applying any of various different methods that are known in the art. For example, data setting (writing) with respect to volatile memory such as SRAM can be used after initialization at power on has ended, or the data could be set beforehand into non-volatile memory such as an EEPROM before the device is used in practice.
Examples of circuits configured by applying an example of an RLB in accordance with the present invention are shown in
Eight LUTs are necessary when configuring a 4-bit adder/subtractor from LUTs of a prior-art FPGA (which is assumed to use a 4-input, 1-output LUT for each RLB), but this embodying example ensures that a 4-bit adder/subtractor can be configured with just one RLB 102 (the combination logic portion 102a), as shown by way of example in
Similarly, four LUTs (RLBs) are necessary when allocating LUTs of a prior-art FPGA to a four 2-input, 1-output MUX circuit, but this embodying example ensures that the same can be configured of just one RLB 102, as shown by way of example in
In this manner, the reconfigurable logic block (RLB) of this embodying example makes it possible to configure devices such as the 4-bit adder/subtractor of
A further example of a circuit configured by applying an example of an RLB in accordance with the present invention are shown in
As shown in
In this case, each of the BTDs 301 and 302 can be configured of half of an RLB 102 (0.5×2=1×RLB) and each of the TGENs 303 and 304 can be configured of one-quarter of an RLB 102 (0.25×2=0.5×RLB). In addition, each of the partial-product creation circuits 305, 306, and 307 can be configured of one CBL 102 (1×3=3×RLB) and each of the 4-bit adder/subtractor circuits 308, 309, 310, and 311 can also be configured of one CBL 102 (1×4=4×RLB).
Thus the 4-bit multiplier 300 of
In this manner, the area efficiency can be improved not only by using LUTs for the combination combination logic portions as far as possible, but also by using them as cells in which the gate architecture thereof is employed (equivalent to the other logic circuit shown in
A graph of comparisons of the numbers of transistors used when configuring signed multipliers is shown in
As is clear from
The description above was based on the reconfigurable logic block (RLB) shown in
The present invention is described further below, with respect to other examples of RLBs that have input-output configurations that differ from those of
A block diagram of another example of the input-output configuration in an RLB in accordance with the present invention is shown in
The RLB 102 shown in
In other words, it is clear from a comparison of
A block diagram of the configuration of the RLB of
As shown in
A logical circuit diagram of another example of the configuration of a hybrid cell in an RLB in accordance with the present invention is shown in
In
A logical circuit diagram of the configuration of another embodying example of an RLB in accordance with the present invention is shown in
As shown in
This configures the combination logic portion 102a of an RLB (in other words, the RLB 102) that has a total of 21 inputs which are three W inputs W0 to W2, four X inputs X0 to X3, four Y inputs Y0 to Y3, four Z inputs Z0 to Z3, four Cin inputs Cin0 to Cin3, one AS input AS, and one Carry-in input Carry-in; a total of 11 outputs which are three E outputs E0 to E2, four S outputs S0 to S3, and four Cout outputs Cout0 to Cout3; and 17 memory bits M0 to M16.
In other words, to configure the four MUXes from the combination logic portion 102a shown in
In other words, to configure one 4-LUT from the combination logic portion 102a shown in
Note that the combination logic portion 102a shown in
Thus, since the RLBs described with reference to FIGS. 18 to 25B can use just one type of hybrid cell (HC), the circuit configurations thereof are simplified and it is also possible to regulate the input patterns and add a wider range of MUX functions.
The present invention enables the provision of a programmable logic device that can maintain the high area efficiency of the chip, regardless of the circuitry configured therein, and aim for both a higher speed and a lower low power consumption.
The present invention can be applied to a reconfigurable logic block, or a programmable logic device provided with such a reconfigurable logic block, that can create various different circuits as necessary by the setting of input-output signals and the logic pattern thereof. Furthermore, the present invention can also be applied to ASICs (or structured ASICs) by configuring circuitry which fixes the input-output signals and logic pattern for each reconfigurable logic block.
Many different embodiments of the present invention may be constructed without departing from the scope of the present invention, and it should be understood that the present invention is not limited to the specific embodiments described in this specification, except as defined in the appended claims.
Number | Date | Country | Kind |
---|---|---|---|
2005-330268 | Nov 2005 | JP | national |
2006-166387 | Jun 2006 | JP | national |