The present invention relates to a programmable volatile/non-volatile memory cell, and to a method of reading a programmable non-volatile memory cell.
The nodes 106 and 108 store complementary voltage states Q and
The circuit 100 has advantage of being relatively quick to access during read and write operations. However, a disadvantage is that, as with all volatile memory cells, the stored data is lost if the supply voltage VDD is removed.
Flash memory is an example of a programmable non-volatile memory. A disadvantage with flash memory is that it is relatively slow to access when compared to the SRAM cell of
In many applications there is a need for a programmable memory cell capable of storing non-volatile data, and having increased access speeds.
It is an aim of embodiments of the present invention to at least partially address one or more needs in the prior art.
According to one aspect of the present invention, there is provided a memory device comprising: at least one memory cell comprising: a first transistor coupled between a first storage node and a first resistance switching element programmed to have a first resistance; and a second transistor coupled between a second storage node and a second resistance switching element programmed to have a second resistance, a control terminal of said first transistor being coupled to said second storage node, and a control terminal of said second transistor being coupled to said first storage node; and control circuitry adapted to store a data value at said first and second storage nodes by coupling said first and second storage nodes to a first supply voltage, the data value being determined by the relative resistances of the first and second resistance switching elements. For example, the first transistor is connected by its main current terminals between the first storage node and the first resistance switching element, and the second transistor is connected by its main current terminals between the second storage node and the second resistance switching element.
According to one embodiment, the control circuitry is further adapted to isolate said first and second storage nodes from said first supply voltage after a time delay.
According to another embodiment, memory cell further comprises a third transistor coupled between said first storage node and a first access line; and a fourth transistor coupled between said second storage node and a second access line, wherein said control circuitry is adapted to control said third and fourth transistors to connect said first and second storage nodes to said first and second access lines respectively.
According to another embodiment, the third and fourth transistors are adapted to have a lower threshold voltage than said first and second transistors.
According to another embodiment, said control circuitry is adapted to couple said first and second access lines to a second supply voltage during a standby phase prior to storing said data value at said first and second storage nodes.
According to another embodiment, the first and second resistance switching elements are respectively coupled between said first and second transistors and the second supply voltage. For example, the first resistance switching element comprises a first terminal connected to a main current terminal of the first transistor and a second terminal connected to the second supply voltage, and the second resistance switching element comprises a first terminal connected to a main current terminal of the second transistor and a second terminal connected to the second supply voltage.
According to another embodiment, the memory device further comprises programming circuitry adapted to program the resistances of said first and second resistance switching elements based on input data.
According to another embodiment, the first and second resistance switching elements are one of: oxide resistive elements; conductive bridging elements; phase change elements; programmable metallization elements; spin-torque-transfer elements; and field-induced magnetic switching elements.
According to another embodiment, the first and second resistance switching elements are thermally assisted switching elements, the memory device further comprising heating circuitry arranged to heat said first and second resistance switching elements by passing a current through them.
According to another embodiment, the heating circuitry is adapted to couple a third supply voltage to said first and second storage nodes.
According to another embodiment, the first transistor is the only transistor of a first inverter of said at least one memory cell, and the second transistor is the only transistor of a second inverter of said at least one memory cell.
According to another aspect of the present invention, there is provided a random access memory comprising an array of the above memory devices.
According to another aspect of the present invention, there is provided a field programmable gate array comprising at least one multiplexer comprising an input coupled to at least one of the above memory devices.
According to another aspect of the present invention, there is provided a field programmable gate array comprising: a plurality of configurable logic blocks; and at least one switching block adapted to interconnect said plurality of configurable logic blocks, wherein said at least one switching block comprises the above memory device.
According to another aspect of the present invention, there is provided a method of transferring a data value from non-volatile storage of a memory cell to first and second volatile storage nodes of said memory cell, wherein the memory cell comprises a first transistor coupled between said first storage node and a first resistance switching element programmed to have a first resistance; and a second transistor coupled between said second storage node and a second resistance switching element programmed to have a second resistance, a control terminal of said first transistor being coupled to said second storage node, and a control terminal of said second transistor being coupled to said first storage node, the method comprising: coupling said first and second storage nodes to a first supply voltage, the data value being determined by the relative resistances of the first and second resistance switching elements.
According to one embodiment, the method further comprises, a first time period after coupling said first and second storage nodes to said first supply voltage, the step of isolating said first and second storage nodes from said first supply voltage.
According to another embodiment, coupling said first and second storage nodes to said first supply voltage comprises activating a third transistor coupled between said first storage node and said first supply voltage, and activating a fourth transistor coupled between said second storage node and said first supply voltage.
The foregoing and other purposes, features, aspects and advantages of the invention will become apparent from the following detailed description of embodiments, given by way of illustration and not limitation with reference to the accompanying drawings, in which:
Throughout the figures, like features have been labelled with like reference numerals.
Only those features useful for an understanding of the invention have been illustrated in the figures and will be described in detail in the following. Other aspects, such as the particular applications of the memory cell, have not been described, the memory cell being suitable for use in a wide range of applications.
The memory cell 200 is similar to the SRAM cell 100 of
The resistance switching elements 202 and 204 are any resistive elements switchable between two resistance values. Such elements maintain the programmed resistive state even after a supply voltage is removed. The resistance switching elements 202, 204 are programmed to have opposite values, and the relative values of the elements indicate one binary data value.
For example, the resistance switching elements 202, 204 are based on magnetic tunnelling junctions (MTJs), such as field-induced magnetic switching (FIMS) elements, thermally assisted switching (TAS) elements, STT (spin-torque-transfer) elements, or those of Toggle MRAM. FIMS-MRAM (magnetic random access memory) are for example discussed in more detail in the publication titled “Magnetoresistive random access memory using magnetic tunnel junctions”, S. Tehrani, Proceedings of IEEE, 91(5):3707-714, May 2003. TAS-MRAM are for example discussed in more detail in the publication titled “Thermally Assisted MRAM”, Prejbeanu et al.
Alternatively, the resistance switching elements 202, 204 could be other types of resistance switching memory devices, including those used in programmable metallization cells (PMC), such as oxide resistive RAM (OxRRAM), conductive bridging RAM (CBRAM), or phase change RAM (PCRAM).
Whatever the type of resistance switching element, information is stored by setting one of the elements at a relatively high resistance (Rmax), and the other at a relatively low resistance (Rmin). Each of the resistance switching elements 202, 204 for example has just two resistive states corresponding to the high and low resistances Rmax and Rmin, although the exact values of Rmin and Rmax may vary depending on conditions such as temperature, process variations etc. The non-volatile data value represented by the resistive elements 202, 204 depends on which of the resistive elements is at the resistance Rmax and Rmin, in other words on the relative resistances. The resistance elements 202, 204 are for example selected such that Rmax is always significantly greater than Rmin, for example at least 20 percent greater. In general, the ratio between the resistance Rmax and the resistance Rmin is for example between 1.7 and 5 for an MRAM, or more generally between 1.2 and 10000. In one example, Rmin is in the region of 2.5 k ohms, and Rmax is in the region of 5 k ohms, although many other values are possible.
In the SRAM cell 100 of
The threshold voltages of the PMOS transistors 110, 112 are lower than those of NMOS transistors 102, 104, such that when in the non-conducting state, the current leakage through transistors 110 and 112 is greater than through transistor 102 or 104, thereby keeping the corresponding node 106 or 108 at a voltage high enough to be seen as a high logic level. In other words, the leakage current IoffP flowing through PMOS transistor 110 or 112 when a high voltage is applied to its gate node is greater that the leakage current IoffN flowing through the corresponding NMOS transistor 102 or 104 when a low voltage is applied to its gate node. The particular threshold voltages will depend on the technology used. But as an example, the threshold voltages of PMOS transistors 110, 112 are chosen to be in the range 0.3 to 0.5 V, while the threshold voltages of NMOS transistors 102, 104 are in the range 0.4 to 0.6 V. In any case, the ratio IOffp/IOffn is selected for example to be greater than 25, and preferably greater than 100.
In operation, for reading and writing data to the volatile portion of the memory cell 200, in other words to the storage nodes 106 and 108, the process is the same as for the memory cell 100, and is not affected by the programmed resistance values of the resistance switching elements 202 and 204. Briefly, writing a bit of data to nodes 106, 108 involves applying, while transistors 110 and 112 are turned on, a high or low voltage to bit line BL depending on the data to be stored, and the opposite voltage to bit line BLB. Reading the data from nodes 106 and 108 involves pre-charging the bit lines BL and BLB, and then turning on transistors 110 and 112 and determining which bit line voltage drops first, with the aid of a sense amplifier (not illustrated), which amplifies the voltage difference between the bit lines. Preferably, so as not to slow the read and write operations to the volatile storage nodes and to prevent a bit-flip during a read operation, the value of Rmax is chosen not to be greater than around 5 k ohms, although this value will depend on the particular technology used, and in particular the on resistance of the transistors.
Independently of this normal SRAM operation, the resistance switching elements may be programmed to store non-volatile data, and the memory cell may be controlled to transfer this data, from physical storage determined by the resistive states of elements 202, 204, to electronic storage determined by the voltage states of the storage nodes 106, 108. Once transferred, this data may be read from the SRAM cell in a standard fashion.
Programming of the resistance switching elements 202 and 204 according to one example will now be described with reference to
In the case of thermally assisted switching MRAM, prior to supplying the write current to program each of the resistance switching elements 202, 204, the resistance switching elements are heated by passing a current through them, which aids the transition from one resistive state to another.
According to one example illustrated in
Alternatively or additionally, heat control circuitry 312 is for example provided, which applies to each of the bit lines BL and BLB a voltage, for example equal to or greater than the supply voltage VDD. Then, by activating the transistors 110 and 112, a current will flow from the bit lines BL and BLB through the corresponding resistance switching elements 202, 204 to the ground voltage.
The conductive track 306 is arranged such that the current IWRITE passes by each resistance switching element 202, 204 in opposite directions, one of which corresponds to the magnetic orientation of the pinned plate 402, and the other being the opposite orientation. Thus, a same current IWRITE can be used to program both the resistive states of the resistance switching element 202 and 204 at the same time, one of which is equal to Rmax, and the other to Rmin.
The signals HEAT and/or WL fall low at falling edge 502, thereby activating the transistors 308 and 310 and/or the transistors 110 and 112. This generates a current IHEAT through the resistance switching elements 202 and 204, and after a certain period, the signal IWRITE is asserted, as shown by the rising edge 504 of this signal. In the example of
Next, the signals HEAT and/or WL are brought high again by rising edge 506, such that the heating current IHEAT is stopped, and the resistance switching elements 202, 204 cool in their current resistive state. Then the signal IWRITE is brought low by a falling edge 508, to end the programming process.
The subsequent transitions of the signals in
In one example, the time during which the signals HEAT and/or WL are active between edges 502 and 506 is around 20 ns. Thus a write operation can be achieved in little more than 35 ns. However, the heating and cooling-off times will vary based on factors such as the materials used, their volumes, etc., and also the heat currents that are applied, and thus the above values are given only as approximate examples.
The current IWRITE is for example in the region of 10 mA for programming one value of the data bit, or in the region of −10 mA for programming the opposite value of the data bit, although other values could be used.
The signals on the word line WL and bit lines BL, BLB during a non-volatile to volatile transfer phase will now be described with reference to
In general, the transfer phase comprises applying by the control circuitry 602 a supply voltage to each of the storage nodes 106, 108, via the bit lines BL and BLB. This generates a current through each of the resistance switching elements 202, 204, such that the voltages at nodes 106, 108 will depend on the relative resistances of the elements 202, 204.
Initially, the circuitry 602 applies a high voltage to each of the bit lines BL, BLB, for example at the supply voltage VDD. The bit lines BL and BLB are likely to be close to or at the supply voltage VDD during a standby or read phase prior to the transfer phase, but during such phases they are generally only periodically charged to the supply voltage, and for this reason the voltages of BL and BLB prior to and after the transfer phase have been indicated by dashed lines in
Then, the word line voltage WL is brought low, to activate the transistors 110 and 112.
In both
Alternatively, if starting from the high Q, low
In
As demonstrated by the curves of
The circuit 800 operates in a similar fashion to the circuit 200, except that transistors 810, 812 are activated by a high voltage level on the word line WL, and a low supply voltage, for example at 0 V, will be applied by circuitry 602 of
Each of the cells 200, 800 is also coupled to a corresponding word line WL common to each row of cells, and a conductive track 306 forms a loop passing by each cell and conducting the current IWRITE for writing to the resistance switching elements of each of the memory cells. Each of the lines WL and 306 is controlled by control circuitry 904, which receives input non-volatile data DNVin, and provides the current IWRITE of the corresponding polarity.
The writing of the non-volatile data is for example performed row by row, in two phases. During a first phase, only the resistance switching elements of cells for which a first logic value, such as logic “0”, is to be programmed are heated. Then, when the corresponding write current is applied to the conductive track 306, the resistive states of only the elements that have been heated will be programmed. During the second phase, the resistance switching elements of the other cells, for which the second logic value, for example a logic “1”, is to be programmed are heated. Then, when the corresponding write current is applied to the conductive track 306, again only the resistive states of the elements that have been heated will be programmed.
As indicated by dashed lines in
The example of
As an alternative, a common track 306 could be used for each column, which has the advantage that a row of memory cells can all be programmed in a single programming cycle. Furthermore, given that a current generator provides the current on each track 306, the number current generators would then be reduced to the number of columns rather than the number of rows of the memory.
The multiplexer 1010 also comprises a 3-bit control input 1012, controlling which of the 8 input lines is selected, and an output line 1014, outputting the data of the selected input line.
An advantage of the embodiments of the memory cell described herein is that it is capable of storing not only one bit of volatile data, but additionally one bit of non-volatile data. Furthermore, the programmed non-volatile data can be quickly loaded to the volatile portion of the memory cell in a simple fashion, by application of a voltage to the access lines of the memory cell. This advantageously means that a state programmed in a non-volatile fashion may be quickly loaded (in less than 1 ns), for example upon activation of the memory on power-up or after a sleep period. In the case of an FPGA, this allows a circuit design to be quickly initialised, without the need of loading external data into the device to program memory latches and switches.
According to embodiments described herein, the inverters forming the memory cell are each advantageously implemented by a single transistor, each coupled to the same supply voltage. Thus the memory cell is connected to only one power rail: ground in
Furthermore, in the case that the volatile data in the memory is to be discarded during the standby state and only the non-volatile data is to be maintained, the power to the bit lines can be removed altogether, such that even the leakage current becomes negligible. The power consumption of the memory is thus extremely low during such a standby state.
A further advantage of the use of a single transistor for forming each inverter of the memory cell is that the difference between the resistances Rmin and Rmax of the resistance switching elements 202, 204 can be relatively low and/or the speed of the transfer of the programmed non-volatile data to the volatile portion of the memory cell can be relative quick. For example, with reference to
Furthermore, advantageously the cell is capable of fast (in around 1 ns) write and read operations for the volatile storage portions, which may occur in a normal fashion irrespective of the programmed states of the non-volatile resistive elements. Furthermore, the write time for the non-volatile portion is also relatively fast (in around 35 ns in the case of an MRAM).
A further advantage of the memory cells described herein is that the circuit is compact, comprising only four transistors and two programmable resistors for the storage of one bit of non-volatile data and one bit of volatile data. Furthermore, the non-volatile data may be read without the need of additional transistors in each memory cell.
Furthermore, the resistance switching elements 202, 204 of
Having thus described at least one illustrative embodiment of the invention, various alterations, modifications and improvements will readily occur to those skilled in the art.
For example, it will be apparent to those skilled in the art that, while the invention has been described in relation to a memory array and FPGA, the memory cell described herein could be used in other types of memory devices, such as registers or flip-flops.
It will be apparent to those skilled in the art that the ground voltage described herein may be at 0 V, or more generally at any supply voltage VSS, that could be different from 0 V.
Furthermore, it will be apparent to those skilled in the art that the variations in the threshold voltages between the transistors 102, 104 and the transistors 110, 112 of the four-transistor memory cell 200 of
Furthermore, while the various embodiments have been described in relation to MOS transistors, it will be apparent to those skilled in the art that the invention could be equally applied to other transistor technologies, such as bipolar transistors.
Furthermore, the features described in relation to the various embodiments could be combined in alternative embodiments in any combination.
Number | Date | Country | Kind |
---|---|---|---|
1150402 | Jan 2011 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/EP2012/050767 | 1/19/2012 | WO | 00 | 11/21/2013 |