This invention relates generally to semiconductor memories and, particularly, to such memories which are prone to imprinting.
Memory imprinting is when a memory cell retains its programmed state and cannot be readily programmed to a different state. A memory cell is a collection of one or more memory bits. Memory imprinting is a function of the amount of time between memory accesses. When the time between accesses is sufficiently long, some memories, such as polymer memories, retain the programmed state unless handled specially.
When a memory cell is imprinted or stuck, a slower access timing unimprinting protocol may overcome the imprinting. A higher voltage or allowing the voltage to act on the cell for a longer time may also overcome the imprint.
One problem with overcoming imprinting is that it must be known in advance whether or not a given cell is imprinted. If the cell that is imprinted is accessed normally, the information that is stored in the cell may be destroyed. Conversely, if all of the cells are accessed with the unimprinting protocol, the access time and the performance of the memory may be severely degraded, and/or endurance of the memory cells may be significantly reduced.
Thus, there is a need for better ways to deal with imprinted memory cells.
Referring to
Those other components may include a semiconductor memory 16 which may be prone to stuck or imprinted cells, such as a polymer memory. Other memories that are subject to these problems may be used as well.
A random access memory 18 is also coupled to the bus 14. The random access memory 18 may store an imprint handler software 34, handler set up software 22, and cell access software 50. The random access memory 18 may, for example, be a semiconductor memory or a rotating memory such as a hard disk drive or a digital versatile disk (DVD) drive, or any other randomly accessible memory.
Also coupled to the bus 14 may be an input/output device 20 which may be any of the conventional input/output devices including a display, a keyboard, or a mouse, to mention a few examples. Finally, a system clock 15 (or a clock interface to obtain timing information from an external source) is provided. However, other components may be utilized in addition to or in place of the components depicted in
In some embodiments, the memory 16 may be a disk cache formed by a polymer memory. The memory 16 may store data within layers. The higher the number of layers, the higher the capacity of the memory. Each layer may include polymer chains with dipole moments. Data may be stored by changing the polarization of polymer between conductive lines.
In various situations, the memory 16 may become imprinted such that if accessed with normal access timings and/or voltage, imprinted memory cells may be destroyed. In order to combat the effects of imprinting, two different approaches may be implemented in some embodiments of the present invention. One approach is to periodically refresh the memory 16 to prevent imprinting from occurring in the first place. The other approach is to compensate for imprinting in those cases where imprinting occurred or likely may have occurred, regardless of the use of preventive measures such as refreshing. Imprinting may occur when a system has been shut-off for a long time, or when a system failure occurs, a power loss occurs, or some other unavoidable circumstance results.
Each cell in the memory 16 may be associated with metadata which indicates various information which may be maintained for that cell. In addition to various other information, the bIMPRINT data about whether the memory cell is likely to have been imprinted may also be stored.
The metadata may be stored in a virtual memory, in the memory 16, or in the memory 18, as examples. The metadata may be stored as packed metadata in a single memory block for all the various blocks or it may be stored in association with each cache line, as another example. Any of a variety of techniques for storing the metadata indicating whether or not a given cell is imprinted may be used. In addition, instead of maintaining the imprint information on a cell-by-cell basis, it may be stored in association with other memory units including blocks, words, arrays, or other arrangements.
In addition, some embodiments decrease the likelihood that imprinting may occur by using a refresh cycle on a periodic basis. The refreshing feature may be ineffective where the system is shutdown for long periods.
To implement these imprinting compensation techniques, the imprint handler software 34, the cell access software 50 and the setup software 22 may be stored in the randomly accessible memory 18 or in some other system memory.
Referring to
Then, a check at diamond 28 determines whether a system startup has occurred. A system startup may occur in the case of a system boot, after a shutdown, crash or a power failure, as three examples. If a system startup is detected at diamond 28, a check at diamond 30 determines whether any of three circumstances have arisen. The first circumstance is that the variable V is equal to false. The variable V is a variable that indicates whether the time stamp variable Tlast-refresh is valid. Generally, it will be valid unless the memory has never been refreshed. The next item that is checked is whether the current time Tcurrent minus the variable Tlast-refresh is greater than a variable Timprint-threshold. The variable Timprint-threshold is the time between refreshes threshold for when imprinting will likely occur absent an intervening refresh. That threshold may be specified in terms of a time which may be sufficient to cause imprinting to occur in the particular memory 16 involved. The final item that is checked is whether the variable Tcurrent, indicating the current time, is less than the variable Tlast-refresh, which would indicate some type of error situation.
If any of these three circumstances is found to exist in diamond 30, in one embodiment, then the imprint bit (bIMPRINT) associated with each memory cell may be set equal to true as indicated at 32.
The cell access software 50 implements the two compensation techniques, those being to prevent imprinting from occurring and to detect and compensate for imprinting when it likely has already occurred nonetheless.
Referring to
Referring to
After the last cell has been refreshed, as determined at diamond 44, the variable Tlast-refresh is set equal to the current time. The current time may be accessed from the system time clock 15 or from an external time device via a clock interface as indicated in block 46. The variable V is set equal to true and the variable A is set equal to −1. A check at diamond 47 determines whether there are more refreshes to do. If so, in block 48, the variable A is incremented and the flow recycles.
A number of variations may be implemented. The memory 16 may be refreshed on each boot/resume cycle. This refresh scheme obviates the need for the variable Tlast-refresh, the variable V, or bIMPRINTED states. However, in some embodiments, this may significantly impact the boot/resume performance for realistically sized non-volatile memories and unimprint protocols.
In other embodiments, the cell V may be omitted by simply setting Tlast-refresh to the minimum possible time each time the logic calls for the variable V to be set equal to FALSE. Also, the memory cells need not be refreshed in order. Some types of memories have segments or collections of memory cells that lock out for some time after access. A striding pattern of accesses in the memory refresh loop may be more appropriate in such cases. In addition, memory cells may be refreshed in blocks. Thus, it may be desirable to refresh N memory cells at a time in parallel or in sequence. These N cells need not be contiguous and multiple counters may be maintained to track each cell range that has been refreshed. N may also vary depending on other system variables, including whether the system is running on line power, in which case it may be preferred to refresh the memory in larger blocks.
In some embodiments, a history may be maintained for each memory cell to decide when the cell was last refreshed. In its simplistic form, a time stamp can be kept per memory cell or memory block in some embodiments. This may reduce the number of refreshes done at the expense of keeping more data per memory cell.
An initial bit R can be maintained, in one embodiment, per memory cell (in its volatile metadata), that specifies whether a given cell has already been refreshed since the previous time based refresh because of an unrelated memory access. These R bits may be initialized to zero at system startup and set to one on every access. During the refresh loop, an address A is refreshed in non-volatile memory only if its R bit is zero and irrespective, the R bit for the memory cell is cleared.
In some embodiments, imprints may be avoided or, if they occur nonetheless, recovery may be provided without accessing all cells on slow timing. Thus, in some embodiments, imprinting may be reduced and access times increased.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.