Embodiments relate to a semiconductor device, and more particularly, to a semiconductor device which enables fast execution of a program speed, a semiconductor system having the same, and a method of programming a memory cell.
Memories are divided into volatile memories and non-volatile memories. Dynamic random access memories (DRAMs) and static random access memories (SRAMs) are volatile memories, while and flash memories, resistive memories, and phase change memories are non-volatile memories. The resistive memory uses a resistance value of a memory device to store one or more bits of data.
An entire block of resistive memory cells cannot be programmed or erased simultaneously, as this would require too large a drive current. Accordingly, a block of such memory cells is programmed sequentially by applying a series of program pulses to respective cells. However, this results in a long programming time.
Embodiments are therefore directed to memory device, a system having the same, and a method of programming a memory cell, which substantially overcome one or more of the problems of the related art.
It is therefore a feature of an embodiment to provide a memory device that enables fast execution of a program speed, a semiconductor system having the same, and a method of programming a memory cell.
It is therefore another feature of an embodiment to provide a memory device that simultaneously activates more than one memory cell, a semiconductor system having the same, and a method of programming a memory cell.
It is yet another feature of an embodiment to provide a memory device that determines a pass/fail status on an individual cell basis, a semiconductor system having the same, and a method of programming a memory cell.
At least one of the above and other features and advantages may be realized by providing a memory device, including an array of resistance change memory cells divided into a first memory block including a first selected memory cell of a first plurality of memory cells and a second memory block including a second selected memory cell of a second plurality of memory cells, and sensing and writing circuitry configured to simultaneously activate a line connected with the first and second selected memory cells, to write the first and second selected memory cells with write data by applying a level-controlled write signal to the first and second selected memory cells, to perform a verify-read operation on the first and second selected memory cells, and, when at least one of the first and second selected memory cells has a programmed state that is not equal to the write data, to iteratively apply the level-controlled write signal to the at least one of the first and second selected memory cells not having a programmed state equal to the write data until the verify-read operation indicates respective programmed states for the first and second selected memory cells are equal to the write data.
To iteratively apply the level-controlled write signal, the sensing and writing circuitry may be configured to iteratively alter at least one of a magnitude, a width, and a slope of the level-controlled write signal. The sensing and writing circuitry may be configured to iteratively increase at least one of a magnitude, a width, and a slope of the level-controlled write signal.
In the memory device, a plurality of blocks may form a tile, adjacent tiles sharing sensing and writing circuitry.
The sensing and writing circuitry may be configured to iteratively apply the level-controlled write signal to a third selected memory cell of a third plurality of memory cells not having a programmed state equal to the write data. The third selected memory cell may be in a same block as one of the first and second memory blocks having a memory cell having a programmed state equal to the write data and the sensing and writing circuitry may be configured to simultaneously activate a line connected with the third selected memory cell and one of the first and second memory blocks having a memory cell not having a programmed state equal to the write data. The third selected memory cell may be in a different block than either one of the first and second memory blocks and the sensing and writing circuitry may be configured to simultaneously activate a line connected with the first to third selected memory cells. One of the first and second memory blocks may have a memory cell having a programmed state equal to the write data and the sensing and writing circuitry may be configured to simultaneously activate a line connected with the third selected memory cell and one of the first and second memory blocks having a memory cell not having a programmed state equal to the write data.
In each iteration, the sensing and writing circuitry may be configured to use an available voltage amount for each simultaneous activation of lines.
The resistance change memory cell may be a phase change memory cell. The phase change memory cell may include a diode.
The sensing and writing circuitry may be configured to verify read more memory cells simultaneously than were activated simultaneously.
The write data may be programmed as multi-level state in the memory cell.
At least one of the above and other features and advantages may be realized by providing a method of writing data in a phase change memory cell in a memory, the memory including N tiles, where N is greater than 2, the method including activating M memory cells, where M is greater than 2, in N tiles simultaneously, one memory cell within a tile be activated at a time, simultaneously supplying a write signal to the M memory cells in the N tiles, verify-reading the M memory cells in N tiles simultaneously, and when Q memory cells in N tiles pass, supplying the write signal to the M-Q memory cells in the N-Q tiles, wherein an amplitude of the write signal supplied to the M memory cells is less than the product of M and an amplitude of a single cell write signal.
Supplying the write signal may include sequentially programming each memory cell in individual ones of the N tiles. The memory may include partitions of P tiles. Each tile within a partition may have a selected memory cell. The partition may include two planes of P/2 tiles, the two planes being physically separated. Adjacent planes of different partitions may share a sensing and writing circuit.
In each iteration, supplying the write signal may use an available voltage amount for each simultaneous supplying of write signals. Supplying the write signal to the M-Q memory cells in the N-Q tiles may include altering at least one of a magnitude, a width, and a slope of the write signal.
At least one of the above and other features and advantages may be realized by providing a system, including a processor and a memory device. The memory device may include an array of resistance change memory cells divided into a first memory block including a first selected memory cell of a first plurality of memory cells and a second memory block including a second selected memory cell of a second plurality of memory cells, and sensing and writing circuitry configured to simultaneously activate a line connected with the first and second selected memory cells, to write the first and second selected memory cells with write data by applying a level-controlled write signal to the first and second selected memory cells, to perform a verify-read operation on the first and second selected memory cells, and, when at least one of the first and second selected memory cells has a programmed state that is not equal to the write data, to iteratively apply the level-controlled write signal to the at least one of the first and second selected memory cells not having a programmed state equal to the write data until the verify-read operation indicates respective programmed states for the first and second selected memory cells are equal to the write data.
The above and other features and advantages of will become more apparent to those of ordinary skill in the art by describing in detail exemplary embodiments with reference to the attached drawings, in which:
Korean Patent Application No. 10-2009-0016330, filed on Feb. 26, 2009, in the Korean Intellectual Property Office, and entitled: “Resistive memory device, memory system including same, and programming method of the same,” is incorporated by reference herein in its entirety.
Exemplary embodiments will now be described more fully hereinafter with reference to the accompanying drawings; however, they may be embodied in different forms and should not be construed as limited to the embodiments set forth herein. Rather, these embodiments are provided so that this disclosure will be thorough and complete, and will fully convey the scope of the invention to those skilled in the art. Like reference numerals refer to like elements/features throughout the specification.
Hereinafter, embodiments of the invention will be described using a phase change random access memory device (PRAM) example. However, it will be apparent to those skilled in the art that embodiments may be applied to other forms of nonvolatile memory using resistance materials, such as a resistive RAM (RRAM), and a ferroelectric RAM (FRAM). Herein, the terms “write” and “program” are used interchangeably in this written description to denote operations for storing data in one or more memory cells.
As illustrated in
An example schematic of a block BLKi is illustrated in
The word lines WLi may be responsive to a row address decoder (not shown) and the bit lines BLi may be selected responsive to a column address decoder (not shown). Such row and address decoders are well known in the art and need not be described further herein. As used herein, a word of data refers to the number of bits that are selected for a given output of the row address decoder and column address decoder (i.e. when a word line is active and a corresponding column select signal is active). Data may be sequentially applied to the SA/WD 20—i, such that fewer than all of the write drivers for a word of data are simultaneously active, which may reduce the peak current requirements when the memory cells are programmed.
Each of the resistive elements Rp may be embodied by a phase change random access memory (PRAM). The PRAM, which may be referred to as a PCRAM or an ovonic unified memory (OUM), may use a phase change material, for example, chalcogenide alloy, for the resistive elements Rp. The phase change material may have a different resistance value according to a crystalline state, an amorphous state, or an intermediate state (when more than 1-bit data is to be programmed). For example, the phase change material may be a material of a compound of two elements, for example, GaSb, InSb, InSe, Sb2Te3, or GeTe, a material of a compound of three elements, for example, GeSbTe, GaSeTe, InSeTe, SnSb2Te4, or InSbGe, or a material of a compound of four elements, for example, AgInSbTe, (GnSn)SbTe, GeSb(SeTe), or Te81Ge15Sb2S2. Additional details regarding structures of the resistive elements according to embodiments will be discussed below.
The current control device D may be a diode or a transistor, e.g., a metal-oxide-semiconductor field effect transistor (MOSFET) or a bipolar junction transistor (BJT).
While conventional resistive memory devices can receive several bits of input at the same time, they are unable to simultaneously program the bits into corresponding memory cells. For example, a resistive memory device may receive 16 inputs through a plurality of pins, the memory device may not be able to simultaneously access 16 memory cells. One reason for this shortcoming is that if a current of 1 mA is required to program one memory cell, then a current of 16 mA would be required to simultaneously program 16 memory cells. Moreover, if the efficiency of a write driver providing the current is 10%, then in reality, a current of 160 mA would be required to simultaneously program the 16 memory cells. However, conventional memory devices are generally not equipped to provide currents with such high magnitudes.
Thus, since a write driver can only provide a limited amount of current, a program operation of several memory cells may be divided into several “divisional program operations” each requiring only a fraction of the total current required to program all of the several memory cells. In each divisional program operation, a subset (i.e., a “division”) of memory cells among a larger group is programmed. For example, a group of sixteen memory cells may be programmed by dividing the sixteen memory cells into eight groups (i.e., divisions) of two and simultaneously programming the two memory cells in each group of two in eight successive divisional program operations.
To prevent unnecessary current consumption and programming failures, the memory device may also perform a verify read operation to verify the program status of each selected memory cell. To perform the verify read operation, program data to be programmed in the selected memory cells may be stored in a temporary storage location, e.g., a program buffer. Next, the program data is programmed into selected cells. Then, the data stored in the selected memory cells may be read and compared with the program data stored in the temporary storage location. Where the data stored in the temporary storage location is different from the data stored in the selected memory cells, the verify read operation indicates a program failure. Otherwise, the verify read operation indicates a program success.
In the configuration illustrated in
Conventionally, when memory cells are programmed simultaneously in a group, if one memory cell in that group has not been successfully programmed, then that group is considered a failed group. Then, that group is subject to another program loop. In other words, in each program loop, program data is programmed to selected cells using a plurality of divisional program operations corresponding to cell groups including the selected memory cells. However, in each program loop, divisional program operations are only performed on cell groups including selected memory cells that have not been successfully programmed, i.e., “failed groups”. A general discussion of such division programming is set forth, for example, in U.S. Pat. No. 7,535,747, which is hereby incorporated by reference in its entirety.
In accordance with embodiments, one memory cell in each tile may be programmed at a time and each tile may have a memory cell to be programmed for at least an initial programming period. Before or after each program loop, a verify read operation may be performed to determine whether selected memory cells have been successfully programmed. As used herein, data to be programmed in selected memory cells will be referred to as program data, and data read from the selected memory cells in a verify read operation will be referred to as verification data.
The greater the number of memory cells on a wordline that are simultaneously accessed, the greater the wordline current. In the particular example illustrated in
In accordance with embodiments, the pass/fail assessment may be performed on a individual memory cell basis. In other words, in a subsequent program loop, memory cells in different blocks that were previously programmed sequentially may be programmed simultaneously, to thereby reduce programming time. Alternatively, in a subsequent program loop, when a memory cell in a block has passed, another memory cell, connected to the same wordline, may be programmed simultaneously with failed memory cells in different blocks. Further, in accordance with embodiments, since verify read operation requires less current than programming operations, verify read operations may be performed on more memory cells simultaneously than were programmed. The simultaneous programming across program loops may consume a same amount of current, i.e., a bandwidth of each programming may be the same, thereby reducing an amount of time subsequent program loops may take.
As illustrated in
As illustrated in
As illustrated in
While the above program methods have illustrated a continuous write method, i.e., all memory cells for the wordline are programmed before verify read operation is performed, the above program methods may be adapted to employ a suspend write method, as set forth, for example, in U.S. Pat. No. 7,535,747 or a suspend program method, as set forth, for example, in U.S. Patent Application No. 2008/0056023, both of which are hereby incorporated by reference in their entirety.
A detailed block diagram of the resistive memory device 100 is illustrated in
The row selection block 110 may include a row decoder configured to select a wordline WL in accordance with a row address ADDX for read or write operations. The row selection block 110 may also include a driver to insure a particular voltage for selected and unselected wordlines, respectively.
The column decoder 120 may be configured to select a bitline BL in accordance with a column address ADDY for read or write operations in accordance. Data to be read from or written to respective memory cells may be controlled by the I/O block 400, described in detail below.
The control block 500 may respond to a mode signal MS and may control operation of the I/O block 400. The mode signal MS may be supplied from outside or may be supplied internally by the control block 500 itself in accordance with an address signal ADDX, ADDY. In response to the mode signal MS, the control block 500 may output timing control signals to the row selection block 110, the column decoder 120, and the I/O block 400, and may output voltage control signals (VCS) to the voltage generator 600.
A schematic diagram of the I/O block 400 is illustrated in
The I/O block 400 may include a write driver 410 and a sense amplifier 450. The I/O block 400 may be connected to a memory cell MCi of the memory cell array 10 through a bitline selection transistor Ty, which is controlled by an address signal ADDY, i.e., Lyi. There are numerous such bit line selection transistors Ty in the column decoder 120. The I/O block 400 may be configured for use with a particular design of the memory cells MC, which includes a resistive element RE1 and a diode D1. Details of such a memory cell may be found, for example, in U.S. Pat. No. 7,427,531, which is hereby incorporated by reference in its entirety. A first terminal of the resistive element RE1 may be connected to the bit line BL, a second terminal of the resistive element RE1 may be connected in series with a first terminal of the diode D1, and a second terminal of the diode D1 may be connected to the wordline WL.
The write driver 410 may include transistors T11, T12, T13, T14, T15, and a latch circuit 415. The transistors T11, T12, T13 may form a pulse provider 412 receiving the supply voltage VCC. The transistors T11 and T12 may form a current mirror 412. The transistor T13 may be controlled by the voltage VC1. The latch circuit 415 may receive data to be written through data line 416 Dli and may control the state of the transistor T14 in accordance with the data from the data line 416 and a control signal register (CSR). The transistor T15, coupling the write driver 410 to the bit line selection transistor Ty, is controlled by the write enable signal (WEN).
The sense amplifier 450 may include a precharge circuit 452, including transistors T52 and T53 in series, a comparator 454, and transistor T51. A first terminal of the transistor T52 may receive the precharge voltage VPRE and a second terminal thereof may be connected to a first terminal of the transistor T53. The transistor T52 may be controlled by the precharge signal PRE. The transistor T53 may be controlled by the discharge signal DIS and may have a second terminal thereof connected to ground. The comparator 454 may compare a read voltage Vr with a reference voltage VREF and output the result as pass or fail signal (P/F). The transistor T51, coupling the sense amplifier 450 to the bit line selection transistor Ty, may be controlled by the read enable signal (REN).
During writing of the memory cell MCi, the write enable signal WEN is high, the address signal Lyi is high, and VC1 is high. Therefore, the transistor T13 is turned ON and a current pulse Ip is generated and output from the current mirror 414 through the transistor T15 to the resistance element RE1 of the memory cell MCi. When the control signal register is a low resistance program, e.g., VC1 is Vset, when the data signal is “0”, the transistor T14 is on and, when the data signal is “1”, the transistor 114 is OFF. When the control signal register is a high resistance program, e.g., VC1 is Vreset, when the data signal is “0”, the transistor T14 is ON and, when the data signal is “1”, the transistor T14 is OFF.
During reading of the memory cell MCi, the read enable signal REN is high and the address signal Lyi is high. When the discharge signal DIS is high, the transistor T53 is on and the bitline BLi is coupled to ground. When VC2 is low, transistor T52 is ON and the bitline BLi is coupled to the precharge voltage VPRE. The comparator 454 compares the read voltage Vr and the reference voltage VREF and outputs a data signal. During normal read operation, the data signal is supplied to outside the I/O block 400, i.e., to data output line DOi. During verify read operation, a pass/fail signal P/F is supplied to the latch circuit 415 of the write driver 410 and to the voltage generator 600. When the pass/fail signal is F, VC1 from the pulse generator 610 may be altered, e.g., increased. Thus, the current pulse Ip from the write driver 410 may be altered, e.g., increased. When the pass/fail signal is P, the latch circuit 415 may stop the write operation by turning OFF the transistor T14, regardless of the input data on the data line Dli.
The write driver 420 may include transistors T21, T22, T23, and a latch circuit 422. The transistor T21 may receive a positive voltage Vp at the first terminal thereof to program an ON or set state. The transistor T22 may receive a negative voltage Vn at a first terminal thereof to program an OFF or reset state. The latch circuit 422 may control the transistors T21 and T22 in accordance with the data line signal Dli and the control signal register (CSR).
During writing of the memory cell MCi', the write enable signal WEN is high and the address signal Lyi is high. When the control signal register CST is a low resistance program, e.g., Vp is to be used, the latch circuit 422 turns the transistor T22 OFF. When the data signal is “0”, the latch circuit 422 turns the transistor T21 ON and, when the data signal is “1”, the latch circuit 422 turns the transistor T21 OFF. When the control signal register CSR is a high resistance program, e.g., Vn is to be used, the latch circuit 422 turns the transistor T21 OFF. When the data signal is “0”, latch circuit 422 turns the transistor T22 ON and, when the data signal is “1”, latch circuit 422 turns the transistor T22 OFF.
The latch circuit 422 turns the transistor T21 ON and, when the data signal is “1”, the transistor T14 is OFF. When the control signal register CSR is a high resistance program, e.g., VC1 is Vreset, when the data signal is “0”, the transistor T14 is ON and, when the data signal is “1”, the transistor T14 is OFF.
The sense amplifier 460 may include transistors T61, T62, T63, and a comparator 462. The operation of the sense amplifier 460 and the relationship of the elements therein is the same as the sense amplifier 450 of
If the read voltage is greater than a reference data voltage VRD and data “1” was to be programmed to the memory cell, than the memory cell will pass. If the read voltage is less than a reference data voltage VRD, and data “0” was to be programmed to the memory cell, than the memory cell will pass. Otherwise, the memory cell will fail.
As noted above, embodiments are not limited to PRAM devices, but may be employed with other resistive memory cells, e.g., RRAM, MRAM, etc. Details of such memory cells may be found, for example, in U.S. Pat. Nos. 6,545,906, 6,646,912, 6,849,891, 7,031,188, and 7,282,756, all of which are hereby incorporated by reference in their entirety.
Further, while the above has focused on the programming of 1-bit data for simplicity, embodiments may be applied to multi-bit data. For example, for storing 2-bit data, the memory cell may be placed in one of four states associated with data values 11, 10, 00, and 01, each of which correspond to unique threshold voltage/resistance distributions. Constituent threshold voltage distributions should be closely controlled to allow each of the threshold voltage distributions to coherently exist within a defined threshold voltage window.
One control method successfully employed to accomplish this goal is a programming method commonly referred to as the incremental step pulse programming (ISPP) scheme as set forth, for example, in co-pending U.S. patent application Ser. No. 12/461,036, filed Jul. 30, 2009, which is hereby incorporated by reference in its entirety. According to the ISPP scheme, a programmed threshold voltage may be moved by defined increments with respect to a given threshold voltage distribution using sequence of program loops. Smaller ISPP programming increments generally allow more accurate definition of a threshold voltage distribution. Careful control of respective threshold voltage distributions allows better voltage margin definitions between data states. However, smaller ISPP programming increments also extend the amount of time required to program a memory cell to a desired state, and longer data programming cycles are generally undesirable. Accordingly, the size of ISPP programming increments must be weighed against programming time. Thus, the reduction in programming time in accordance with embodiments may be particularly useful for programming using ISPP, whether for storing single-bit or multi-bit data.
Alternatively, embodiments may be used with other programming methods as set forth, for example, in U.S. Patent Application Publication Nos. 2008/0123389, which is hereby incorporated by reference in its entirety.
The processor 820 may generally control the write operation, the read operation, or the verify read operation of the memory device 100. For example, the processor 820 outputs write data and a command to control the write operation of the memory device 100. Also, the processor 820 may generate a command to control the read operation or the verify read operation of the semiconductor device 10. Thus, the control block (50 in
When the memory system 800 is implemented as a portable application, the memory system 800 may further include a battery 850 for supplying operation power to the memory device 100 and the processor 820. The portable application includes portable computers, digital cameras, personal digital assistants (PDAs), cellular telephones, MP3 players, portable multimedia players, automotive navigation systems, memory cards, smart cards, game consoles, electronic dictionaries, or solid state discs.
The memory system 800 may further include an interface I/F 830 for exchange of data with an external data processing device. When the semiconductor system 800 is a wireless system, the memory system 800 may further include a wireless interface I/F 840. In this case, the wireless interface 840 may be connected to the processor 820 to wirelessly exchange data with an external wireless device (not shown) via the system bus 810. For example, the processor 820 may process the data input through the wireless interface 840 and store the processed data in the memory device 100, or read out the data from the memory device 100 and transmit the read data to the wireless interface 840.
The wireless system may be a wireless device such as PDAs, portable computers, wireless telephones, pagers, or digital cameras, radio-frequency identification (RFID) readers, or RFID systems. Also, the wireless system may be wireless local area network (WLAN) systems or wireless personal area network (WPAN) systems. Also, the wireless system may be a cellular network.
When the memory system 800 is an image pick-up device, the memory system 800 may further include an image sensor 860 for converting an optical signal to an electric signal. The image sensor 860 may be an image sensor using a charge coupled device (CCD) or a complementary metal-oxide semiconductor (CMOS) image sensor manufactured using a CMOS process. In this case, the memory system 100 may be a digital camera or a cellular telephone having a digital camera function. Also, the memory system 800 may be an artificial satellite system to which a camera is attached.
Thus, in accordance with embodiments, by simultaneously activating more than one memory cell and/or by determining a pass/fail status on an individual memory cell basis, programming speed of a resistive memory device may be increased.
Example embodiments have been disclosed herein, and although specific terms are employed, they are used and are to be interpreted in a generic and descriptive sense only and not for purpose of limitation. Accordingly, it will be understood by those of ordinary skill in the art that various changes in form and details may be made without departing from the spirit and scope of the present invention as set forth in the following claims.
Number | Date | Country | Kind |
---|---|---|---|
10-2009-0016330 | Feb 2009 | KR | national |