Adaptive over-provisioning in memory systems
First Claim
1. A method for data storage, comprising:
- in a memory that includes multiple memory blocks, specifying at a first time a first over-provisioning overhead, and storing data in the memory while retaining in the memory blocks memory areas, which do not hold valid data and whose aggregate size is at least commensurate in size with the specified first over-provisioning overhead;
compacting portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas; and
at a second time subsequent to the first time, specifying a second over-provisioning overhead that is different from the first over-provisioning overhead, and continuing to store the data and compact the data portions while complying with the second overprovisioning overhead;
wherein storing the data at the first time comprises encoding the data with an Error Correction Code (ECC) having a given redundancy level and storing the encoded data, and wherein specifying the second over-provisioning overhead comprises modifying the given redundancy level of the ECC.
2 Assignments
0 Petitions
Accused Products
Abstract
A method for data storage includes, in a memory that includes multiple memory blocks, specifying at a first time a first over-provisioning overhead, and storing data in the memory while retaining in the memory blocks memory areas, which do not hold valid data and whose aggregated size is at least commensurate with the specified first over-provisioning overhead. Portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas are compacted. At a second time subsequent to the first time, a second over-provisioning overhead, different from the first over-provisioning overhead, is specified, and data storage and data portion compaction is continued while complying with the second over-provisioning overhead.
669 Citations
54 Claims
-
1. A method for data storage, comprising:
in a memory that includes multiple memory blocks, specifying at a first time a first over-provisioning overhead, and storing data in the memory while retaining in the memory blocks memory areas, which do not hold valid data and whose aggregate size is at least commensurate in size with the specified first over-provisioning overhead; compacting portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas; and at a second time subsequent to the first time, specifying a second over-provisioning overhead that is different from the first over-provisioning overhead, and continuing to store the data and compact the data portions while complying with the second overprovisioning overhead; wherein storing the data at the first time comprises encoding the data with an Error Correction Code (ECC) having a given redundancy level and storing the encoded data, and wherein specifying the second over-provisioning overhead comprises modifying the given redundancy level of the ECC. - View Dependent Claims (2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25)
-
26. A method for data storage, comprising:
-
in a memory that includes multiple memory blocks, predefining a range of logical addresses for storing data in the memory; defining a number of physical storage locations in the memory blocks, such that data storage in the number of the physical storage locations retains in the memory blocks memory areas that do not hold valid data and whose aggregated size is at least commensurate in size with an initial over-provisioning overhead; at a first time, storing the data in the memory by mapping the logical addresses to the number of physical storage locations, while complying with the initial over-provisioning overhead, and compacting portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas; and at a second time subsequent to the first time, defining a modified over-provisioning overhead that is different from the initial over-provisioning overhead, modifying the number of the physical storage locations so as to comply with the modified over-provisioning overhead, and continuing to store the data by mapping the logical addresses to the modified number of the physical storage locations and compacting the data portions; wherein defining and modifying the number of physical storage locations comprise applying a mapping process, which maps between the logical addresses and the physical storage locations and which varies in accordance with the over-provisioning overhead. - View Dependent Claims (27)
-
-
28. Apparatus for data storage, comprising:
-
a memory, comprising multiple memory blocks; and a processor, which is configured to specify at a first time a first over-provisioning overhead and store data in the memory while retaining in the memory blocks memory areas, which do not hold valid data and whose aggregated size is at least commensurate in size with the specified first over-provisioning overhead, to compact portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas, and, at a second time subsequent to the first time, to specify a second over-provisioning overhead that is different from the first over-provisioning overhead and to continue to store the data and compact the data portions while complying with the second over-provisioning overhead; wherein the processor is configured to encode the data at the first time with an Error Correction Code (ECC) having a given redundancy level and store the encoded data, and to specify the second over-provisioning overhead by modifying the given redundancy level of the ECC. - View Dependent Claims (29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52)
-
-
53. Apparatus for data storage, comprising:
-
a memory, comprising multiple memory blocks; and a processor, which is configured to predefine a range of logical addresses for storing data in the memory, to define a number of physical storage locations in the memory blocks, such that data storage in the number of the physical storage locations retains in the memory blocks memory areas that do not hold valid data and whose aggregated size is at least commensurate in size with an initial over-provisioning overhead, to store data in the memory at a first time by mapping the logical addresses to the number of the physical storage locations, while complying with the initial overprovisioning overhead, and compacting portions of the data from one or more previously-programmed memory blocks containing one or more of the retained memory areas, and, at a second time subsequent to the first time, to define a modified over-provisioning overhead that is different from the initial over-provisioning overhead, to modify the number of the physical storage locations so as to comply with the modified over-provisioning overhead, and to continue to store the data by mapping the logical addresses to the modified number of the physical storage locations and compact the data portions; wherein the processor is configured to apply a mapping process, which maps between the logical addresses and the physical storage locations and which varies in accordance with the over-provisioning overhead. - View Dependent Claims (54)
-
Specification