TECHNICAL FIELD
The present invention relates to a reconfigurable circuit with non-volatile resistive switches, and the method for using the reconfigurable circuit.
BACKGROUND ART
A typical semiconductor integrated circuit (IC) is constructed by transistors build on a semiconductor substrate and upper layer wires used to connect the transistors. The patterns of the transistors and wires are determined in a design stage of the IC. Interconnections between the transistors and wires cannot be changed after fabrication. In order to improve flexibility of IC, field-programmable gate arrays (FPGAs) have been proposed and developed. In FPGAs, configuration data including operation and interconnection information is stored in memories, so that different logic operations and interconnections can be realized by configuring the memories after fabrication according to requirements of end users. Interconnections within FPGA can be altered by controlling ON-and-OFF of switches in a routing multiplexer (MUX) or routing fabrics arranged in the FPGA in accordance with the interconnection information stored in the memories.
The relatively large energy consumption of FPGAs limits integration of commercial FPGAs into IoT (Internet of Things) devices. In most of commercial FPGAs, SRAM (Static Random Access Memory) is used to store the configuration data. Typically, each memory cell of SRAM is composed of six transistors and each modern FPGA chip has more than 10M (ten-million) memory cells of SRAM. This causes extremely large area overhead, cost, and energy consumption in FPGAs. In this Description, FPGAs which use SRAM as memories storing configuration data are referred to as SRAM-based FPGAs or SRAM FPGAs.
Recently, FPAGs with non-volatile resistive switches (NVRSs) such as Nanobridge® (NB) integrated between the wires upon a transistor layer have been proposed to overcome the problems of SRAM-based FPGAs and achieve small area overhead [NPL 1, NPL 2]. FPGAs with NBs are referred to as NBFPGAs (Nanobridge® field programmable gate arrays). Non-volatility of NBs also contributes to zero standby power consumption. An example of NVRS which can applied to a memory portion of LSI (Large-Scale Integration) is disclosed in [PTL 1].
FIG. 1 illustrates a typical configuration of NBFPGA. A large number of cells 101 constitute a cell array of NBFPGA. Each cell 101 includes routing MUX 102 and logic block 103. In this example, logic block 103 includes two look-up tables (LUTs) 104, two D-type flip-flops 105 and two selectors 106. Routing MUX 102 includes a plurality of input and output lines arranged in a lattice manner which are connected to logic block 103 and adjacent cells 101. Data routing switch 107 is arranged at each cross-point or intersection between the input lines and the output lines. Therefore, routing MUX 102 has a crossbar structure. In FIG. 1, enlarged view 110 illustrates four data routing switches 107 or NBs which are arranged at cross-points between input lines IN0, IN1 and output lines OUT0, OUT1. Each data routing switch 107 is composed of two NVRSs S11, S12 serially connected with each other. One NVRS S11 is coupled to the input line and the other NVRS S12 is coupled to the output line. When both NVRSs S11, S12 in one switch 107 of the crossbar are in ON-state or set state in which NVRS has lower resistance, switch 107 electrically connects the input line to the output line. A signal can be transmitted from the input line to the output line. On the other hand, both NVRSs S11, S12 in switch 107 are in OFF-state or reset state in which NVRS has higher resistance, switch 107 does not electrically connect the input line to the output line. No signal can transmit from the input line to the output line. Two NVRSs S11, S12 constituting each switch 107 are used for only data routing in NBFPGA.
CITATION LIST
Patent Literature
- PTL 1: WO 2015/198573 A1
- PTL 2: JP 2013-77681A
- PTL 3: U.S. Pat. No. 7,486,111 B2
Non Patent Literature
- NPL 1: Munehiro Tada, et al., Improved OFF-State Reliability of Nonvolatile Resistive Switch with Low Programming Voltage, IEEE TRANSACTIONS ON ELECTRON DEVICES, Vol. 59, No. 9, pp. 2357-2362, SEPTEMBER 2012.
- NPL 2: Makoto Miyamura, et al., Low-power programmable-logic cell arrays using nonvolatile complementary atom switch, ISQED 2014, pp. 330-334.
- NPL 3: Xu Bai et al., Architecture of Reconfigurable-Logic Cell Array with Atom Switch: Cluster Size & Routing Fabrics, FPGA 2015, pp. 269.
SUMMARY OF INVENTION
Technical Problem
In NBFPGA, a NB crossbar requires more than 60% of the total area of the NBFPGA and this somewhat impairs flexibility of NBFPGA. The relatively low flexibility of NBFPGA still limits its wide applications.
An exemplary object of the present invention is to provide a reconfigurable circuit which has flexibility higher than NBFPGA and can function as both an FPGA and a memory.
Another exemplary object of the present invention is to provide a method for using a reconfigurable circuit which can function as both an FPGA and a memory.
Solution to Problem
According to an exemplary aspect of the present invention, a reconfigurable circuit includes: a first line; a first switch element disposed between the first line and a first power source line of first voltage; a second line; a second switch element disposed between the second line and a second power source line of second voltage which is different from the first voltage; and a resistive switch assembly disposed between the first line and the second line, the resistive switch assembly including a first NRVS (non-volatile resistive switch) and a second NVRS whose first end is coupled to a first end of the first NVRS, wherein a second end of the first NVRS is coupled to the first line, and a second end of the second NVRS is coupled to the second line.
According to another exemplary aspect of the present invention, provided is a method for using reconfigurable circuit comprising a first line, a second line, and a resistive switch assembly disposed between the first line and the second line, wherein the resistive switch assembly includes a first NVRS and a second NVRS whose first end is coupled to a first end of the first NVRS, a second end of the first NVRS is coupled to the first line, and a second end of the second NVRS is coupled the second line. The method includes: using the first NVRS and the second NVRS as a data routing switch between the first line and the second line, by selectively making one of a first state in which the first NVRS and the second NVRS are in ON-state, and a second state in which the first NVRS and the second NVRS are in OFF-state; and using the first NVRS and the second NVRS as a memory element, by making one of the first NVRS and the second NVRS the ON-state and the other the OFF-state.
BRIEF DESCRIPTION OF DRAWINGS
FIG. 1 is a schematic view illustrating an exemplary structure of NBFPGA.
FIG. 2 is a circuit diagram illustrating a reconfigurable circuit according to a first exemplary embodiment of the present invention.
FIGS. 3A to 3D are circuit diagrams illustrating an example of operation of the reconfigurable circuit.
FIG. 4 is a graph showing energy efficiency and flexibility of various semiconductor devices.
FIG. 5 shows sectional views of an example of a non-volatile resistive element.
FIG. 6 is a circuit diagram illustrating another reconfigurable circuit according to the first exemplary embodiment.
FIG. 7 shows timing charts for programming the reconfigurable circuit shown in FIG. 6.
FIG. 8 is a circuit diagram illustrating a reconfigurable circuit according to a second exemplary embodiment.
FIGS. 9A and 9B are circuit diagrams illustrating an example of operation of the reconfigurable circuit shown in FIG. 8.
FIG. 10 is a circuit diagram of a reconfigurable circuit with a program circuit.
FIG. 11 is a circuit diagram of a reconfigurable circuit with a program circuit and a serial read circuit.
FIG. 12 is a circuit diagram of a reconfigurable circuit with a program circuit and a parallel read circuit.
FIG. 13 is a circuit diagram illustrating a reconfigurable circuit according to a third exemplary embodiment.
FIGS. 14A and 14B are views explaining flexible configuration of NBPLMD (Nanobridge® programmable logic memory device) according to a fourth exemplary embodiment.
FIG. 15 is a circuit diagram illustrating a cell of NBPLMD.
DESCRIPTION OF EMBODIMENT
Exemplary embodiments of the present invention will be next described with reference to the accompanying drawings.
First Exemplary Embodiment
FIG. 2 illustrates a reconfigurable circuit according to a first exemplary embodiment of the present invention. The reconfigurable circuit includes: first line L1; first switch element SW1 disposed between first line L1 and a first power source line of voltage V1; second line L2; second switch element SW2 disposed between second line L2 and a second power source line of voltage V2; and resistive switch assembly 111 disposed between first line L and second line L2. The voltages V1 and V2 are different from each other. Resistive switch assembly 111 includes: first NVRS (non-volatile resistive switch) S1; and second NVRS S2 whose first end is coupled to the first end of the first NVRS S1. The second end of first NVRS S1 is coupled to first line L1, and the second end of second NVRS S2 is coupled to second line L2. For the purpose of explanation, terminals T1 and T2 are illustrated at ends of first line L1 and second line L2, respectively, in FIG. 2. Terminal T3 is connected to the coupling part or node between first NVRS S1 and second NVRS S2. NVRSs S1, S2 can be separately and arbitrarily programmed to ON-state, i.e., lower resistance state, or OFF-state, i.e., higher resistance state, by applying control voltages among first line L1, second line L2, and the coupling part. A node separated from both NVRSs S1, S2 may be provided as the coupling part of the first end of first NVRS S1 and the first end of second NVRS S2. Alternatively, a portion of one of first NVRS S1 and second NVRS S2 may function as the coupling part.
In one example of the present exemplary embodiment, switch elements SW1, SW2 may be MOS (metal-oxide-semiconductor) transistors, and voltages V1, V2 may be power source voltage VDD and ground potential GND, respectively.
In the reconfigurable circuit shown in FIG. 2, resistive switch assembly 111 in which two NVRSs S1, S2 are serially connected via the node is disposed between first line L1 and second line L2. Therefore, resistive switch assembly 111 may constitute an one-input-two-output NB (Nanobridge®). The reconfigurable circuit of the present exemplary embodiment uses the NB to implement both a data routing switch and a memory cell. The data routing switch realized by the reconfigurable circuit may be used for path routing in FPGA (field programmable gate array). Here, a mode in which the reconfigure circuit is used as a data routing switch is called data routing mode, and another mode in which the circuit is used as a memory cell is called memory mode.
In the data routing mode, both switch elements SW1, SW2 are turned off. NVRS s S1, S2 are configured to control data routing between terminals T1, T2, i.e., between first line L and second line L2. When enabling data routing between terminals T1, T2, both NVRSs S1, S2 are programmed to or made ON-state. When disabling data routing between terminals T1, T2, both NVRSs S1, S2 are made OFF-state. The two serially-connected NVRSs can contribute to low programming voltage and high OFF-state reliability, because voltage stress is divided into half for each NVRS [NPL 1, NPL 2].
In the memory mode, one of NVRSs S1, S2 is made ON-state and the other OFF-state to store data. For example, if NVRS S1 is turned on and NVRS S2 is turned off, data “1” is stored. In read operation, both switch elements SW1, SW2 are turned on to apply voltages V1, V2 to lines L1, L2, respectively. As a result, memory output can be read from terminal T3. If the memory stores “1,” the voltage read out from terminal T3 is a value close to voltage V1. When NVRS S1 is turned off and NVRS S2 is turned on, data “0” is stored and voltage close to V2 may be read out. Voltage stress on either NVRS S1 or S2 is twice larger than that in the data routing mode, however, extremely short read time makes no reliability problem happen.
FIGS. 3A to 3D illustrate an example of operation of the reconfigurable circuit of this exemplary embodiment. In FIGS. 3A to 3D, it is assumed that switch elements SW1, SW2 are pMOS transistor M1 and nMOS transistor M2, respectively, and voltages V1, V2 are VDD and GND, respectively. Terminals T1 and T2 are input terminal IN and output terminal OUT for data routing, respectively. Terminal T3 is memory output terminal MOUT. In the data routing mode, a cutoff voltage and ground potential are applied to the gates of pMOS transistor M1 and nMOS transistor M2 to turn off them. As shown in FIG. 3A, when both NVRSs S1 and S2 are turned on (i.e., in ON-state), a signal can transmit from terminal IN to terminal OUT through NVRSs S1, S2. As shown in FIG. 3B, when both NVRSs S1 and S2 are turned off (i.e., in OFF-state), the path from terminal IN to terminal OFF is cut off. In the memory mode, data “1” is stored by turning on NVRS S1 and turning off NVRS S2, and data “0” is stored by turning off NVRS S1 and turning on NVRS S2. When data is read out, both transistors M1, M2 are turned on. FIG. 3C illustrates reading-out of data “1” in which voltage close to VDD appears at terminal MOUT. Fig. D illustrates reading-out of data “0” in which voltage close to GND appears at terminal MOUT.
As described above, the present exemplary embodiment provides a novel reconfigurable circuit to implement both FPGA and a non-volatile memory using a single device for flexibility improvement. We name the novel reconfigurable circuit NBPLMD (Nanobridge® programmable logic memory device). FIG. 4 illustrates relationship between energy efficiency and flexibility of various semiconductor devices. As shown in FIG. 4, ASIC (Application Specific Integrated Circuit) has high energy efficiency and low flexibility while a CPU (Central Processing Unit) has low energy efficiency and high flexibility. SRAM FPGA has middle energy efficiency and middle flexibility. NBFPGA is an improved version in energy efficiency of SRAM FPGA. Our NBPLMD has flexibility higher than NBFPGA. Therefore, NBPLMD has well-balanced characteristics between energy efficiency and flexibility.
Next, NVRS which can be used in the reconfigurable circuit will be described. As described above, NVRS can be altered between ON-state (i.e., set state) and OFF-state (i.e., reset state). In FIG. 5, two NVRSs 121, 122 are illustrated, NVRS 121 is in OFF-state, and NVRS 122 is in ON-state. NVRS includes: active electrode 123 made of, for example, copper (Cu); inert electrode 124 made of, for example, ruthenium (Ru); and solid-electrolyte 125 sandwiched between active electrode 123 and inert electrode 124.
In the OFF-state, active electrode 123 and inert electrode 124 are electrically separated by solid-electrolyte 125, and the electric resistance between active electrode 123 and inert electrode 124 is very high. When the voltage of inert electrode 124 is fixed to zero and a positive voltage higher than a threshold voltage is applied to active electrode 123 of NVRS 121 in the OFF-state, metal ions are attracted by the electric field and supplied to solid-electrolyte 125. Then, metal bridge 126 is formed between active electrode 123 and inert electrode 124, and both electrode 123, 124 are electrically short-circuited by metal bridge 126. The resistance between active electrode 123 and inert electrode 124 is remarkably reduced. This operation making NVRS ON-state is referred to set operation. When the voltage of inert electrode 124 is fixed to zero and a negative voltage whose absolute value is larger than another threshold voltage is applied to active electrode 123 of NVRS 122 in the ON-state, metal ions in metal bridge 126 move in a direction of active electrode 123, and metal bridge 126 then disappears. The resistance between active electrode 123 and inert electrode 124 increases and returns the initial value, i.e., the value at the OFF-state. This operation making NVRS OFF-state is referred to reset operation. NVRS has high ON/OFF resistance ratio (typically, >105) between the ON- and OFF-states. Small area overhead and high logic density can be achieved by replacing CMOS (Complementary MOS) switch with NVRS.
Two NVRSs are serially connected to constitute resistive switch assembly 111 in the present exemplary embodiment. Since each NVRS has active electrode 123 and inert electrode 124, there are four ways to serially connect two NVRSs. In order to improve reliability of the NVRSs, especially in the data routing mode, it preferable to connect the active electrodes of both NVRSs to each other, or connect the inert active electrodes of both NVRSs to each other. Two NVRSs in which the active electrodes of both NVRSs are connected to each other or the inert electrodes are connected to each other are called complementary NVRSs. When the inert electrodes of two NVRSs are connected each other, the two NVRSs can share a single inert electrode. In such a case, the coupling part of the two NVRSs is the shared inert electrode. Although the two NVRSs can similarly share a single active electrode, it is preferable to share the inert electrode in comparison with case of the shared active electrode from a viewpoint of compatibility with semiconductor fabrication processes.
FIG. 6 illustrates an example of the reconfiguration circuit with the shared inert electrode. Compared to the reconfigurable circuit shown in FIG. 2, the reconfigurable circuit shown in FIG. 6 differs in that NVRSs S1, S2 share inert electrode 124, and that circuits for programming and reading NVRSs S1, S2 are added. The program circuit is used both for programming the NVRSs for the data routing mode and for writing data to the NVRSs for the memory mode. As switch elements SW1, SW2, pMOS transistor M1 and nMOS transistor M2 are used, respectively. Memory enable signal MEN which is active during reading operation is supplied to the reconfigurable circuit and invertor INV generates reversed memory enable signal MEN′ based on signal MEN. Shared inert electrode 124 functions as the coupling part between NVRSs S1, S2. Program drivers PX, PY are connected to lines L1, L2, respectively, and program driver C is connected to the coupling part of NVRSs S1, S2. The coupling part is also connected to memory output terminal MOUT through transmission gate TG to which signals MEN, MEN′ are supplied. Transistors M1, M2 are configured to turn on when memory enable signal MEN is asserted. Transmission gate TG is also turned on when memory enable signal MEN is asserted. The operation of the circuit shown in FIG. 6 in the data routing mode and the memory mode are the same as those of the circuit shown in FIG. 2.
FIGS. 7A to 7D illustrate programming of NVRSs S1, S2 in the reconfigurable circuit shown in FIG. 6. Here, VSET is a voltage enough to change the state of NVRS from OFF-state to ON-state while VRESET is a voltage enough to change the state of NVRS from ON-state to OFF-state. It should be noted that application of voltage of VSET/2, i.e., half of VSET, does not cause the state change of NVRS, and application of VRESET/2 does not cause the change of NVRS. In order to simplify the programming operation, it is preferable that magnitude of VSET is equal to that of VRESET. Voltages VPX, VPY, VC are output voltages of program drivers PX, PY, C, respectively.
FIG. 7A illustrates the set operation for NVRS S1. In the initial stage, each of VPX, VPY, VC is maintained at level of VSET/2. Then, VC is changed to the ground potential GND and VPY is subsequently changed to VSET whereby the state of NVRS S1 shifts into the ON-state. After the transition to the ON-state, VPY is changed back to VSET/2 and VC is subsequently changed to VSET/2. VPX is unchanged throughout the set operation of NVRS S1. FIG. 7B illustrates the set operation for NVRS S2. The set operation of NVRS S2 is similar to the set operation of NVRS S1, but VPX is changed instead of VPY.
FIG. 7C illustrates the reset operation for NVRS S1. In the initial stage, each of VPX, VPY, VC is maintained at level of VRESET/2. Then, VC is changed to VRESET and VPY is subsequently changed to the ground potential GND whereby the state of NVRS S1 shifts into the OFF-state. After the transition to the OFF-state, VPY is changed back to VRESET/2 and VC subsequently is changed VRESET/2. VPX is unchanged throughout the reset operation of NVRS S1. FIG. 7D illustrates the reset operation for NVRS S2. The reset operation of NVRS S2 is similar to the reset operation of NVRS S1, but VPX is changed instead of VPY.
Second Exemplary Embodiment
Next, applications of the above-mentioned reconfigurable circuit will be described. FIG. 8 illustrates the reconfigurable circuit according to the second exemplary embodiment in which a plurality of first lines and a plurality of second lines are arranged and the resistive switch assembly including two NVRSs serially connected to each other is disposed at each cross-point between the first lines and the second lines. In the drawing, the first lines extend in the vertical direction while the second lines extend in the horizontal direction. In the present embodiment too, each resistive switch assembly is a one-input-two-output NB (Nonobridge®) which is used both for a data routing switch between the first line and the second line, and for a memory cell.
In the example shown in FIG. 8, two first or vertical lines LV0, LV1 and two second or horizontal lines LH0, LH1 are arranged in a lattice manner and a resistive switch assembly or Nonobridge® is arranged at each cross-point between vertical lines LV0, LV1 and horizontal lines LH0, LH1, thereby constituting a 2×2 NB crossbar. Total eight NVRSs S1 to S8 are contained in the circuit shown in FIG. 8. Vertical lines LV0, LV1 are coupled to power source line VDD via pMOS transistors M11, M12, respectively. Horizontal lines LH0, LH1 are coupled to ground source line GND via nMOS transistors M21, M22, respectively. This NB crossbar can implement both a routing multiplexer (MUX) and a memory array and has different operational modes, data routing mode and memory mode. FIG. 9A and FIG. 9B illustrate the data routing mode and the memory mode of the circuit shown in FIG. 8, respectively.
In the data routing mode, transistors M11, M12, M21, M22 are cut off. It is assumed that ends of vertical lines LV0, LV1 are input ends IN0, IN1, respectively, and ends of horizontal lines LH0, LH1 are output ends OUT1, OUT2, respectively. As shown in FIG. 9A, to implement a data transfer path from IN0 to OUT0 and another data transfer path from IN1 to OUT1, NVRSs S3, S4, S7, S8 are made ON-state while the NVRSs S1, S2, S5, S6 are made OFF-state. The two NVRSs at the same cross-point have the same ON/OFF state.
In memory mode, one of two NVRSs at each cross-point is made ON-state and the other OFF-state to store logic value “1” or “0.” In the example illustrated in FIG. 9B, NVRSs S1, S2 are made ON and OFF, respectively, to store logic value “1.” NVRSs S3, S4 are made OFF and ON, respectively, to store logic value “0.” NVRSs S5, S6 are similarly configured to store logic value “1” and NVRSs S7, S8 are configured to store logic value “0.” When the stored values of the memory array are read, transistors M11, M12, M21, M22 are turned on. Then, the voltage of terminal T3 which is connected to the coupling part between the two NVRSs at each cross-point indicates the stored logic value. In this case, when the stored value is “0,” the voltage of terminal T3 approaches to GND while the voltage of terminal T3 approached to VDD when the stored value is “1.”
Programming of NVRSs in the reconfigurable circuit shown in FIG. 8 will be described. FIG. 10 illustrates a 2×2 NB crossbar in the related art which has only data routing function [NPL 2, PTL 1]. The circuit shown in FIG. 10 is equipped with a program circuit. Portions of the program circuit are surrounded by dashed lines in the drawing. Although the program circuit is used for separately programming NVRSs, the circuit shown in FIG. 10 does not implement a memory array. A control transistor is provided for each cross-point between the vertical lines and the horizontal lines. The source of the control transistor is connected to the coupling part between the two NVRSs at the same cross-point. In FIG. 10, nMOS transistors Tr4 to Tr7 are the control transistors at the respective cross-points. Diodes or the like may be used instead of the control transistors. Vertical lines LV0, LV1 are coupled to an output of a common column program driver PY via nMOS transistors Tr0, Tr1, respectively, and horizontal lines LH0, LH1 are coupled to an output of common row program driver PX via nMOS transistors Tr2, Tr3, respectively. The line connecting the output of column program driver PY to nMOS transistors Tr0, Tr1 is column program line LPY, and the line connecting the output of row program driver PX to nMOS transistors Tr2, Tr3 is row program line LPX. The drains of the control transistors on the same column are connected with each other, and then coupled to common mid program driver C via one of nMOS transistors Tr8, Tr9 which are provided for the respective columns. The line connecting the output of mid program driver C to nMOS transistors Tr8, Tr9 is mid program line LC. Row address signals X0, X1 and column address signals Y0, Y1 control nMOS transistors Tr0 to Tr9 for configuration of the NB crossbar.
In order to realize the novel NB crossbar according to the second exemplary embodiment, which has both data routing function and memory function, we can add read circuits to the circuit of the related art shown in FIG. 10. FIG. 11 illustrates the reconfigurable circuit, i.e., NB crossbar, according to the second exemplary embodiment with a serial read circuit and the program circuit. The portions of the serial read circuit are surrounded by dashed-and-dotted lines while the portions of the program circuit are surrounded by dashed lines in the drawing.
In the example shown in FIG. 11, memory enable signal MEN, which is in High level when asserted, is supplied to the read circuit, and its inverse signal MEN′ is generated by inverter INV. Power supply voltage VDD is applied to column program line Lpy via pMOS transistor Tr11 controlled by signal MEN′. Ground potential GND is applied to row program line LPX via nMOS transistor Tr12 controlled by signal MEN. Since the memory value is read from the coupling part of the two NVRSs of the same cross-point, the memory value is transferred to mid program line LC via the corresponding control transistor and one of nMOS transistors Tr8, Tr9. In order to supply the memory value to an external circuit, the mid program line is connected to buffer BUF via transmission gate TG controlled by signals MEN and MEN′. The output of buffer BUF is connected to memory output terminal MOUT.
For example, when data stored in the NVRSs at the cross-point of vertical line LV0 and horizontal line LH0 is read, it is necessary to set signal MEN as High, addresses X0, Y0 as High, and addresses X1, Y1 as low. Transistor Tr0 is turned on to apply power supply voltage VDD to vertical line LV0, and transistor Tr2 is turned on to apply ground potential GND to horizontal line LH0. Transistors Tr4, Tr8 are then turned on to output the data stored in the NVRSs at the target cross-point.
Ten transistors Tr0 to Tr9 constitute the program circuit shown in FIG. 11 and these transistors Tr0 to Tr9 also engage in the read operation. Additional components for the serial read circuit is only two transistors Tr11, Tr12, one invertor INV, one transmission gate TG and one buffer BUF. This leads to very small area overhead of the novel NB crossbar with both routing switch function and memory function compared with the NB crossbar of the related art which has only the routing switch function.
The NB crossbar shown in FIG. 11 includes the serial read circuit. When a high memory read rate is required, the serial read circuit can be replaced with a parallel read circuit. FIG. 12 illustrates a reconfigurable circuit with a program circuit and a parallel read circuit which is modification of the circuit shown in FIG. 11. The circuit shown in FIG. 12 is different from the circuit shown in FIG. 11 only in a parallel read circuit is used instead of the serial read circuit. The portions of the parallel read circuit are surrounded by dashed-and-dotted lines in FIG. 12.
In the parallel read circuit, invertor INV reverses memory enable signal MEN to generate signal MEN′. Vertical lines LV0, LV1 are connected to power source line VDD via pMOS transistors Tr20, Tr21, respectively. Transistors Tr20, Tr21 are controlled by signal MEN′. Ground potential GND is applied to row program line LPX via nMOS transistor Tr12 controlled by signal MEN. Transmission gates TG0, TG1 are provided for the respective columns. The drains of the control transistors on the same column are connected with each other, and then coupled to the corresponding one of transmission gates TG0, TG1. Each of transmission gates TG0, TG1 is controlled by signals MEN, MEN′. The outputs of transmission gates TG0, TG1 are connected memory output terminals MOUT0, MOUT1, via buffers BUF0, BUF1, respectively.
The circuit shown in FIG. 12 can read memory cells on the same row at the same time. When parallel reading is carried out, power source voltage VDD is applied, without using transistor Tr0, Tr1, to vertical lines LV0, LV1 via transistors Tr20, Tr21 controlled by signal MEN′. The memory data is supplied to the transmission gates and buffers for parallel read without using transistors Tr8, Tr9. For example, if the data stored in the NVRSs at the cross-point of vertical line LV0 and horizontal line LH0 and another data stored at the cross-point of vertical lines LV1 and horizontal line LH0 are read simultaneously, it is necessary to set signal MEN as High, address Y0 as High, and address Y1 as low. Signal MEN at High causes voltage VDD to be supplied to both vertical lines LV0, LV1. Ground potential GND is supplied to horizontal line LH0 because transistor Tr2 is turned on by address Y0. Transistors Tr4, Tr5 are turned on by address Y0, so that memory data corresponding to the cross-point of lines LV0, LH0 and another data corresponding to the cross-point of lines LV1, LH0 can be read to memory output terminals MOUT, MOUT1, simultaneously.
In the examples described above, two vertical lines LV0, LV1 and two horizontal lines LH0, LH1 are arranged to constitute a crossbar. However, each of the number of the vertical lines and the number of horizontal lines is not limited to two. Three or more vertical lines can be arranged and three or more horizontal lines can be arranged. The larger scale of the lattice structure of the vertical lines and the horizontal lines further improves flexibility of the reconfigurable circuit.
Third Exemplary Embodiment
The reconfigurable circuit based on the present invention can be also applied to time-multiplexed crossbar or interconnect structures, such as proposed in [PTL 3], in which a plurality of switches are arranged at each of cross-points between horizontal lines and vertical lines and the switches are selected in time-divisional manner such that two or more switches are not simultaneously selected. The time-multiplexed crossbar achieves time-divisional changeover of contexts in FPGA. The selection of the switches is performed by using a pass transistor interposed in each switch. Time control signals are applied to the respective pass transistors at each cross-point. Since the selection using the pass transistor can be rapidly executed, the time-multiplex crossbar configuration provides runtime-changeable data signal routing which improves flexibility of FPGA.
FIG. 13 illustrates an example of a reconfigurable circuit according to a third exemplary embodiment in which a plurality of resistive switch assemblies each comprising two NVRSs serially-connected to each other are arranged at each cross-points between the vertical lines and the horizontal lines. The example shown in FIG. 13 is a modification of the circuit shown in FIG. 12 and is thus equipped with two resistive switch assemblies at each cross-point between two vertical lines LV0, LV1 and two horizontal lines LH0, LH1. However, three or more vertical lines and three or more horizontal lines can be arranged. In addition, although two resistive switch assemblies are arranged at each cross-point, the number of resistive switch assemblies per cross-point between the first lines, i.e., the vertical lines, and the second lines, i.e., the second lines, can be three or more. The multiplicity of contexts which are switched in a time-divisional manner increases as the number of resistive switch assemblies per cross-point increases.
A pass transistor is arranged in each of the resistive switch assemblies such that the pass transistor can interrupt the current flowing through the serially-connected two NVRSs in the resistive switch assembly. In FIG. 13, two resistive switch assemblies arranged at the cross-point of vertical line LV1 and horizontal line LH0, the first assembly including two NVRSs S1a, S2a and pass transistor Tr15a, and the second assembly including two NVRSs S1b, S2b and pass transistor Tr15b. In the first resistive switch assembly, the second ends of NVRSs S1a, S1b are connected to lines LV1, LH0, respectively, and pass transistor Tr15a which is a nMOS transistor is inserted between the first ends of NVRSs S1a, S2a. The source of control transistor Tr5a is connected to the junction between first end of NVRS S2a and pass transistor Tr15a. Similarly, in the second resistive switch assembly, the second ends of NVRSs S1b, S2b are connected to lines LV1, LH0, respectively, and pass transistor Tr15b is inserted between the first ends of NVRSs S1b, S2b. Control transistor Tr5b is connected to the junction between first end of NVRS S2b and pass transistor Tr15b. The drains of control transistors Tr5a, Tr5b are commonly connected to the drains of the other control transistors Tr7a, Tr7b in the same column, and then connected to transistor Tr9 which is controlled by address X1.
Two time control signals CS1, CS2 are supplied to the reconfigurable circuit. Signal CS1 is applied to the gates of pass transistors Tr14a, Tr15a, Tr16a, Tr17a which are included in the first resistive switch assemblies at the respective cross-point. Signal CS2 is applied to the gates of pass transistors Tr14b, Tr15b, Tr16b, Tr17b which are included in the second resistive switch assemblies at the respective cross-point. In addition, AND gate A10 receives time control signal CS1 and address Y0, and the output of AND gate A10 is supplied to the gates of controls transistors Tr4a, Tr5a in the first resistive assemblies on horizontal line VH0. Similarly, AND gate A20 receives time control signal CS2 and address Y0, and the output of AND gate A20 is supplied to the gates of controls transistors Tr4b, Tr5b in the second resistive assemblies on horizontal line VH0. With regard to vertical line VH1, two AND gates A11, A21 are similarly provided and their outputs are supplied to the gates of control transistors Tr6a, Tr7a, Tr6b, Tr7b.
Although the pass transistor is inserted between the first ends of the first NVRS and the second NVRS for each cross-point in the example shown in FIG. 12, the position of the pass transistor is not limited to this. The pass transistor can be disposed at an arbitrary position between the coupling position of the first NVRS to the first line and the coupling position of the second NVRS to the second line. For example, in the case of the cross-point of vertical line LV1 and horizontal line LH0 shown in FIG. 12, pass transistor Tr15a may be inserted between vertical line LV1 and the second end of NVRS S1a. Alternatively, pass transistor Tr15a may be inserted between horizontal line LH0 and the second end of NVRS S2a.
The operation of the reconfigurable circuit shown in FIG. 13 is the same as that of the circuit shown in FIG. 12 except for selection of one of two resistive switch assemblies at each cross-point by time control signals CS1, CS2. When the first resistive switch assemblies or NBs are used for data routing switches or memory cells, time control signal CS1 is activated while time control signal CS2 is kept inactive. On the other hand, if the second resistive switch assemblies are used for data routing switches or memory cells, time control signal CS2 is activated while time control signal CS1 is kept inactive. The programming operation to the NVRSs is also carried out by activating one of time control signals CS1, CS2.
Fourth Exemplary Embodiment
Next, a fourth exemplary embodiment according to the present invention will be explained. As described above, the reconfigurable circuits of the above exemplary embodiments are called as NBPLMD. The present exemplary embodiment explains how to use the novel NBPLMD. FIGS. 14A and 14B illustrate usage of the novel NBPLMD. The NBPLMD has the same structure as the previous NBFPGA shown in FIG. 1, but with the novel NB crossbar which can be used for both a data routing switch and a memory, as disclosed in the above exemplary embodiments. As shown in FIG. 14A, there are three kinds of usage for the NBPLMD. The first one is that the NBPLMD is configured as a complete NBFPGA if a large-sized application is mapped on the NBPLMD. The second one is that the NBPLMD is configured as a complete memory if only data storage is necessary. The third one is that one part of the NBPLMD is configured as NBFPGA and the other part is configured as a memory if both application and memory are necessary simultaneously. The example shown in FIG. 14B illustrates the case where an application can be realized using 25% of the NBPLMD, the other 75% can be used as a programmable ROM (read only memory). The area ratio between the NBFPGA part and the memory part can be arbitrarily set between the ranges of 1:0 and 0:1. Since the data routing mode, i.e., NBFPGA mode, and the memory mode are different only in the state of memory enable signal MEN and data pattern written to the serially connected two NVRSs in each NB, the mode of NBPLMD can be dynamically change between the NBFPGA mode and the memory mode for each block in the NBPLMD during the operation of the NBPLMD.
FIG. 15 illustrates how a large size FPGA or memory can be provided by NBPLMD with a typical architecture. In this example, it is assumed that cluster size, segment length and segment lane are optimized to be 4 as introduced in [NPL 3], and a cell array of 64×64 cells are arranged in NBPLMD. Each cell has four look-up tables (LUTs), therefore totally 64×64×4=16384 LUTs are provided in the FPGA mode of the NBPLMD. As shown in FIG. 15, each cell of NBPLMD has thirty-two (32) horizontal lines LH0 to LH31 and sixty-nine (69) vertical lines LV0 to LV68, therefore a 32×69 NB crossbar is formed per cell. In the memory mode, since 32×69×64×64=9,043,968, a 9-megabits memory is provided by the NBPLMD.
The reconfigurable circuits of the above exemplary embodiments may be used in, for example, mobile phones, IoT (Internet of Things) devices, and so on. A highly flexible PLMD (programmable logic memory device) can be realized by the reconfigurable circuits described above.
It is apparent that the present invention is not limited to the above exemplary embodiments and examples, but may be modified and changed without departing from the scope and sprit of the invention.
REFERENCE SIGNS LIST
111 Resistive switch assembly,
- L1, L2 lines,
- S1, S2 Non-volatile resistive switches (NVRSs),
- T1, T2, T3 Terminals.