Embodiments disclosed herein pertain to memory programming methods and memory systems.
Memory may include one-time programmable memory cells for use for various purposes. In one example conventional memory arrangement, one memory structure is provided for writing/reading data while a separate memory structure is provided for one-time programmable cells. One-time programmable cells may be programmed by a manufacturer of the memory or perhaps an end user customer who incorporates the memory into an end product. The one-time programmable cells are written to once and may be implemented as non-volatile memory, such as fuses or anti-fuses, to permanently store the one-time programmable data.
However, it has been recognized that one-time programmable data may be undesirably changed, reversed or un-programmed from its originally programmed state under some conditions. A charge retaining region of a flash memory cell utilized as a one-time programmable cell may gain or lose charge over time to an extent that the state of the flash memory cell is indeterminate or different than the originally-programmed state. The data level of a programmed cell may approach the read level of the cell to such an extent that the state of the memory cell may be indeterminate or incorrectly determined with respect to its originally programmed state.
At least some embodiments described below are directed towards methods and apparatus which provide increased data reliability and retention of data which is programmed once compared with some conventional memory arrangements.
At least some embodiments are directed towards apparatus and methods which utilize re-writable memory to store data which is not to be changed from its originally-programmed state after the original programming of the memory. The data which is only programmed once may be referred to as one-time programmed data and the re-writable memory used to store this data may be referred to as one-time programmed memory. At least some embodiments also provide re-writing of the one-time programmed data over time to assure that the data may be accurately read at subsequent moments in time after being originally-programmed into the one-time programmed memory. While the re-writable memory utilized to store the one-time programmed data in some embodiments is physically capable of being re-written to other states after initially being programmed, the contents of the one-time programmed memory (i.e., one-time programmed data) are not changed after being initially programmed in at least some embodiments. In at least one embodiment, user-initiated operations are utilized to trigger re-writing of the one-time programmed data. The re-writing of the one-time programmed data increases the reliability and retention of the data compared with arrangements where the data is not re-written. Additional examples are discussed below with respect to illustrative embodiments.
Referring to
Controller 12 controls operations of writing, reading and re-writing data of memory 16 as well as interfacing with other components or circuitry, such as sources of data to be stored within memory 16. Controller 12 may access and process user inputs such as commands with respect to memory 16 during operations of an associated device. Example commands instruct the generation of erase and program pulses which are applied to memory 16 in one embodiment. The application of erase and program pulses programs memory in one embodiment, and the application of an erase pulse and the application of a program pulse are both referred to as programming operations of memory in one embodiment. Other types of pulses may be utilized for programming in other embodiments.
In one embodiment, controller 12 is configured to process data, control data access and storage, issue commands, and control other desired operations. Controller 12 may comprise processing circuitry configured to execute programming provided by appropriate computer-readable storage media in at least one embodiment. In one embodiment, firmware of the controller 12 is stored in one-time programmed memory. For example, the controller 12 may be implemented as one or more processor(s) and/or other structure configured to execute executable instructions including, for example, software and/or firmware instructions. The programming may be stored within one or more computer-readable storage media of controller 12. The storage media may be non-transitory and be embodied in one or more articles of manufacture. Other example embodiments of controller 12 may include hardware logic, PGA, FPGA, ASIC, state machines, and/or other structures alone or in combination with one or more processor(s). These examples of controller 12 are for illustration and other configurations are possible.
Access circuitry 14 is coupled with controller 12 and memory 16 and is configured to implement addressing (selection of columns and rows of an array of memory 16), writing, reading and re-writing operations with respect to memory 16. For example, access circuitry 14 may receive instructions from controller 12 to select a specific page, word or byte of the memory 16 as well as implement writing, reading and re-writing with respect to a plurality of cells of the selected page, word or byte. As discussed below, the access circuitry 14 may re-write one-time programmed data stored in one-time programmed cells of the memory 16 while performing other writing and reading operations with respect to main cells of memory 16. The X and Y decoders may be positioned adjacent to any of the sides of an array of memory 16 in some embodiments.
Memory 16 can include a plurality of memory cells configured to store data, conductors, and perhaps additional circuitry. In one embodiment, memory 16 includes one portion which may be referred to as main memory and another portion which may include the one-time programmed memory. The main memory is a first storage location, or main block/array, of a plurality of main cells that are accessible to the user where the user is authorized to change the contents of the main memory. The one-time programmed memory is a second storage location, or secondary block/array, of a plurality of one-time programmed cells where the user is not authorized to change the data once it is programmed into the one-time programmed memory. The one-time programmed memory is not programmed by a user in one embodiment, but may be programmed by a manufacturer of memory 16, a manufacturer of an associated device which utilizes the memory 16, and/or another entity. One-time programmed data may include a manufacturer identifier, serial number, redundant information, firmware to control a memory system, or other information.
The main cells may be configured as volatile or non-volatile cells (e.g., DRAM, CBRAM, phase change, programmable metallization or resistive) and may be utilized to store data for use within an associated device. The main memory is available to store data during operations of an associated device (e.g., storing image files generated by an imaging system of an associated device). Data stored within main memory may be referred to as main data. The main cells may be programmed to different states to store different main data at different moments in time in some embodiments. In a more specific embodiment, main memory may be implemented as multiple-time programmable memory which may be intentionally written to with different main data at different moments in time during operations of the associated device. In addition, some of the main memory may never be written to or utilized during operations of the associated device, or only written to once during operations of the associated device.
The one-time programmed cells may be configured as the same type of cells as the main cells and utilized to store data programmed by a manufacturer of the memory 16, a manufacturer of the memory system 10, a customer who implements the memory 16 in an associated device, or other appropriate entity. As mentioned above, data stored within one-time programmed memory may be referred to as one-time programmed data and the one-time programmed cells are programmed once with the one-time programmed data as discussed above. More specifically, the one-time programmed cells are programmed once and memory system 10 is configured such that the one-time programmed data stored in one-time programmed memory is retained, not written over once programmed, and is re-written as originally-programmed as discussed in further detail below. In one embodiment, some of the one-time programmed memory may never be written to or utilized.
Referring to
In one embodiment, main memory 20 of a single page 24 includes more main cells 25 than one-time programmed cells 27 of one-time programmed memory 22 of the same page. Normal memory 20 of an individual page 24 may include, depending upon the type of memory utilized, between 16-8000 main cells 25 while the one-time programmed memory 22 for the same page 24 may include between 1-8 one-time programmed cells 27 in example embodiments. Different numbers of cells 25, 27 may be provided within an individual page 24 in other embodiments.
While all of the illustrated pages 24 in
Although the main and one-time programmed cells of a given page 24 may be accessed simultaneously in some embodiments described herein, only the main memory 20 is available to the associated device for storage of data during user operations of the associated device, while the one-time programmed memory 22 is reserved for one-time programmed data programmed by the manufacturer of the memory, manufacturer of the associated device, end customer which implements the memory in the associated device or end product, etc.
In the illustrated embodiment, access circuitry 14 is implemented as an X decoder 30, a plurality of Y decoders 32a, 32b, and a plurality of sense amplifiers 34a, 34b. X and Y decoders 30, 32a, 32b and sense amplifiers 34a, 34b operate to access desired pages 24 and cells 25, 27 of main and one-time programmed memory portions 20, 22 for reading, writing and re-writing of data within the main and one-time programmed cells.
As mentioned above, the memory 16 of the embodiment shown in
One-time programmed memory 22 is written once with one-time programmed data as mentioned above. Thereafter, it is not utilized to store main data during operations of the associated device, but rather main data utilized and generated by operations of the associated device is stored in main memory 20. Accordingly, in one embodiment, Y decoder 32a is utilized to access the main memory cells 25 during operations of the associated device while decoder 32b is utilized to access the one-time programmed memory cells 27. In some embodiments, Y decoders 32a, 32b and sense amplifiers 34a, 34b may be implemented as a single Y decoder and a single sense amplifier, respectively, and the associated device may only access addresses within main memory 20 for writing main data during user operations, while the one-time programmed cells 27 are only re-written.
Data stored within memory 16 (e.g., binary 0's data and 1's data) including one-time programmed data within one-time programmed memory 22 may, upon initial programming, have respective data levels (e.g., voltages, states, resistances) which enable the data to be easily determinable with respect to a read level of the memory 16. However, over time, the data levels of data stored within memory 16, including one-time programmed memory 22, may degrade with respect to the read level, and perhaps reach a level sufficiently close to the read level that the data is no longer accurately determinable. Some embodiments of the disclosure re-write the one-time programmed data of one-time programmed memory 22 at a plurality of different moments in time to increase the retention, reliability and integrity of the one-time programmed data (i.e., ability to distinguish the states of the one-time programmed data stored in the one-time programmed cells 27) for longer periods of time compared with arrangements which do not re-write the one-time programmed memory 22 at the plurality of moments in time.
In one operational embodiment, actions by a user of an associated device in which the memory 16 is incorporated will result in the re-writing of one-time programmed data of one-time programmed memory 22 at the different moments in time. In one more specific embodiment, user commands may result in the generation of erase and program pulses which are applied at different moments in time to the cells of main memory 20 during operations of the associated device. In one embodiment, a plurality of re-write pulses may be applied to one-time programmed cells 27 of one-time programmed memory 22 to re-write the one-time programmed data stored therein corresponding to the application of erase and program pulses to program main cells 25 of the main memory 20. In some embodiments, the erase and program pulses are both utilized to program the main cells 25 as well as simultaneously re-write the one-time programmed cells 27. The application of the re-write pulses to the one-time programmed memory 22 increases the differences of the data levels of the contents of the one-time programmed memory 22 with respect to the read level resulting in one-time programmed data which may be readily determinable by the sense amplifier 34b as discussed further below with respect to
In one more specific embodiment, assume the controller 12 is erasing the contents of main memory 20 of a given page 24 (e.g., Page 1) during operations of the associated device in which the memory 16 is utilized. The X decoder 30 operates to select the word line 23 of the selected page 24 to activate the main cells 25 of the selected page 24. In one embodiment mentioned above, the one-time programmed cells 27 of the corresponding selected page 24 may also be coupled with the word line 23 selected by X decoder 30. Accordingly, the selection of the word line 23 for the desired page 24 results in the simultaneous activation of the corresponding one-time programmed cells 27 of the desired page 24 as well as the main cells 25 of the desired page 24. Following selection of the respective word line 23 for the desired page 24, controller 12 may control the application of a common erase pulse to appropriate main cells 25 of main memory 20 and appropriate one-time programmed cells 27 of one-time programmed memory 22 using Y decoders 32a, 32b. While appropriate main cells 25 of the selected page 24 may receive the erase pulse in some embodiments, controller 12 may read or access the contents of the one-time programmed memory 22 to determine which specific one-time programmed cells 27 are also to receive the common erase pulse which would operate to re-write the respective one-time programmed cells 27 (e.g., re-write 1's one-time programmed data). The re-writing of the one-time programmed data is automatic and implemented without specific user instruction which instructs the re-writing in one embodiment.
Furthermore, some of the main cells 25 of main memory 20 for the desired page 24 may also receive a program pulse during programming. Following assertion of the respective word line 23 for the desired page 24, controller 12 may control the application of the program pulse to appropriate main cells 25 of main memory 20 and appropriate one-time programmed cells 27 of one-time programmed memory 22. Controller 12 may read or access the contents of the one-time programmed memory 22 to determine which specific one-time programmed cells 27 are to receive the program pulse which would operate to re-write the respective one-time programmed cells 27 (e.g., re-write 0's one-time programmed data). Accordingly, appropriate one-time programmed cells 27 of the one-time programmed memory 22 are re-written simultaneously with the application of the erase and program pulses to the main cells 25 of main memory 20 in one embodiment. More specifically, a common erase pulse may re-write 1's data of the one-time programmed memory 22 along with erasure of main cells 25 and a common program pulse may re-write 0's data of the one-time programmed memory 22 while being applied to appropriate main cells 25. Again, the re-writing of the one-time programmed data is automatic and implemented without specific user instruction which instructs the re-writing in one embodiment.
Referring to
More specifically, in the illustrated example, X decoder 30a asserts word lines of respective pages 24 of main memory 20a to activate the main cells and X decoder 30b asserts word lines of respective pages 24 of one-time programmed memory 22a to activate the one-time programmed cells. Program and erase pulses may be applied by Y decoder 32a to appropriate main cells to program and erase the main bits of main data and program and erase pulses may be applied by Y decoder 32b to appropriate one-time programmed cells to re-write the one-time programmed bits of one-time programmed data. The contents of the main cells may be sensed by sense amplifier 34a and contents of one-time programmed cells may be sensed by one-time programmed amplifier 34b in the illustrated example embodiment.
The embodiment of
In one embodiment, one-time programmed data addresses can be associated with a number of operations with respect to the main memory if a counter is provided which stores how many operations have been performed with respect to the main memory. For example, referring to
Referring to
At an initial time t=0, both the 0's and 1's data have respective data levels relative to read level 42. As time progresses to the right in
In some embodiments discussed above, the one-time programmed bits may be re-written along with the assertion of program and erase pulses with respect to the main cells without user instruction. For example, the 0's one-time programmed data may be re-written by a program pulse when the program pulse is applied to the main memory and the 1's one-time programmed data may be re-written by an erase pulse when the erase pulse is applied to the main memory.
In one embodiment, the one-time programmed bits may be re-written as a result of their respective data levels. For example, in one implementation, one-time programmed bits may be re-written as a result of their respective data levels reaching a respective one of the program or erase verify levels 43, 44. In one more specific example, when a program pulse is to be asserted for 0's data in main memory, the data level of the 0's data within one-time programmed memory may be compared with respect to the program verify level 43. Using the comparison, all 0's bits within a page of one-time programmed memory which reach and/or are below the program verify level 43 may also be re-written with the program pulse while 0's bits within the page of one-time programmed memory which are above the program verify level 43 will not receive the program pulse. In another example, all of the 0's bits in a page of one-time programmed memory may receive a program pulse if one or more 0's bits in the page of one-time programmed memory reach or are below the program verify level 43. Similarly, the 1's bits in the one-time programmed memory may also be re-written if one or more 1's bit in the one-time programmed memory reach or are above the erase verify level 44 during the application of an erase pulse to main memory.
Referring to
At an act A10, a user action, such as a program command or erase command, instructs the application of a program or erase pulse to the main memory. The generated command may be accessed and utilized to initiate programming of main memory and re-writing of one-time programmed memory as described in subsequent acts of
At an act A12, a one-time programmed pre-read action is performed where the one-time programmed bits are read with respect to the “read level” to determine the state of the one-time programmed bits as 0's and 1's. The results of this action may be utilized to determine which of the one-time programmed bits are to receive either the program pulse (0 bits) or erase pulse (1 bits) based upon their respective states (i.e., if an erase pulse is to be applied, it is determined which of the one-time programmed bits are 1's to receive the erase pulse).
At an act A14, a main and one-time programmed pre-read action is performed where the main and one-time programmed bits are read with respect to the verify levels to determine which 0's bits are at or below the program verify level and which 1's bits are at or above the erase verify level and are to receive either the program pulse (0 bits) or erase pulse (1 bits).
At an act A16, a program pulse or an erase pulse is applied to the appropriate main bits for programming according to the main data to be stored and to the appropriate one-time programmed bits for re-writing the one-time programmed data. The appropriate one-time programmed bits to receive the program or erase pulse were identified in acts A12 and A14 in the described example.
At an act A18, the main bits and the one-time programmed bits are verified after the application of the program pulse or erase pulse.
The process returns to act A16 for another application of the program or erase pulse if the verification fails. Otherwise, if the verification is acceptable, the process terminates until another appropriate user command is accessed whereupon the process of
The acts of comparing the one-time programmed data with respect to the program and verify levels prior to re-writing may reduce stresses upon the one-time programmed memory by avoiding unnecessary re-writing of the one-time programmed data (i.e., re-writing of data when the data has suitable data levels with respect to the read level). In particular, the repetitive re-writing pulses over time may result in dielectric breakdown of the memory cells or increased power consumption in some implementations. However, in some embodiments, the comparison of the contents of the one-time programmed bits with respect to the erase and program verify levels may be omitted and the appropriate one-time programmed bits may be re-written with the user commands instructing a program or erase operation.
Sensing circuitry may utilize a voltage sensing scheme or current sensing scheme for program verify operations, erase verify operations and pre-read operations (e.g., with respect to the one-time programmed data). A particular circuit configuration may be selected based upon various design parameters of a device, such as speed, accuracy, size, efficiency and power.
Referring to
While some of the embodiments are described with respect to main and one-time programmed memory both being implemented as the same type of memory, it is to be understood that other types of memory may be utilized and main and one-time programmed memory may be implemented as different structures and/or types of memory in a single memory system in some embodiments. For example, main memory may be implemented as DRAM memory and one-time programmed memory may be implemented as resistive or phase change memory or flash memory in one possible embodiment.
In some embodiments, a memory programming method comprises programming a plurality of first main cells of a main memory, erasing a plurality of second main cells of the main memory, first re-writing one-time programmed data within a plurality of first one-time programmed cells of a one-time programmed memory during the programming, and second re-writing one-time programmed data within a plurality of second one-time programmed cells of a one-time programmed memory during the erasing.
In some embodiments, a memory programming method comprises, using a word line, activating a plurality of main cells and one-time programmed cells which are coupled with the word line, programming at least some of the activated main cells to store main data, and re-writing one-time programmed data of at least one of the activated one-time programmed cells which was previously programmed with the one-time programmed data.
In some embodiments, a memory programming method comprises accessing a plurality of user commands, as a result of the accessing one of the user commands, programming a plurality of first main memory cells which are individually configured to store a bit of main data having a first state, as a result of the accessing an other of the user commands, erasing a plurality of second main memory cells which are individually configured to store a bit of main data having a second state, reading one-time programmed data stored in a plurality of one-time programmed memory cells, using the reading, identifying some of the one-time programmed memory cells as storing data having the first state, using the reading, identifying others of the one-time programmed memory cells as storing data having the second state, as a result of the accessing the one of the user commands, automatically re-writing the one-time programmed data having the first state, as a result of the accessing the other of the user commands, automatically re-writing the one-time programmed data having the second state, and wherein the automatically rewritings individually comprise re-writing in the absence of a user command which instructs the respective re-writing.
In some embodiments, a memory system comprises main memory comprising a plurality of main cells, one-time programmed memory comprising a plurality of one-time programmed cells, and circuitry configured to program the main cells to store main data as a result of a user command and to re-write one-time programmed data stored in the one-time programmed cells as a result of the user command.
In some embodiments, a memory system comprises memory comprising a plurality of pages, and circuitry configured to program the pages with main data and to re-write one-time programmed data stored in the pages at a plurality of moments in time.
In compliance with the statute, the subject matter disclosed herein has been described in language more or less specific as to structural and methodical features. It is to be understood, however, that the claims are not limited to the specific features shown and described, since the means herein disclosed comprise example embodiments. The claims are thus to be afforded full scope as literally worded, and to be appropriately interpreted in accordance with the doctrine of equivalents.
This application is a continuation of and claims priority to U.S. patent application Ser. No. 14/853,557 filed Sep. 14, 2015, titled “Memory Programming Methods and Memory Systems”, which is a continuation of and claims priority to U.S. patent application Ser. No. 13/546,919 filed Jul. 11, 2012, titled “Memory Programming Methods and Memory Systems”, the teachings of which are incorporated herein by reference.
Number | Name | Date | Kind |
---|---|---|---|
5761115 | Kozicki et al. | Jun 1998 | A |
5999447 | Naura et al. | Dec 1999 | A |
6044012 | Rao et al. | Mar 2000 | A |
6366495 | Miwa et al. | Apr 2002 | B2 |
6728137 | Lin | Apr 2004 | B1 |
6985378 | Kozicki | Jan 2006 | B2 |
7218547 | Kurth et al. | May 2007 | B2 |
7337282 | Happ et al. | Feb 2008 | B2 |
7508693 | Chen | Mar 2009 | B2 |
7675766 | Kozicki | Mar 2010 | B2 |
7855147 | Dulkin et al. | Dec 2010 | B1 |
7929349 | Seol et al. | Apr 2011 | B2 |
8003971 | Happ et al. | Aug 2011 | B2 |
8032727 | Brownhill et al. | Oct 2011 | B2 |
8059479 | Kurjanowicz | Nov 2011 | B2 |
8122307 | Lindhorst et al. | Feb 2012 | B1 |
8279657 | Takagi | Oct 2012 | B2 |
8331128 | Derhacobian et al. | Dec 2012 | B1 |
8547736 | Rao et al. | Oct 2013 | B2 |
8804399 | Sills et al. | Aug 2014 | B2 |
8804401 | Sugimae | Aug 2014 | B2 |
8913449 | Chung | Dec 2014 | B2 |
8957399 | Wei | Feb 2015 | B2 |
9053789 | Ertosun | Jun 2015 | B1 |
9117522 | Matsunami | Aug 2015 | B2 |
9135978 | Kunihiro | Sep 2015 | B2 |
9165648 | Jameson, III | Oct 2015 | B1 |
9293196 | Otsuka et al. | Mar 2016 | B2 |
9691441 | Kunihiro | Jun 2017 | B2 |
9911489 | Otsuka et al. | Mar 2018 | B2 |
20060055065 | Liu et al. | Mar 2006 | A1 |
20060163734 | Thei et al. | Jul 2006 | A1 |
20060265548 | Symanczyk et al. | Nov 2006 | A1 |
20070101115 | Murakami | May 2007 | A1 |
20070157000 | Qawami et al. | Jul 2007 | A1 |
20070274120 | Pinnow et al. | Nov 2007 | A1 |
20080253167 | Symanczyk | Oct 2008 | A1 |
20080273370 | Keller et al. | Nov 2008 | A1 |
20080310211 | Toda et al. | Dec 2008 | A1 |
20080320208 | Nagashima et al. | Dec 2008 | A1 |
20090157953 | Matsubara et al. | Jun 2009 | A1 |
20100123542 | Vaithyanathan et al. | May 2010 | A1 |
20100319971 | Lin | Dec 2010 | A1 |
20110066787 | Markey et al. | Mar 2011 | A1 |
20110222330 | Lee et al. | Sep 2011 | A1 |
20120047322 | Chung | Feb 2012 | A1 |
20120320657 | Chung | Dec 2012 | A1 |
20130021835 | Hwang | Jan 2013 | A1 |
20130182487 | Lee et al. | Jul 2013 | A1 |
20130188414 | Kawai | Jul 2013 | A1 |
20140016393 | Kunihiro | Jan 2014 | A1 |
20140131653 | Lee | May 2014 | A1 |
20140268992 | Otsuka et al. | Sep 2014 | A1 |
20160005442 | Kunihiro | Jan 2016 | A1 |
20160203861 | Otsuka et al. | Jul 2016 | A1 |
20180144792 | Otsuka et al. | May 2018 | A1 |
Number | Date | Country |
---|---|---|
1727151 | Nov 2006 | EP |
Entry |
---|
Otsuka et al., U.S. Appl. No. 15/858,201, filed Dec. 27, 2017, titled “Memory Cells, Memory Systems, and Memory Programming Methods”, 35 pages. |
A Brief History and Explanation of Otp Memory; http://www.articlesnatch.com/Article/A-Brief-History-And-Explanation-Of-Otp-Memory/909407; 2005; 2 pages. |
Aratani et al., “A Novel Resistance Memory with High Scalability and Nanosecond Switching”, IEEE International Electronic Devices Meeting Technical Digest, 2007, United States, pp. 783-786. |
Ertosun, U.S. Appl. No. 61/636,800, filed Apr. 23, 2012, titled “Programmed/Triggered Cell Annihilation for Resistive Switching Memory Devices”, 11 pages. |
Gilbert et al., “An Embeddable Multilevel-Cell Solid Electrolyte Memory Array”, IEEE Journal of Solid-State Circuits vol. 42, No. 6, Jun. 2007, United States, pp. 1383-1391. |
Peng et al., “Resistive Switching of Au/SnO/Au Resistive Memory: An in situ Obervation of Conductive Bridge Formation”, Nanoscale Research Letters vol. 7, 2012, United States, 6 pages. |
Tan et al., “Overview of Wafer-Level 3D ICs”, Process Technology, Springer, 2008, United States, 11 pages. |
Wong, “Time Dependent Dielectric Breakdown in Copper Low-k Interconnects: Mechanisms and Reliability Models”, Materials vol. 5, 2012, Switzerland, pp. 1602-1625. |
Otsuka et al., U.S. Appl. No. 16/437,997, filed Jun. 11, 2019, titled “Memory Cells, Memory Systems, and Memory Programming Methods”, 35 pages. |
Number | Date | Country | |
---|---|---|---|
20170294235 A1 | Oct 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 14853557 | Sep 2015 | US |
Child | 15631162 | US | |
Parent | 13546919 | Jul 2012 | US |
Child | 14853557 | US |