Apparatus and methods implemented therein are disclosed for relocating data stored in pages of a non-volatile memory. The number of memory chunks with invalid data in an slc type first page is determined and if the number is above a first threshold and above a second threshold, a bit error rate (ber) for the valid data in the set of memory chunks of the first page is compared with a first ber threshold. If the ber is below the first ber threshold, an error correcting code (ecc) for valid data in a set of memory chunks of a second page is computed and the invalid data of the first page with valid data is replaced with valid data from the second page and the computed ecc. The valid data of the first and second page is relocated to a third page.
|
15. A method for relocating data in a memory system comprising a non-volatile memory and a memory controller, wherein the non-volatile memory comprises a set of pages wherein each page comprises a set of memory chunks, the method comprising:
identifying a first page based on determining that the density of memory cells comprising the first page corresponds to a first density, wherein the first page comprises valid and invalid data stored in a set of memory chunks;
computing by the memory controller an error correcting code (ecc) for valid data stored in a second page and storing the ecc with the valid data;
merging the valid data of the first page with the valid data from the second page; and
storing the merged data in a third page.
8. An apparatus comprising:
a non-volatile memory, wherein the non-volatile memory comprises a set of pages and a data latch and wherein a page comprises a set of memory chunks; and
a memory controller electrically coupled to the memory wherein the memory controller comprises: a processor, a random access memory (ram) and an error correcting code (ecc) engine wherein
the ram is configured to store data;
the ecc engine is configured to determine a ecc; and,
a processor configured to:
determine that a first page is an slc type page,
determine if a number of memory chunks with invalid data in the first page is above a first threshold and above a second threshold and compare a bit error rate (ber) for the valid data in the set of memory chunks with a first ber threshold; and
if the ber is below the first ber threshold:
read the valid data and invalid data of the first page into the data latch;
cause the ecc engine to compute an ecc for valid data of a second page and store the valid data of the second page in the ram;
to replace the invalid data in the data latch with valid data from ram; and
to store the valid data from the data latch into a third page.
1. A method for relocating data in a memory system comprising a memory and a memory controller, wherein the memory comprises a set of pages wherein each page comprises a set of memory chunks, the method comprising:
determining by the memory controller that a first page is an slc type page;
in response to determining that the first page is an slc type page, determining by the memory controller a number of memory chunks with invalid data in the first page;
in response to determining that the number of memory chunks with invalid data in the first page is above a first threshold and above a second threshold, comparing a bit error rate (ber) for the valid data in the set of memory chunks of the first page with a first ber threshold;
in response to determining the ber is below the first ber threshold, computing an error correcting code (ecc) for valid data in a set of memory chunks of a second page and replacing the invalid data of the first page with valid data from the second page and the computed ecc; and
relocating the valid data of the second page and the valid data of the first page to a third page, without computing an ecc for valid data in the set of memory chunks of the first page.
2. The method of
3. The method of
4. The method of
5. The method of
6. The method of
7. The method of
9. The apparatus of
10. The apparatus of
11. The apparatus of
12. The apparatus of
13. The apparatus of
16. The method of
17. The method of
18. The method of
19. The method of
|
This application relates generally to managing data in a memory system. More specifically, this application relates to relocating data from one memory block to another memory block in a solid state storage device based on determining if one or more criteria associated with the memory blocks are satisfied.
The background description provided herein is for the purpose of generally presenting the context of the disclosure. Work of the presently named inventors, to the extent it is described in this background section, as well as aspects of the description that may not otherwise qualify as prior art at the time of filing, are neither expressly nor impliedly admitted as prior art against the present disclosure.
Non-volatile memory systems, such as flash memory, are used in digital computing systems as a means to store data and have been widely adopted for use in consumer products. Flash memory may be found in different forms, for example in the form of a portable memory card that can be carried between host devices or as a solid state disk (SSD) embedded in a host device. These memory systems typically work with memory units called memory chunks, pages and memory blocks.
For efficient functioning of non-volatile memory systems it is often desirable to relocate data stored in one memory unit to another memory unit. Current methods of relocating data from a memory unit do not take into consideration the state of the data stored in the memory unit. As a result, relocation is performed unintelligently and inefficiently.
In order to address the need for improved reliability in an embedded flash memory device, methods, apparatuses and systems are disclosed herein for relocating data in a non-volatile memory system.
According to one aspect, a method is disclosed for relocating data in a memory system. In one embodiment, the memory system comprises a memory and a memory controller. The memory comprises a set of pages and each page comprises a set of memory chunks. The memory controller, in response to determining that a first page is an SLC type page, determines the number of memory chunks with invalid data in the first page. The memory controller in response to determining the number of memory chunks with invalid data in the first page is above a first threshold and above a second threshold, compares a bit error rate (BER) for the valid data in the set of memory chunks of the first page with a first BER threshold. In response to determining the BER is below the first BER threshold, the memory controller computes an error correcting code (ECC) for valid data in a set of memory chunks of a second page and replaces the invalid data of the first page with valid data from the second page and the computed ECC. The memory controller, without computing an ECC for valid data in the set of memory chunks of the first page, relocates the valid data of the second page and the valid data of the first page to a third page.
According to another aspect, an apparatus comprising a non-volatile memory and a memory controller is disclosed. The memory comprises a set of pages and a data latch. Each page comprises a set of memory chunks. The memory controller is electrically coupled to the memory and the memory controller comprises a processor, a random access memory (RAM) and an error correcting code (ECC) engine. The RAM is configured to store data and the ECC engine is configured to determine an ECC. The processor is configured to determine that a first page is an SLC type page, determine if a number of memory chunks with invalid data in the first page is above a first threshold and above a second threshold and compare a bit error rate (BER) for the valid data in the set of memory chunks with a first BER threshold; and if the BER is below the first BER threshold, the processor is configured to read the valid data and invalid data of the first page into the data latch, cause the ECC engine to compute an ECC for valid data of a second page and store the valid data of the second page in the RAM, replace the invalid data in the data latch with valid data from RAM and store the valid data from the data latch into a third page.
A system suitable for use in implementing aspects of the invention is shown in
In an embodiment, the storage device 102 comprises a memory controller 106 and a memory 108. Memory 108 may include semiconductor memory devices that store data. In an exemplary embodiment, methods implemented by the memory controller 106 may relocate data stored in the memory 108. The storage device 102 may be in the form of a portable flash drive, an integrated solid state drive or any of a number of known flash drive formats. In yet other embodiments, the storage device 102 may include only a single type of flash memory having one or more partitions.
Memory controller 106 operates to communicate data and program code back and forth between host system 100 and memory 108. The memory controller 106 may convert between logical addresses of data used by the host system 100 and physical addresses of memory 108 during programming and reading of data.
As discussed in more detail below, the storage device 102 may include functions for memory management. In operation, the processor 110 may execute memory management instructions for operation of memory management functions. The memory management functions may control the assignment of the one or more portions of the memory 108 within storage device 102. In a preferred embodiment, memory management functions also include relocating stored data between different portions of memory 108 in response to detecting one or more conditions.
Memory 108 may correspond to any solid state non-volatile memory. Non-volatile memory retains information stored therein even if the storage device 102 is powered down or disconnected from host 100. In an embodiment, memory 108 may be organized as a plurality of memory chunks. Data stored in a memory chunk may be referred to as a data chunk. In this embodiment, a memory chunk is a smallest unit of writing in the memory 108. NAND flash memory is one example of memory 108 that is organized as memory chunks. Each memory chunk may be made up of a number single-level cell (SLC) or multi-level cell (MLC). A SLC memory can store a single bit of data per cell. MLC memory can store multiple bits of data per cell. For example, two-level MLC memory can store 4 bits of data per cell, three level MLC memory can store 8 bits of data per cell and N level MLC memory can store 2N bits of data per cell. Typical sizes of memory chunks are 4096 bytes or 4 Kilobytes (Kbytes). In describing exemplary embodiments herein, the term “cell” is used to refer to both SLC and MLC.
Both types of cells (SLC and MLC) store data by storing electric charge (charge). The amount of charge stored in a cell is representative of the data bit(s) stored in the cell. For example, where no charge is stored in an SLC, the charge value represents a bit value of 0. In contrast, a predefined amount of charge stored in an SLC, represents the bit value of 1. In the case of an N-level MLC, different amounts of charge may be stored to represent anyone of the 2N bits of data. For example, a two-level MLC is configured to store any one of four amounts of charge (22=4).
In an embodiment, the reading circuit 218 of
Memory chunks may be grouped to create physical pages (pages). Pages comprising memory chunks consisting of SLCs may be referred to as SLC type pages and pages comprising memory chunks consisting of MLCs may be referred to as MLC type pages. For example, four memory chunks may be grouped together to form a page. Based on a 4 Kbytes memory chunk size, the size of a page comprising four memory chunks is 16 Kbytes. Pages may be grouped together to form a physical memory block. A memory block consisting of SLC type pages may be referred to as an SLC memory block. A memory block consisting of MLC type pages may be referred to as an MLC memory block. For example, sixteen 16 Kbytes pages may be grouped to create a 256 Kilobytes memory block. Referring to
Memory 108 also includes a programming circuit 220, a reading circuit 218 and transfer data latch (XDL) 224. The XDL 224 functions as intermediate data storage between memory controller 106 and memory 108. When instructed by host 100 to write data to memory 108, memory controller 106 writes data to XDL 224. The programming circuit 220 then writes the data from XDL 224 to the specified memory block and page. By way of example and without limitation, the size of the XDL is equal to the size of a page. Similarly, when instructed to read data from a specified memory chunk or page, reading circuit 218 reads data from the specified memory chunk or page into the XDL 224 and memory controller 106 transfers the read data from the XDL 224 to controller RAM 204.
Generally writing data to a SLC memory block takes less time than writing the same data to an MLC memory block. However, an MLC memory block has a higher density than an SLC memory block. To take advantage of the speed of SLC and density of MLC, memory 108 may consist of both SLC memory blocks and MLC memory blocks, as is the case of the memory 108 of
After a memory chunk in a memory block is written to with data, all memory chunks in the memory block must be erased before processor 202 can write data to the memory chunk. For example, if data is written to memory chunk 212, block 208-1 must be erased before memory chunk 212 can be written to again.
In an embodiment, the memory controller 106 maintains a logical to physical address table 226 in controller RAM 204. An entry in the table 226 includes a reference to a memory chunk. Thus, the logical to physical address table 226 may comprise an array of references to memory chunks. One format of an entry in the table may comprise a reference to the memory block associated with the memory chunk and an index of the memory chunk in the memory block. As an example, a reference to memory chunk 212 may comprise a reference to memory block 208-1 and the index of memory chunk 212 in memory block 208-1.
The host system 100 when requesting a write of a data chunk specifies a logical address. In response to receiving a request from host system 100 to write data to a logical address, processor 202 may utilize the logical address as an index into the logical to physical address table 226 and identify the memory chunk and the memory block corresponding to the logical address. The processor 202 may determine if the identified memory chunk is already written to (old memory chunk). In response to determining that the memory chunk is already written to, processor 202 may locate a new memory chunk that has not been written to and write the received data to the new memory chunk and mark the old memory chunk as invalid. Separately, processor 202 may update the entry in the logical to physical address table 226 corresponding to the logical address with a reference to the new memory chunk and a reference to the block associated with the new page.
As an example, in response to receiving a request from host system 102 to write data to a logical address that references memory chunk 212 and memory block 208-1, processor 202 may determine if memory chunk 212 had been previously written to. In response to determining that memory chunk 212 had been previously written to, processor 202 may locate a memory chunk 216 that has not been written to and write the date received from host processor 202 to memory chunk 216. A memory chunk with invalid data may be referred to as an invalid memory chunk and the data in the invalid memory chunk may be referred to as an invalid data or an invalid data chunk. Processor 212 may mark memory chunk 212 as invalid and update the entry in the logical to physical address table 226 corresponding to the logical address with a reference to memory chunk 216. If however processor 202 determines that memory chunk 212 was not previously written to, processor 202 may write the data to memory chunk 212. In an exemplary embodiment, processor 202 may monitor the number of invalid memory chunks in a page. In response to determining that the number of invalid memory chunks in a page exceeds a threshold, processor 202 may copy the valid data from all of the valid memory chunks out of the page (source page) to unwritten or erased memory chunks associated with a new physical page (destination page). The source page and destination page may be in the same memory block or in different memory blocks. Processor 202 may then update those entries in the logical to physical address table 226 that were associated with the memory chunks from where data was copied with references to memory chunks where the data were copied. Of course, in other embodiments, the processor 202 may compare the number of invalid memory chunks in a memory block with a threshold.
Additionally, in response to detecting errors in the data stored in a memory chunk of a page, processor 202 may move all the data from the page to another page. Errors are introduced because of the structure of the SLC and MLC. As previously explained, SLC and MLC store data by storing electric charge. Over time, it is not uncommon for the charge in a cell to dissipate or for the cell itself to deteriorate, whereby the data stored in the cell may no longer be correct. When the charge in the cell dissipates, the charge level in the cell no longer corresponds to the data (bit(s)) that was initially store in the cell. As a result the data in the cell is no longer correct. The bit is said to be in error. As more and more cells in a memory chunk dissipate their stored charge, the number of bits in error in the memory chunk increases.
An error correction code (ECC) may be implemented to identify and correct errors in the data of a memory chunk. When writing data to a memory chunk, processor 202 may cause the calculation of an error correcting code (ECC). The calculated ECC may be written to the memory chunk along with the data. Calculation of the ECC may be performed by error correcting code (ECC) engine 214. An example ECC is the low-density parity-check code (LDPC). Separately, ECC engine 214 may compute the ECC for data in a memory chunk whenever the data in the memory chunk is read out by memory controller 106. The memory controller 106 may read out the data from the memory chunk in response to receiving a request from host 100. The ECC engine 214 may compare the computed ECC with the ECC that was stored in the memory chunk when the data was written to the memory chunk. Generally, if the number of bits in error or the bit error rate (BER) of the data of a memory chunk is below a threshold, the ECC engine 214 may utilize the ECC stored with the data to recover the bits in error. In an exemplary embodiment, the memory controller 106 may behave in one of several ways based on the magnitude of the difference between the computed ECC and the ECC that was stored in the memory chunk when the data was written to the memory chunk. If the difference in the two ECCs is below a first threshold or a first bit error rate (BER), the ECC engine 214 may not take any action. If the difference in the ECCs is above the first BER, the ECC engine 214 may use the ECC code stored with the block to recover the bits in error and write the corrected data back to a new memory chunk.
Referring to
As previously discussed, the individual pages are in turn divided for operational purposes into memory chunks of memory cells, as illustrated in
Next discussed are several methods of relocating data from one page (source page) to another page (destination page) of a memory, memory 108 for example. The methods discussed may be implemented in the storage device 102 (
Memory controller 106 of
Processor 202 may identify the data corresponding to memory chunks marked as invalid in page 408. Processor 202 may overwrite the invalid data with data from valid memory chunks from other pages. In the example depicted in
Processor 202 may copy the valid data for memory chunks 408-1, 408-2, 408-3 and 412-1 from controller RAM 406 to page 416 of block 404. For example, valid data from memory chunk 408-1 may be relocated to memory chunk 416-1, valid data from memory chunk 408-2 may be relocated to memory chunk 416-2, valid data from memory chunk 408-3 may be relocated to memory chunk 416-3 and valid data from memory chunk 412-1 may be relocated to memory chunk 416-4. By way of example and without limitation, in the foregoing discussion, the pages 408 and 412 are located in the same source memory block 402. In other embodiments, the pages 408 and 412 may be located in different source memory blocks. Because all data relocated from a source memory block to a destination memory block is copied through memory controller 206 components controller RAM 204 and ECC engine 214, the method described with reference to
Separately, processor 202 may identify in another page a memory chunk containing valid data, for example memory chunk 412-1 in page 412. Memory chunk 412-1 may be identified based the difference between a computed ECC for the data in memory chunk 412-1 and the ECC stored with the data which was computed when the data was originally written to memory. For example, based on the difference, the processor 202 may conclude that any further errors in the data in the memory chunk 412-1 may prevent recovery of the bit in error. In response, processor 202 may read the data stored in memory chunk 412-1 and instruct the ECC engine 214 to recover any bit in error in the data. As previously explained, ECC engine 214 may use the ECC stored with the data to recover the bit in error and correct the errors in the data stored in the memory chink 412-1. This error-corrected data may then be stored in controller RAM 204. Processor 202 may execute instructions to replace the invalid data from the invalid memory chunk 408-4 in the transfer data latch 224 with the error-corrected data from controller RAM 204. After the replacement, XDL 224 may contain data from memory chunks 408-1, 408-2 and 408-3 and error corrected data from memory chunk 412-1. Processor 202 may cause the data contained in XDL 224 to be stored to the memory chunks 416-1, 416-2, 416-3 and 416-4 of page 416.
In the preceding discussion, memory controller 106 utilizes the XDL 224 of memory 108 as an intermediate memory location to effectuate the merging of error-corrected valid data from memory chunks from one page with the valid data from memory chunks of a second page. Other embodiments are contemplated where in place of XDL 224, an intermediate non-volatile memory device, conforming for example to a shared memory model between memory 108 and memory controller 106, may be used to perform the above described merging of valid data from different memory chunks. The method of relocation described above may be referred to a “hybrid copy through controller (CTC)” because only some of the memory chunks are copied into controller RAM 204 and subject to ECC verification by ECC engine 214 instead of all the memory chunks as detailed with respect to the
As depicted in
In the preceding discussion of the various methods for relocation of data in memory 108, it is contemplated that data from memory chunks from different pages may be merged using anyone of the above described methods and relocated to a new page. For example, with reference to
At step 802, memory controller 106 may receive an indication to determine if data from memory chunks of pages in a memory block need to be relocated. The indication may be received in response to the completion of a write operation to a page in the memory block. The indication may also be received in response to the expiration of a periodic timer. In an embodiment where processor 202 executes software instructions to effectuate the relocation of data, at step 804, processor 202 may determine if the pages selected for relocation of valid data belong to an MLC memory block or SLC memory block.
In response to determining that the block is an MLC type block, for example 210-1, processor 202 may execute the method steps associated with step 806, in an embodiment. At step 806, an available MLC type memory block may be identified. An available MLC type memory block is one whose pages contain no valid data, for example 210-M. At step 806, processor 202 may determine if the available MLC type memory block is erased. In response to determining that the available MLC type memory block is not erased, processor 202 may cause the erasure of the available MLC type block. Erasure may be effectuated by operating the programming circuit 220 of
In an embodiment, at step 806, the contents of the block targeted for relocation, example MLC memory block 210-1, may be read into controller RAM 204. Processor 202 may execute software instructions that cause the reading circuit 218 to read the contents of the pages of the MLC memory block 210-1 into controller RAM 204. Processor 202 may identify data associated with invalid pages in the contents of the controller RAM 204. Processor 202 may overwrite the data associated with invalid pages with data associated with valid pages. Thus, in effect, the valid pages within the block are relocated. In an embodiment, replacement of data may be performed to create a contiguous group of pages with valid data. At step 606, references in the logical to physical address table 216 may be updated to point to the new page locations for the valid data. Processor 202 may instruct ECC engine 214 to compute a new ECC for the relocated contents of the memory block. Processor 202 may cause the relocated data to be copies to the transfer data latch (XDL) 224 and instruct the programming circuit 220 to write the data in the XDL 224 to the previously identified and erased available MLC memory block 210-M for example. Processor 202 may mark the MLC memory block 210-1 as being available to be erased. Generally, the method steps 806 may correspond to the copy through controller method described with reference to
Returning back to step 804, in response to determining that data selected for relocation is stored in memory chunks of an SLC memory block, for example 208-1, memory controller 106 may identify the number of memory chunks with invalid data and compare the number with a first threshold at step 808. In response to determining that the number is below the first threshold, at step 810, ECC may be computed for data from the memory chunks. The ECC may be recomputed by ECC engine 214. Based on recomputed ECC and the FCC originally stored with the data when the data was first written to the memory chunks, at step a BER may be determined. As previously discussed the BER may correspond to a difference between the recomputed ECC and the original ECC. The BER may be compared to a BER threshold. In response to determining that the BER is less than the BER threshold, data from the memory chunks may be copied to a destination memory block using the steps detailed in the on-chip copy (OCC) method described with reference to
However, in response to determining the number is above the first threshold, at step 810, the method may branch to step and perform the steps of copy through controller RAM described with respect to
Returning to step 808, in response to determining that the number of memory chunks with invalid data is above the first threshold, method 800 may branch to step 814 and compare the number of memory chunks with invalid data is below a second threshold. In response to determining that the number of memory chunks with invalid data is above a second threshold, at step 816 a BER may be computed for the memory chunks with valid data. As previously explained, the BER may be calculated by computing the ECC for the valid data in the memory chunks and comparing it with the originally computed ECC when the data was written to the memory chunks. By way of example and without limitation, BER is computed based on the ECC. Other methods of computing BER are contemplated. If the BER is less than a second BER threshold, valid data from memory chunks from the source memory block may be relocated to a destination memory block using the method steps described with reference to
If at step 814, the number of memory chunks with invalid data is equal to below the second threshold, method 800 branches to step 820 and implements the combined copy through controller and on-chip copy method detailed with reference to
By way of example and without limitation, in the foregoing discussion, the number of invalid memory chunks and the BER corresponding to memory chunks with valid data are two metrics used to select between the different relocation methods. One skilled in the art will recognize that other metrics may be used to select the appropriate relocation method.
As has been described above, several different methods of relocating data between memory chunks in a memory system are discussed. Some of the methods involve performing computationally intensive ECC checksums using the ECC engine before the data is relocated. Other methods involve using the transfer data latch to perform the relocation which is a relatively inexpensive computation. Still other methods use a combination of the two methods discussed in the paragraph to merge in the transfer data latch ECC check-summed memory chunks from one page with non-ECC check-summed memory chunks from another page. Separately, a method and system that selectively using one of the several methods to relocate data is described. The selection of a method is based on one or more criteria including for example number of invalid memory chunks in a page and BER of the valid data in the memory chunks of a page. By using the BER as a criteria in selecting a method, the computational expensive ECC checksum operation can be skipped when relocating data if the bits in error are below the BER threshold.
Semiconductor memory devices include volatile memory devices, such as dynamic random access memory (“DRAM”) or static random access memory (“SRAM”) devices, non-volatile memory devices, such as resistive random access memory (“ReRAM”), electrically erasable programmable read only memory (“EEPROM”), flash memory (which can also be considered a subset of EEPROM), ferroelectric random access memory (“FRAM”), and magnetoresistive random access memory (“MRAM”), and other semiconductor elements capable of storing information. Each type of memory device may have different configurations. For example, flash memory devices may be configured in a NAND or a NOR configuration.
The memory devices can be formed from passive and/or active elements, in any combinations. By way of non-limiting example, passive semiconductor memory elements include ReRAM device elements, which in some embodiments include a resistivity switching storage element, such as an anti-fuse, phase change material, etc., and optionally a steering element, such as a diode, etc. Further by way of non-limiting example, active semiconductor memory elements include EEPROM and flash memory device elements, which in some embodiments include elements containing a charge storage region, such as a floating gate, conductive nanoparticles, or a charge storage dielectric material.
Multiple memory elements may be configured so that they are connected in series or so that each element is individually accessible. By way of non-limiting example, flash memory devices in a NAND configuration (NAND memory) typically contain memory elements connected in series. A NAND memory array may be configured so that the array is composed of multiple strings of memory in which a string is composed of multiple memory elements sharing a single bit line and accessed as a group. Alternatively, memory elements may be configured so that each element is individually accessible, e.g., a NOR memory array. NAND and NOR memory configurations are exemplary, and memory elements may be otherwise configured.
The semiconductor memory elements located within and/or over a substrate may be arranged in two or three dimensions, such as a two dimensional memory structure or a three dimensional memory structure.
In a two dimensional memory structure, the semiconductor memory elements are arranged in a single plane or a single memory device level. Typically, in a two dimensional memory structure, memory elements are arranged in a plane (e.g., in an x-z direction plane) which extends substantially parallel to a major surface of a substrate that supports the memory elements. The substrate may be a wafer over or in which the layer of the memory elements are formed or it may be a carrier substrate which is attached to the memory elements after they are formed. As a non-limiting example, the substrate may include a semiconductor such as silicon.
The memory elements may be arranged in the single memory device level in an ordered array, such as in a plurality of rows and/or columns. However, the memory elements may be arrayed in non-regular or non-orthogonal configurations. The memory elements may each have two or more electrodes or contact lines, such as bit lines and word lines.
A three dimensional memory array is arranged so that memory elements occupy multiple planes or multiple memory device levels, thereby forming a structure in three dimensions (i.e., in the x, y and z directions, where the y direction is substantially perpendicular and the x and z directions are substantially parallel to the major surface of the substrate).
As a non-limiting example, a three dimensional memory structure may be vertically arranged as a stack of multiple two dimensional memory device levels. As another non-limiting example, a three dimensional memory array may be arranged as multiple vertical columns (e.g., columns extending substantially perpendicular to the major surface of the substrate, i.e., in the y direction) with each column having multiple memory elements in each column. The columns may be arranged in a two dimensional configuration, e.g., in an x-z plane, resulting in a three dimensional arrangement of memory elements with elements on multiple vertically stacked memory planes. Other configurations of memory elements in three dimensions can also constitute a three dimensional memory array.
By way of non-limiting example, in a three dimensional NAND memory array, the memory elements may be coupled together to form a NAND string within a single horizontal (e.g., x-z) memory device levels. Alternatively, the memory elements may be coupled together to form a vertical NAND string that traverses across multiple horizontal memory device levels. Other three dimensional configurations can be envisioned wherein some NAND strings contain memory elements in a single memory level while other strings contain memory elements which span through multiple memory levels. Three dimensional memory arrays may also be designed in a NOR configuration and in a ReRAM configuration.
Typically, in a monolithic three dimensional memory array, one or more memory device levels are formed above a single substrate. Optionally, the monolithic three dimensional memory array may also have one or more memory layers at least partially within the single substrate. As a non-limiting example, the substrate may include a semiconductor such as silicon. In a monolithic three dimensional array, the layers constituting each memory device level of the array are typically formed on the layers of the underlying memory device levels of the array. However, layers of adjacent memory device levels of a monolithic three dimensional memory array may be shared or have intervening layers between memory device levels.
Then again, two dimensional arrays may be formed separately and then packaged together to form a non-monolithic memory device having multiple layers of memory. For example, non-monolithic stacked memories can be constructed by forming memory levels on separate substrates and then stacking the memory levels atop each other. The substrates may be thinned or removed from the memory device levels before stacking, but as the memory device levels are initially formed over separate substrates, the resulting memory arrays are not monolithic three dimensional memory arrays. Further, multiple two dimensional memory arrays or three dimensional memory arrays (monolithic or non-monolithic) may be formed on separate chips and then packaged together to form a stacked-chip memory device.
Associated circuitry is typically required for operation of the memory elements and for communication with the memory elements. As non-limiting examples, memory devices may have circuitry used for controlling and driving memory elements to accomplish functions such as programming and reading. This associated circuitry may be on the same substrate as the memory elements and/or on a separate substrate. For example, a controller for memory read-write operations may be located on a separate controller chip and/or on the same substrate as the memory elements.
One of skill in the art will recognize that this invention is not limited to the two dimensional and three dimensional exemplary structures described but cover all relevant memory structures within the spirit and scope of the invention as described herein and as understood by one of skill in the art.
Further embodiments can be envisioned by one of ordinary skill in the art after reading the foregoing. In other embodiments, combinations or sub-combinations of the above disclosed invention can be advantageously made. The block diagrams of the architecture and flow diagrams are grouped for ease of understanding. However it should be understood that combinations of blocks, additions of new blocks, re-arrangement of blocks, and the like are contemplated in alternative embodiments of the present invention.
The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense. It will, however, be evident that various modifications and changes may be made thereunto without departing from the broader spirit and scope of the invention as set forth in the claims.
Huang, Jianmin, Luo, Ting, Yang, Niles
Patent | Priority | Assignee | Title |
10353622, | Oct 08 2015 | Seagate Technology LLC | Internal copy-back with read-verify |
9619321, | Oct 08 2015 | Seagate Technology LLC | Internal copy-back with read-verify |
Patent | Priority | Assignee | Title |
6651208, | Apr 04 2000 | Promos Technologies Inc | Method and system for multiple column syndrome generation |
6675349, | May 11 2000 | International Business Machines Corporation | Error correction coding of data blocks with included parity bits |
6738947, | Oct 25 1999 | MATSUSHITA ELECTRIC INDUSTRIAL CO , LTD | Method and apparatus for error correction |
6907559, | Dec 22 2000 | CALLAHAN CELLULAR L L C | Method and apparatus for data reproduction |
8187936, | Jun 30 2010 | SanDisk Technologies LLC | Ultrahigh density vertical NAND memory device and method of making thereof |
20050149833, | |||
20100064111, | |||
20110238899, | |||
20120284587, | |||
20150106556, | |||
20150262714, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 30 2014 | SanDisk Technologies Inc. | (assignment on the face of the patent) | / | |||
Mar 27 2015 | YANG, NILES | SanDisk Technologies Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035297 | /0496 | |
Mar 27 2015 | HUANG, JIANMIN | SanDisk Technologies Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035297 | /0496 | |
Mar 27 2015 | LUO, TING | SanDisk Technologies Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 035297 | /0496 | |
May 16 2016 | SanDisk Technologies Inc | SanDisk Technologies LLC | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 038807 | /0948 |
Date | Maintenance Fee Events |
Jul 04 2019 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Sep 11 2023 | REM: Maintenance Fee Reminder Mailed. |
Feb 26 2024 | EXP: Patent Expired for Failure to Pay Maintenance Fees. |
Date | Maintenance Schedule |
Jan 19 2019 | 4 years fee payment window open |
Jul 19 2019 | 6 months grace period start (w surcharge) |
Jan 19 2020 | patent expiry (for year 4) |
Jan 19 2022 | 2 years to revive unintentionally abandoned end. (for year 4) |
Jan 19 2023 | 8 years fee payment window open |
Jul 19 2023 | 6 months grace period start (w surcharge) |
Jan 19 2024 | patent expiry (for year 8) |
Jan 19 2026 | 2 years to revive unintentionally abandoned end. (for year 8) |
Jan 19 2027 | 12 years fee payment window open |
Jul 19 2027 | 6 months grace period start (w surcharge) |
Jan 19 2028 | patent expiry (for year 12) |
Jan 19 2030 | 2 years to revive unintentionally abandoned end. (for year 12) |