US20080126680A1 - Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics - Google Patents
Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics Download PDFInfo
- Publication number
- US20080126680A1 US20080126680A1 US11/640,304 US64030406A US2008126680A1 US 20080126680 A1 US20080126680 A1 US 20080126680A1 US 64030406 A US64030406 A US 64030406A US 2008126680 A1 US2008126680 A1 US 2008126680A1
- Authority
- US
- United States
- Prior art keywords
- write data
- data
- file system
- volatile memory
- transition layer
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0613—Improving I/O performance in relation to throughput
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0616—Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/0643—Management of files
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/068—Hybrid storage device
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C11/00—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C11/56—Digital stores characterised by the use of particular electric or magnetic storage elements; Storage elements therefor using storage elements with more than two stable states represented by steps, e.g. of voltage, current, phase, frequency
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7202—Allocation control and policies
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2212/00—Indexing scheme relating to accessing, addressing or allocation within memory systems or architectures
- G06F2212/72—Details relating to flash memory management
- G06F2212/7211—Wear leveling
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C2211/00—Indexing scheme relating to digital stores characterized by the use of particular electric or magnetic storage elements; Storage elements therefor
- G11C2211/56—Indexing scheme relating to G11C11/56 and sub-groups for features not covered by these groups
- G11C2211/564—Miscellaneous aspects
- G11C2211/5641—Multilevel memory having cells with different number of storage levels
Definitions
- the present invention relates to a non-volatile memory system. More particularly, the invention relates to a non-volatile memory system storing data in a single-level cell or a multi-level cell according to one or more characteristics of the data.
- Non-volatile memory systems such as those using flash memory, have found increasing application in variety of host devices, such as computers, cellular telephones, digital video devices, etc.
- Non-volatile memory systems have historically been built around either single bit (or level) memory cells or multiple level memory cells.
- the use of single level memory cells offers performance advantages, while the use of multi-level memory cells allows greater data storage capacity per unit chip area.
- non-volatile memory systems including both a single-level cell and a multi-level cell has been proposed.
- Such memory systems provide increased operating flexibility in that single-level memory cells may be accessed when high performance and endurance are required, while the provision of multi-level memory cells improves data storage capacity and price competitiveness.
- some capability must exits for determining whether or not received data should be stored in single-level or multi-level memory cells.
- Embodiments of the invention provide a non-volatile memory system storing data in single-level or multi-level memory cells in accordance with one or more characteristics of the data.
- the invention provides a system storing write data received from at least one of an application and a file system in a non-volatile memory system
- the non-volatile memory system comprises; a non-volatile memory cell array having a plurality of multi-level cells forming a MLC area and a plurality of single-level cells forming a SLC area, an interface unit analyzing a characteristic of the write data and generating a corresponding data characteristic signal, and a flash transition layer determining whether the write data should be stored in the MLC area or the SLC area on the basis of the data characteristic signal.
- the interface unit may be located on the same abstraction layer on which the application or the file system is located.
- the interface unit may also be located on a different abstraction layer than the flash transition layer.
- the interface unit may comprise a file system interface that analyzes the characteristic of write data received from the file system and communicates a corresponding data characteristic signal to the flash transition layer, or an application interface that determines whether an address associated with write data received from the application is frequently updated and communicates a corresponding data characteristic signal to the flash transition layer.
- the flash transition layer may comprise a hybrid algorithm unit that determines that the write data should be written to the SLC area or the MLC area on the basis of the data characteristic signal, or a mapping unit capable of mapping an address for the write data into a physical address for the non-volatile memory cell array.
- the invention provides in a system storing write data received from at least one of an application and a file system in a non-volatile memory system
- the non-volatile memory system comprises; a non-volatile memory cell array having a plurality of multi-level cells forming a MLC area and a plurality of single-level cells forming a SLC area, and a flash transition layer analyzing a characteristic of the write data and generating a corresponding data characteristic signal and determining whether the write data should be stored in the MLC area or the SLC area on the basis of the data characteristic signal.
- the flash transition layer may comprise; a file system aware unit determining whether write data received from the file system is accessed by the file system and generating a corresponding data characteristic signal, an application aware unit determining whether an address associated with write data received from the application is frequently updated and generating a corresponding data characteristic signal, and a hybrid algorithm unit determining whether the write data received respectively from the application and the file system should be written to the MLC area or the SLC area on the basis of either data characteristic signal generated by the file system aware unit and the application ware unit.
- the flash transition layer may further comprise a data block history storage unit including a plurality of entries; each entry comprising a data block number identifying a corresponding data block, a count value indicating a number of times the corresponding data block has been accessed by the system, and a least recently used value.
- FIG. 1 is a block diagram of a general computational system according to an embodiment of the present invention
- FIG. 2 is a diagram illustrating an approach, consistent with an embodiment of the present invention, of determining single-level verses multi-level memory cell storage of data according to its characteristics;
- FIG. 3 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in a file system interface and/or a flash transition layer during a data write operation within a non-volatile memory system such as the one illustrated in FIG. 1 ;
- FIG. 4 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in an application interface and/or a flash transition layer during a data write operation in a non-volatile memory system such as the one illustrated in FIG. 1 ;
- FIG. 5 is a block diagram of a general computational system according to another embodiment of the present invention.
- FIG. 6 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in an application data determination unit within a non-volatile memory system such as the one illustrated in FIG. 5 ;
- FIG. 7 is a diagram further illustrating the operation of a data block history storage unit according to an embodiment of the invention.
- FIG. 1 is a block diagram of a general system 100 according to an embodiment of the invention.
- a non-volatile memory system within system 100 includes a non-volatile memory cell array 190 , an interface unit 120 , and a flash transition layer 150 .
- An application 110 and a file system 130 are also shown in FIG. 1 for convenience of explanation.
- application 110 and/or file system 130 may be variously implemented in software and/or hardware.
- application 110 may be a program running on an operating system within a host device.
- the operating system and/or application 110 may control file system 130 .
- non-volatile memory cell array 190 includes a plurality of multi-level cells (MLC) located in a MLC area 194 and a plurality of single-level cells (SLC) located in a SLC area 192 .
- MLC multi-level cells
- SLC single-level cells
- area is used here to generally denote a collection of memory cell types.
- Such SL and ML memory cells need not be separately provided in distinct regions, but may be provided in any reasonable fashion.
- Interface unit 120 shown in FIG. 1 conceptually represents specialized software and/or hardware adapted to interface application 110 and file system 130 with the memory cell resources provided by memory system 100 .
- Interface unit 120 receives and analyzes the characteristics of data received from file system 130 , for example, and generate a corresponding data characteristic signal.
- flash transition layer 150 determines whether the data should be written to MLC area 194 or SLC area 192 .
- interface unit 120 is located on the same abstraction layer on which application 110 and file system 130 are loacted. Interface unit 120 may therefore is located on a different abstraction layer within system 100 than flash transition layer 150 . With this architecture, interface unit 120 may readily analyze one or more characteristics of write data received from an external source responsive to application 110 and/or file system 130 .
- Interface unit 120 may be conceptually viewed as having a file system interface 145 and an application interface 125 .
- File system interface 145 may be used to determine characteristics of “write data” being communicated from file system 130 through flash transition layer 150 . For example, file system interface 145 may determine whether the address associated with the write data corresponds to a designated FAT region and/or meta data region of an external memory. The determination result is then communicated to flash transition layer 150 as a data characteristic signal.
- flash transition layer 150 include a hybrid algorithm unit 160 and a mapping unit 170 .
- Hybrid algorithm unit 160 decides whether the write data should be written to SLC area 192 or the MLC area 194 on the basis of the data characteristic signal. For example, when the write data is associated with a particular functionality of or data type within file system 130 , a determination may be made that such data should be written to SLC area 192 . In contrast, write data associated with sources other than file system 130 may result in a determination that such data should be written to MLC area 194 . In one embodiment, write data that is frequently accessed (“frequently updated data”) by file system 130 will be stored in SLC area 192 of non-volatile memory cell array 190 .
- application interface 125 within interface unit 120 may be used to determine whether a write data address indicates “frequently updated data”, and communicate a corresponding data characteristic signal to flash transition layer 150 .
- FIG. 3 is a flow chart of an exemplary method executable by file system interface 145 and/or flash transition layer 150 during a data write operation within system 100 incorporating non-volatile memory cell array 190 , as described in relation to FIG. 1 .
- file system interface 145 receives data to be written to non-volatile memory cell array 190 (hereafter “write data”) from file system 130 ( 310 ).
- File system interface 145 determines whether the write data is associated with an address that is frequently updated ( 320 ). When the write data is associated with a frequently updated address, file system interface 145 sets an OFAST flag value in a location accessible to flash transition layer 150 , as one particular form of a data characteristic signal ( 330 ).
- file system interface 145 sets an OSLOW flag value ( 335 ). Either one of these flag values may subsequently be communicated in relation to (or define) a respective write command identifying SLC area 192 or MLC area 194 within non-volatile memory cell array 190 ( 340 or 345 ).
- OSLOW flag value 335
- SLC area 192 or MLC area 194 within non-volatile memory cell array 190
- FIG. 4 is a flow chart of an exemplary method executable by application interface 125 and/or flash transition layer 150 during a data write operation within system 100 incorporating non-volatile memory cell array 190 , as described in relation to FIG. 1 .
- application interface 125 receives write data from application 110 ( 410 ). Then, application interface 125 determines whether the write data is meta data or FAT data ( 420 ). There are various techniques for doing this, such as reference to header data associated with the write data. In one embodiment consistent with the example presented in FIG. 3 , when the write data is meta data or FAT data, application interface 125 sets the OFAST flag value in a location accessible by flash transition layer 150 , as one form of a data characteristic signal.
- application interface 125 sets the OSLOW flag value ( 430 , 435 ).
- either one of these flag values may subsequently be communicated in relation to (or define) a respective write command identifying SLC area 192 or MLC area 194 within non-volatile memory cell array 190 ( 440 or 445 ).
- hybrid algorithm unit 160 of flash transition layer 150 may be used to determine whether the write data should be written to SLC area 192 or MLC area 194 in response a received data type signal or an address frequency update signal.
- the data type e.g. meta data or FAT data
- the data type signal may in certain embodiments be inherently related to a frequency of access characteristic.
- write data associated with frequently accessed address locations or identified as a frequently accessed type of data result in such data being stored in SLC area 192 .
- Other types of data associated with less frequently accessed addresses or less frequently accessed data types are conversely stored in MLC area 194 .
- FIG. 2 is a conceptual diagram illustrating various data types commonly found or generated by contemporary applications. These are merely selected examples, and each particular application will have its own “fast” and “slow” data types. However, in the illustrated example, Volinfo data 211 , frequently (freq.) accessed address data 216 and meta data 217 are indicated as “fast” data that should be written to SLC area 192 . In contrast, operating system (OS) data 213 , application (Apps) data 214 , and general data 215 are indicated as “slow” data that should be written to MLC 194 . Differentiation between fast and slow data types in this regard may be had by reference to the address of the data as stored in an external memory, associated data header information, an external command or command type, etc.
- OS operating system
- Apps application
- write operations are commonly performed to non-volatile memory cell array 190 using the same address as the address of data stored in a FAT region of a memory.
- data from the FAT region be written to SLC area 192 to avoid data translation overhead.
- Meta data is commonly used to accomplish write buffering and mapping functions associated with flash transition layer 150 . As such, meta data is frequently updated. It is therefore preferable in some embodiments that meta data be written to SLC area 192 . This is similarly true for other frequently updated data.
- flash transition layer 150 may further include a mapping unit 170 .
- Mapping unit 170 maps the address of write data into a physical address identifying specific memory cells within non-volatile memory cell array 190 . This function may be implemented in various conventionally understood methods.
- FIG. 1 is a block diagram of a general system 100 according to an embodiment of the invention.
- system 500 includes a non-volatile memory cell array 590 and a flash transition layer 550 .
- Non-volatile memory cell array 590 includes a plurality of multi-level cells in a MLC area 594 and a plurality of single-level cells in a SLC area 592 .
- Flash transition layer 550 receives write data from an application 510 and/or a file system 530 and stores that write data in MLC area 594 or SLC area 592 of non-volatile memory cell array 590 in accordance with one or more characteristics.
- flash transition layer 550 of FIG. 5 includes include a file system aware unit 540 and an application aware unit 520 in addition to a hybrid algorithm unit 560 .
- the functionality provided by application interface 125 and file system interface 145 may be subsumed in these additional flash translation layer units. This capability is particularly useful when the host device incorporating a memory system consistent with the subject invention has limited interface capabilities.
- File system aware unit 540 may be used to determine whether write data received from file system 530 or some other source has one or more characteristics indicating “fast” data to be stored in SLC area 592 .
- Application aware unit 520 may be used to make a similar determination in relation to write data received from application 510 .
- File system aware unit 540 and/or application aware unit 520 may communicate any number of data characteristic indications in this regard (e.g., a frequently accessed address signal, a data type signal, etc.).
- hybrid algorithm unit 560 may be used to determine whether the write data from application 510 or file system 530 should be written to MLC area 594 or SLC area 592 of non-volatile memory cell array 590 .
- file system aware unit 540 is used to determine whether the write data has an address corresponding to a FAT memory region and/or an address corresponding to meta data region of an external memory.
- hybrid algorithm unit 560 may be used to determine that data being stored and accessed by file system 530 should be stored in SLC area 592 . Hybrid algorithm unit 560 will thus determine that write data received from or accessed by other sources should be stored in MLC area 594 .
- hybrid algorithm unit 560 may be used to determine that the write data should be written to SLC area 592 when the address of the data is frequently updated. Data associated with less frequently updated addresses will be written to MLC area 594 .
- Flash transition layer 550 may further include a data block history storage unit, such as those conceptually illustrated in FIG. 7 .
- Such data block history storage unit may be used to store a plurality of entries. Each entry contains information about a data block number of a data block corresponding thereto, as well as the number of times the data block has been accessed, updated in sequence, etc.
- application aware unit 520 may be used to reference the data block history storage unit and determine whether an address associated with certain write data is frequently updated.
- FIG. 6 is a flow chart of an exemplary method executable within application aware unit 520
- FIG. 7 is a conceptual diagram of corresponding data block history storage units.
- Application aware unit 520 obtains a logic block number (Blk Num) of received write data ( 610 , 620 ) and determines whether the received logic block number is identical to one of the data block number entries already stored in a data block history storage unit ( 630 ). When the received logic block number is identified as one of the stored data block number entries in the data block history storage unit, a count value (Cnt) associated with the entry is incremented ( 640 ). When the count value for a particular logic block number reaches a defined threshold value, the corresponding block of write data is identified as “frequently updated data” ( 650 , 660 ).
- application aware unit 520 identifies whether the data block history storage unit has an empty entry ( 670 ).
- the entry having the smallest least recently used (LRU) value is deleted ( 680 ), and an entry for the write data is made newly allocated entry position within the data block history storage unit ( 690 ).
- LRU least recently used
- FIGS. 7( a ) through 7 ( c ) The sequential update of an exemplary data block history storage unit is shown in the data progression between FIGS. 7( a ) through 7 ( c ).
- the data block history storage unit initially has the entries shown in FIG. 7( a ). Then an additional entry is made in FIG. 7( b ) for write data associated with a logic block number 100 . Note that this entry has a single count value of 1 and a LRU value of 11—the highest LRU value in the data block history storage unit. Subsequently, another entry is required, but the data block history storage unit has a maximum number of entries.
- the oldest entry i.e., the least recently used data—as indicated by the lowest LRU value
- the oldest entry is deleted and replaced by a new entry associated with write data having a logic block number of 120 .
- This approach is just one of many approaches that may be used to identify certain data as “frequently updated data”. Based on this identification, a determination may be subsequently made with a non-volatile memory system as to whether the write data should be stored in a single-level memory cell or a multi-level memory cell portion of memory.
- the “frequently updated data” status is just one of many characteristics upon which such a determination may be made to improve overall performance of the memory system.
Abstract
Description
- 1. Field of the Invention
- The present invention relates to a non-volatile memory system. More particularly, the invention relates to a non-volatile memory system storing data in a single-level cell or a multi-level cell according to one or more characteristics of the data.
- This application claims the benefit of Korean Patent Application No. 10-2006-0108382, filed on Nov. 3, 2006, the subject matter of which is hereby incorporated by reference.
- 2. Description of the Related Art
- Non-volatile memory systems, such as those using flash memory, have found increasing application in variety of host devices, such as computers, cellular telephones, digital video devices, etc.
- Non-volatile memory systems have historically been built around either single bit (or level) memory cells or multiple level memory cells. The use of single level memory cells offers performance advantages, while the use of multi-level memory cells allows greater data storage capacity per unit chip area.
- More recently, however, non-volatile memory systems including both a single-level cell and a multi-level cell has been proposed. Such memory systems provide increased operating flexibility in that single-level memory cells may be accessed when high performance and endurance are required, while the provision of multi-level memory cells improves data storage capacity and price competitiveness. However, to efficiently use both single-level and multi-level memory cells in a common memory system, some capability must exits for determining whether or not received data should be stored in single-level or multi-level memory cells.
- Embodiments of the invention provide a non-volatile memory system storing data in single-level or multi-level memory cells in accordance with one or more characteristics of the data.
- In one embodiment, the invention provides a system storing write data received from at least one of an application and a file system in a non-volatile memory system, the non-volatile memory system comprises; a non-volatile memory cell array having a plurality of multi-level cells forming a MLC area and a plurality of single-level cells forming a SLC area, an interface unit analyzing a characteristic of the write data and generating a corresponding data characteristic signal, and a flash transition layer determining whether the write data should be stored in the MLC area or the SLC area on the basis of the data characteristic signal.
- The interface unit may be located on the same abstraction layer on which the application or the file system is located. The interface unit may also be located on a different abstraction layer than the flash transition layer.
- The interface unit may comprise a file system interface that analyzes the characteristic of write data received from the file system and communicates a corresponding data characteristic signal to the flash transition layer, or an application interface that determines whether an address associated with write data received from the application is frequently updated and communicates a corresponding data characteristic signal to the flash transition layer.
- The flash transition layer may comprise a hybrid algorithm unit that determines that the write data should be written to the SLC area or the MLC area on the basis of the data characteristic signal, or a mapping unit capable of mapping an address for the write data into a physical address for the non-volatile memory cell array.
- In another embodiment, the invention provides in a system storing write data received from at least one of an application and a file system in a non-volatile memory system, the non-volatile memory system comprises; a non-volatile memory cell array having a plurality of multi-level cells forming a MLC area and a plurality of single-level cells forming a SLC area, and a flash transition layer analyzing a characteristic of the write data and generating a corresponding data characteristic signal and determining whether the write data should be stored in the MLC area or the SLC area on the basis of the data characteristic signal.
- The flash transition layer may comprise; a file system aware unit determining whether write data received from the file system is accessed by the file system and generating a corresponding data characteristic signal, an application aware unit determining whether an address associated with write data received from the application is frequently updated and generating a corresponding data characteristic signal, and a hybrid algorithm unit determining whether the write data received respectively from the application and the file system should be written to the MLC area or the SLC area on the basis of either data characteristic signal generated by the file system aware unit and the application ware unit.
- The flash transition layer may further comprise a data block history storage unit including a plurality of entries; each entry comprising a data block number identifying a corresponding data block, a count value indicating a number of times the corresponding data block has been accessed by the system, and a least recently used value.
-
FIG. 1 is a block diagram of a general computational system according to an embodiment of the present invention; -
FIG. 2 is a diagram illustrating an approach, consistent with an embodiment of the present invention, of determining single-level verses multi-level memory cell storage of data according to its characteristics; -
FIG. 3 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in a file system interface and/or a flash transition layer during a data write operation within a non-volatile memory system such as the one illustrated inFIG. 1 ; -
FIG. 4 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in an application interface and/or a flash transition layer during a data write operation in a non-volatile memory system such as the one illustrated inFIG. 1 ; -
FIG. 5 is a block diagram of a general computational system according to another embodiment of the present invention; -
FIG. 6 is a flow chart of an exemplary method, consistent with an embodiment of the invention, executable in an application data determination unit within a non-volatile memory system such as the one illustrated inFIG. 5 ; and -
FIG. 7 is a diagram further illustrating the operation of a data block history storage unit according to an embodiment of the invention. - Embodiments of the invention will now be described in some additional detail with reference to the accompanying drawings. The invention may, however, be embodied in many different forms and should not be construed as being limited to only the embodiments set forth herein. Rather, these embodiments are presented as teaching examples. Throughout the written description and drawings, like reference numerals indicate like or similar elements.
-
FIG. 1 is a block diagram of ageneral system 100 according to an embodiment of the invention. Referring toFIG. 1 , a non-volatile memory system withinsystem 100 includes a non-volatilememory cell array 190, aninterface unit 120, and aflash transition layer 150. Anapplication 110 and afile system 130 are also shown inFIG. 1 for convenience of explanation. Those of ordinary skill in the art will recognize thatapplication 110 and/orfile system 130 may be variously implemented in software and/or hardware. For example,application 110 may be a program running on an operating system within a host device. The operating system and/orapplication 110 may controlfile system 130. - In the illustrated example, non-volatile
memory cell array 190 includes a plurality of multi-level cells (MLC) located in aMLC area 194 and a plurality of single-level cells (SLC) located in aSLC area 192. The term “area” is used here to generally denote a collection of memory cell types. Such SL and ML memory cells need not be separately provided in distinct regions, but may be provided in any reasonable fashion.Interface unit 120 shown inFIG. 1 conceptually represents specialized software and/or hardware adapted tointerface application 110 andfile system 130 with the memory cell resources provided bymemory system 100.Interface unit 120 receives and analyzes the characteristics of data received fromfile system 130, for example, and generate a corresponding data characteristic signal. In response to the data characteristic signal,flash transition layer 150 determines whether the data should be written toMLC area 194 orSLC area 192. - In one embodiment,
interface unit 120 is located on the same abstraction layer on whichapplication 110 andfile system 130 are loacted.Interface unit 120 may therefore is located on a different abstraction layer withinsystem 100 thanflash transition layer 150. With this architecture,interface unit 120 may readily analyze one or more characteristics of write data received from an external source responsive toapplication 110 and/orfile system 130. -
Interface unit 120 may be conceptually viewed as having afile system interface 145 and anapplication interface 125.File system interface 145 may be used to determine characteristics of “write data” being communicated fromfile system 130 throughflash transition layer 150. For example,file system interface 145 may determine whether the address associated with the write data corresponds to a designated FAT region and/or meta data region of an external memory. The determination result is then communicated to flashtransition layer 150 as a data characteristic signal. - In the illustrated example,
flash transition layer 150 include ahybrid algorithm unit 160 and amapping unit 170.Hybrid algorithm unit 160 decides whether the write data should be written toSLC area 192 or theMLC area 194 on the basis of the data characteristic signal. For example, when the write data is associated with a particular functionality of or data type withinfile system 130, a determination may be made that such data should be written toSLC area 192. In contrast, write data associated with sources other thanfile system 130 may result in a determination that such data should be written toMLC area 194. In one embodiment, write data that is frequently accessed (“frequently updated data”) byfile system 130 will be stored inSLC area 192 of non-volatilememory cell array 190. - In the illustrated example,
application interface 125 withininterface unit 120 may be used to determine whether a write data address indicates “frequently updated data”, and communicate a corresponding data characteristic signal toflash transition layer 150. -
FIG. 3 is a flow chart of an exemplary method executable byfile system interface 145 and/orflash transition layer 150 during a data write operation withinsystem 100 incorporating non-volatilememory cell array 190, as described in relation toFIG. 1 . Referring toFIG. 3 ,file system interface 145 receives data to be written to non-volatile memory cell array 190 (hereafter “write data”) from file system 130 (310).File system interface 145 determines whether the write data is associated with an address that is frequently updated (320). When the write data is associated with a frequently updated address,file system interface 145 sets an OFAST flag value in a location accessible toflash transition layer 150, as one particular form of a data characteristic signal (330). In contrast, when the write data is not associated with a frequently updated address,file system interface 145 sets an OSLOW flag value (335). Either one of these flag values may subsequently be communicated in relation to (or define) a respective write command identifyingSLC area 192 orMLC area 194 within non-volatile memory cell array 190 (340 or 345). However, those of ordinary skill in the art will recognize that there are many other ways to implement a data characteristic signal. -
FIG. 4 is a flow chart of an exemplary method executable byapplication interface 125 and/orflash transition layer 150 during a data write operation withinsystem 100 incorporating non-volatilememory cell array 190, as described in relation toFIG. 1 . Referring toFIG. 4 ,application interface 125 receives write data from application 110 (410). Then,application interface 125 determines whether the write data is meta data or FAT data (420). There are various techniques for doing this, such as reference to header data associated with the write data. In one embodiment consistent with the example presented inFIG. 3 , when the write data is meta data or FAT data,application interface 125 sets the OFAST flag value in a location accessible byflash transition layer 150, as one form of a data characteristic signal. However, when the write data is not meta data or FAT data,application interface 125 sets the OSLOW flag value (430, 435). Here again, either one of these flag values may subsequently be communicated in relation to (or define) a respective write command identifyingSLC area 192 orMLC area 194 within non-volatile memory cell array 190 (440 or 445). - In relation to either one or both of the foregoing exemplary methods,
hybrid algorithm unit 160 offlash transition layer 150 may be used to determine whether the write data should be written toSLC area 192 orMLC area 194 in response a received data type signal or an address frequency update signal. In this regard, the data type (e.g. meta data or FAT data) signal may in certain embodiments be inherently related to a frequency of access characteristic. Thus, in the foregoing exemplary methods, write data associated with frequently accessed address locations or identified as a frequently accessed type of data result in such data being stored inSLC area 192. Other types of data associated with less frequently accessed addresses or less frequently accessed data types are conversely stored inMLC area 194. -
FIG. 2 is a conceptual diagram illustrating various data types commonly found or generated by contemporary applications. These are merely selected examples, and each particular application will have its own “fast” and “slow” data types. However, in the illustrated example,Volinfo data 211, frequently (freq.) accessedaddress data 216 andmeta data 217 are indicated as “fast” data that should be written toSLC area 192. In contrast, operating system (OS)data 213, application (Apps)data 214, andgeneral data 215 are indicated as “slow” data that should be written toMLC 194. Differentiation between fast and slow data types in this regard may be had by reference to the address of the data as stored in an external memory, associated data header information, an external command or command type, etc. - For example, write operations are commonly performed to non-volatile
memory cell array 190 using the same address as the address of data stored in a FAT region of a memory. As most FAT memory regions are implemented using single level memory cells, it is preferable in some embodiments that data from the FAT region be written toSLC area 192 to avoid data translation overhead. Meta data is commonly used to accomplish write buffering and mapping functions associated withflash transition layer 150. As such, meta data is frequently updated. It is therefore preferable in some embodiments that meta data be written toSLC area 192. This is similarly true for other frequently updated data. - Referring back to
FIG. 1 ,flash transition layer 150 may further include amapping unit 170.Mapping unit 170 maps the address of write data into a physical address identifying specific memory cells within non-volatilememory cell array 190. This function may be implemented in various conventionally understood methods. -
FIG. 1 is a block diagram of ageneral system 100 according to an embodiment of the invention. Referring toFIG. 5 ,system 500 includes a non-volatilememory cell array 590 and aflash transition layer 550. Non-volatilememory cell array 590 includes a plurality of multi-level cells in aMLC area 594 and a plurality of single-level cells in aSLC area 592.Flash transition layer 550 receives write data from anapplication 510 and/or afile system 530 and stores that write data inMLC area 594 orSLC area 592 of non-volatilememory cell array 590 in accordance with one or more characteristics. - In contrast to
system 100 ofFIG. 1 ,flash transition layer 550 ofFIG. 5 includes include a file systemaware unit 540 and an applicationaware unit 520 in addition to ahybrid algorithm unit 560. The functionality provided byapplication interface 125 andfile system interface 145 may be subsumed in these additional flash translation layer units. This capability is particularly useful when the host device incorporating a memory system consistent with the subject invention has limited interface capabilities. - File system
aware unit 540 may be used to determine whether write data received fromfile system 530 or some other source has one or more characteristics indicating “fast” data to be stored inSLC area 592. Applicationaware unit 520 may be used to make a similar determination in relation to write data received fromapplication 510. File systemaware unit 540 and/or applicationaware unit 520 may communicate any number of data characteristic indications in this regard (e.g., a frequently accessed address signal, a data type signal, etc.). - In response to the data characteristic indications from these units,
hybrid algorithm unit 560 may be used to determine whether the write data fromapplication 510 orfile system 530 should be written toMLC area 594 orSLC area 592 of non-volatilememory cell array 590. - In one embodiment, file system
aware unit 540 is used to determine whether the write data has an address corresponding to a FAT memory region and/or an address corresponding to meta data region of an external memory. - in one embodiment,
hybrid algorithm unit 560 may be used to determine that data being stored and accessed byfile system 530 should be stored inSLC area 592.Hybrid algorithm unit 560 will thus determine that write data received from or accessed by other sources should be stored inMLC area 594. - In one embodiment,
hybrid algorithm unit 560 may be used to determine that the write data should be written toSLC area 592 when the address of the data is frequently updated. Data associated with less frequently updated addresses will be written toMLC area 594. -
Flash transition layer 550 may further include a data block history storage unit, such as those conceptually illustrated inFIG. 7 . Such data block history storage unit may be used to store a plurality of entries. Each entry contains information about a data block number of a data block corresponding thereto, as well as the number of times the data block has been accessed, updated in sequence, etc. In the embodiment illustrated inFIG. 5 , applicationaware unit 520 may be used to reference the data block history storage unit and determine whether an address associated with certain write data is frequently updated. -
FIG. 6 is a flow chart of an exemplary method executable within applicationaware unit 520, andFIG. 7 is a conceptual diagram of corresponding data block history storage units. - Application
aware unit 520 obtains a logic block number (Blk Num) of received write data (610, 620) and determines whether the received logic block number is identical to one of the data block number entries already stored in a data block history storage unit (630). When the received logic block number is identified as one of the stored data block number entries in the data block history storage unit, a count value (Cnt) associated with the entry is incremented (640). When the count value for a particular logic block number reaches a defined threshold value, the corresponding block of write data is identified as “frequently updated data” (650, 660). - However, when the logic block number is found as an entry in the data block history storage unit, application
aware unit 520 identifies whether the data block history storage unit has an empty entry (670). - When the data block history storage unit does not have an empty entry, the entry having the smallest least recently used (LRU) value is deleted (680), and an entry for the write data is made newly allocated entry position within the data block history storage unit (690).
- The sequential update of an exemplary data block history storage unit is shown in the data progression between
FIGS. 7( a) through 7(c). The data block history storage unit initially has the entries shown inFIG. 7( a). Then an additional entry is made inFIG. 7( b) for write data associated with alogic block number 100. Note that this entry has a single count value of 1 and a LRU value of 11—the highest LRU value in the data block history storage unit. Subsequently, another entry is required, but the data block history storage unit has a maximum number of entries. Thus, as shown inFIG. 7( c), the oldest entry (i.e., the least recently used data—as indicated by the lowest LRU value) is deleted and replaced by a new entry associated with write data having a logic block number of 120. - This approach is just one of many approaches that may be used to identify certain data as “frequently updated data”. Based on this identification, a determination may be subsequently made with a non-volatile memory system as to whether the write data should be stored in a single-level memory cell or a multi-level memory cell portion of memory. In this regard, the “frequently updated data” status is just one of many characteristics upon which such a determination may be made to improve overall performance of the memory system.
- While the present invention has been particularly shown and described with reference to exemplary embodiments thereof, it will be understood by those of ordinary skill in the art that various changes in form and details may be made therein without departing from the scope of the present invention as defined by the following claims.
Claims (18)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/711,461 US8214582B2 (en) | 2006-11-03 | 2010-02-24 | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
KR1020060108382A KR100833188B1 (en) | 2006-11-03 | 2006-11-03 | Non-volatile memory system storing data at single-level cell or multi-level cell based on the feature of data |
KR10-2006-0108382 | 2006-11-03 |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/711,461 Continuation US8214582B2 (en) | 2006-11-03 | 2010-02-24 | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics |
Publications (2)
Publication Number | Publication Date |
---|---|
US20080126680A1 true US20080126680A1 (en) | 2008-05-29 |
US7676626B2 US7676626B2 (en) | 2010-03-09 |
Family
ID=39465130
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/640,304 Active 2028-04-18 US7676626B2 (en) | 2006-11-03 | 2006-12-18 | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics |
US12/711,461 Active US8214582B2 (en) | 2006-11-03 | 2010-02-24 | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/711,461 Active US8214582B2 (en) | 2006-11-03 | 2010-02-24 | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics |
Country Status (2)
Country | Link |
---|---|
US (2) | US7676626B2 (en) |
KR (1) | KR100833188B1 (en) |
Cited By (71)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080209114A1 (en) * | 1999-08-04 | 2008-08-28 | Super Talent Electronics, Inc. | Reliability High Endurance Non-Volatile Memory Device with Zone-Based Non-Volatile Memory File System |
US20080215800A1 (en) * | 2000-01-06 | 2008-09-04 | Super Talent Electronics, Inc. | Hybrid SSD Using A Combination of SLC and MLC Flash Memory Arrays |
US20080239811A1 (en) * | 2007-04-02 | 2008-10-02 | Kabushiki Kaisha Toshiba | Method for controlling a non-volatile semiconductor memory, and semiconductor storage system |
US20080244203A1 (en) * | 2007-03-30 | 2008-10-02 | Gorobets Sergey A | Apparatus combining lower-endurance/performance and higher-endurance/performance information storage to support data processing |
US20090157974A1 (en) * | 2007-12-12 | 2009-06-18 | Menahem Lasser | System And Method For Clearing Data From A Cache |
US20090172400A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Digital content distribution and consumption |
US20090172274A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Storage device having direct user access |
US20090171891A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il, Ltd. | Data indexing by local storage device |
US20090204746A1 (en) * | 2008-02-13 | 2009-08-13 | Genesys Logic, Inc. | Flash memory storage device for adjusting efficiency in accessing flash memory |
US20090222628A1 (en) * | 2008-03-01 | 2009-09-03 | Kabushiki Kaisha Toshiba | Memory system |
US20090300269A1 (en) * | 2008-05-28 | 2009-12-03 | Radke William H | Hybrid memory management |
US20090319721A1 (en) * | 2008-06-19 | 2009-12-24 | Silicon Motion, Inc. | Flash memory apparatus and method for operating the same |
US20100122016A1 (en) * | 2008-11-12 | 2010-05-13 | Micron Technology | Dynamic slc/mlc blocks allocations for non-volatile memory |
WO2010033455A3 (en) * | 2008-09-16 | 2010-05-14 | Micron Technology, Inc. | Embedded mapping information for memory devices |
US20100169604A1 (en) * | 2008-12-30 | 2010-07-01 | Trika Sanjeev N | Hybrid memory device |
US20100169540A1 (en) * | 2008-12-30 | 2010-07-01 | Sinclair Alan W | Method and apparatus for relocating selected data between flash partitions in a memory device |
US20100169541A1 (en) * | 2008-12-30 | 2010-07-01 | Guy Freikorn | Method and apparatus for retroactive adaptation of data location |
US20100235715A1 (en) * | 2009-03-13 | 2010-09-16 | Jonathan Thatcher | Apparatus, system, and method for using multi-level cell solid-state storage as single-level cell solid-state storage |
US20100250834A1 (en) * | 2009-03-31 | 2010-09-30 | Trika Sanjeev N | Method and system to perform caching based on file-level heuristics |
US20100332738A1 (en) * | 2009-06-29 | 2010-12-30 | A-Data Technology (Suzhou) Co., Ltd. | Storage device and data processing method |
US20100332749A1 (en) * | 2009-06-30 | 2010-12-30 | International Business Machines Corporation | Wear leveling of solid state disks distributed in a plurality of redundant array of independent disk ranks |
US20110010514A1 (en) * | 2009-07-07 | 2011-01-13 | International Business Machines Corporation | Adjusting Location of Tiered Storage Residence Based on Usage Patterns |
US20110066882A1 (en) * | 2009-09-16 | 2011-03-17 | International Business Machines Corporation | Wear leveling of solid state disks based on usage information of data and parity received from a raid controller |
US20110191525A1 (en) * | 2010-02-04 | 2011-08-04 | Phison Electronics Corp. | Flash memory storage device, controller thereof, and data programming method thereof |
CN102160121A (en) * | 2008-09-22 | 2011-08-17 | 美光科技公司 | Programming a memory device to increase data reliability |
US20110302355A1 (en) * | 2010-06-04 | 2011-12-08 | Solid State System Co., Ltd. | Mapping and writting method in memory device with multiple memory chips |
US20110320684A1 (en) * | 2010-06-23 | 2011-12-29 | Sergey Anatolievich Gorobets | Techniques of Maintaining Logical to Physical Mapping Information in Non-Volatile Memory Systems |
US20120030413A1 (en) * | 2010-07-30 | 2012-02-02 | Masaki Miyagawa | Memory management device, information processing device, and memory management method |
US8135903B1 (en) * | 2009-10-30 | 2012-03-13 | Western Digital Technologies, Inc. | Non-volatile semiconductor memory compressing data to improve performance |
US8266503B2 (en) | 2009-03-13 | 2012-09-11 | Fusion-Io | Apparatus, system, and method for using multi-level cell storage in a single-level cell mode |
WO2012158521A1 (en) * | 2011-05-17 | 2012-11-22 | Sandisk Technologies Inc. | Non-volatile memory and method having block management with hot/cold data sorting |
TWI381274B (en) * | 2008-07-10 | 2013-01-01 | Phison Electronics Corp | Block management method and storage system and controller thereof |
US20130031298A1 (en) * | 2011-07-26 | 2013-01-31 | Apple Inc. | Including performance-related hints in requests to composite memory |
US8370402B2 (en) | 2008-01-02 | 2013-02-05 | Sandisk Il Ltd | Dual representation of stored digital content |
JP2013050779A (en) * | 2011-08-30 | 2013-03-14 | Sony Corp | Information processing device and method, and recording medium |
TWI416524B (en) * | 2008-06-25 | 2013-11-21 | Silicon Motion Inc | Memory device and data storing method |
US8661184B2 (en) | 2010-01-27 | 2014-02-25 | Fusion-Io, Inc. | Managing non-volatile media |
US8782325B1 (en) * | 2009-02-09 | 2014-07-15 | Marvell International Ltd. | Data type based alignment of data written to non-volatile memory |
WO2014110535A1 (en) * | 2013-01-14 | 2014-07-17 | Western Digital Technologies, Inc. | Systems and methods of configuring a mode of operation in a solid-state memory |
US20140281158A1 (en) * | 2013-03-14 | 2014-09-18 | Narendhiran Chinnaanangur Ravimohan | File differentiation based on data block identification |
US8854882B2 (en) | 2010-01-27 | 2014-10-07 | Intelligent Intellectual Property Holdings 2 Llc | Configuring storage cells |
US20150026387A1 (en) * | 2009-07-22 | 2015-01-22 | Joseph Sheredy | Method and apparatus for selecting a memory block for writing data, based on a predicted frequency of updating the data |
TWI474325B (en) * | 2009-07-22 | 2015-02-21 | Toshiba Kk | Semiconductor memory device |
US9003101B1 (en) * | 2011-06-29 | 2015-04-07 | Western Digital Technologies, Inc. | Prioritized access for media with heterogeneous access rates |
US9009565B1 (en) | 2013-03-15 | 2015-04-14 | Pmc-Sierra, Inc. | Systems and methods for mapping for solid-state memory |
CN104583978A (en) * | 2012-09-26 | 2015-04-29 | 英特尔公司 | Techniques associated with a read and write window budget for a two level memory system |
US20150120991A1 (en) * | 2013-10-31 | 2015-04-30 | SK Hynix Inc. | Data processing system and operating method thereof |
US9026867B1 (en) | 2013-03-15 | 2015-05-05 | Pmc-Sierra, Inc. | Systems and methods for adapting to changing characteristics of multi-level cells in solid-state memory |
US9053012B1 (en) | 2013-03-15 | 2015-06-09 | Pmc-Sierra, Inc. | Systems and methods for storing data for solid-state memory |
US9081701B1 (en) | 2013-03-15 | 2015-07-14 | Pmc-Sierra, Inc. | Systems and methods for decoding data for solid-state memory |
US9141528B2 (en) | 2011-05-17 | 2015-09-22 | Sandisk Technologies Inc. | Tracking and handling of super-hot data in non-volatile memory systems |
US20150324119A1 (en) * | 2014-05-07 | 2015-11-12 | Sandisk Technologies Inc. | Method and System for Improving Swap Performance |
US9208018B1 (en) | 2013-03-15 | 2015-12-08 | Pmc-Sierra, Inc. | Systems and methods for reclaiming memory for solid-state memory |
US9208079B2 (en) * | 2007-08-14 | 2015-12-08 | Samsung Electronics Co., Ltd. | Solid state memory (SSM), computer system including an SSM, and method of operating an SSM |
US9245653B2 (en) | 2010-03-15 | 2016-01-26 | Intelligent Intellectual Property Holdings 2 Llc | Reduced level cell mode for non-volatile memory |
US20160026565A1 (en) * | 2014-07-25 | 2016-01-28 | Micron Technology, Inc. | Apparatuses and methods for concurrently accessing different memory planes of a memory |
US9275096B2 (en) | 2012-01-17 | 2016-03-01 | Apple Inc. | Optimized b-tree |
US9348741B1 (en) | 2011-12-19 | 2016-05-24 | Western Digital Technologies, Inc. | Systems and methods for handling write data access requests in data storage devices |
JP2016146219A (en) * | 2016-05-16 | 2016-08-12 | ソニー株式会社 | Information processor, method and recording medium |
US9542278B2 (en) | 2013-12-26 | 2017-01-10 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9710198B2 (en) | 2014-05-07 | 2017-07-18 | Sandisk Technologies Llc | Method and computing device for controlling bandwidth of swap operations |
US20200150873A1 (en) * | 2018-11-14 | 2020-05-14 | Western Digital Technologies, Inc. | Solid state device with improved sustained data writing speed |
CN112306393A (en) * | 2019-08-02 | 2021-02-02 | 三星电子株式会社 | Storage device |
US11194516B2 (en) | 2019-10-08 | 2021-12-07 | Micron Technology, Inc. | Media type selection |
US11392318B2 (en) | 2019-06-12 | 2022-07-19 | Samsung Electronics Co., Ltd. | Electronic device and method of utilizing storage space thereof |
US11397526B2 (en) | 2020-02-28 | 2022-07-26 | Micron Technology, Inc. | Media type selection for image data |
US11481150B2 (en) * | 2020-04-01 | 2022-10-25 | Western Digital Technologies, Inc. | Read modify write optimization for video performance |
US11537321B2 (en) | 2020-07-14 | 2022-12-27 | Micron Technology, Inc. | Data selection based on quality |
US11543983B2 (en) * | 2010-09-28 | 2023-01-03 | Amazon Technologies, Inc. | System and method for providing enhancements of block-level storage |
US11614893B2 (en) | 2010-09-15 | 2023-03-28 | Pure Storage, Inc. | Optimizing storage device access based on latency |
US20240061587A1 (en) * | 2022-08-22 | 2024-02-22 | Micron Technology, Inc. | Zone write operation techniques |
Families Citing this family (23)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
SG130988A1 (en) * | 2005-09-29 | 2007-04-26 | Trek 2000 Int Ltd | Portable data storage device incorporating multiple flash memory units |
JP2007305210A (en) * | 2006-05-10 | 2007-11-22 | Toshiba Corp | Semiconductor storage device |
US20140108888A1 (en) | 2008-03-11 | 2014-04-17 | Rod Brittner | Error tolerant or streaming storage device |
US8514509B2 (en) * | 2007-03-10 | 2013-08-20 | Rod Brittner | Error tolerant or streaming storage device |
TW200841343A (en) * | 2007-04-02 | 2008-10-16 | Apacer Technology Inc | A data storage device consisting of NAND (Not-AND) flash memory and its data storing method |
US20080250220A1 (en) * | 2007-04-06 | 2008-10-09 | Takafumi Ito | Memory system |
US8429358B2 (en) * | 2007-08-14 | 2013-04-23 | Samsung Electronics Co., Ltd. | Method and data storage device for processing commands |
US8843691B2 (en) * | 2008-06-25 | 2014-09-23 | Stec, Inc. | Prioritized erasure of data blocks in a flash storage device |
TWI494948B (en) * | 2011-01-31 | 2015-08-01 | Phison Electronics Corp | Data writing method for a non-volatile memory module, memory controller and memory storage apparatus |
KR101720101B1 (en) * | 2011-03-18 | 2017-03-28 | 삼성전자주식회사 | Writing method of writing data into memory system and writing method of memory systme |
KR101319589B1 (en) * | 2011-08-12 | 2013-10-16 | 아주대학교산학협력단 | Method for distinguishing write data of solid state drive and controller thereof |
KR101813182B1 (en) | 2011-11-16 | 2017-12-29 | 삼성전자주식회사 | Multi-valued logic device having nonvolatile memory device |
US8977803B2 (en) * | 2011-11-21 | 2015-03-10 | Western Digital Technologies, Inc. | Disk drive data caching using a multi-tiered memory |
US9146851B2 (en) * | 2012-03-26 | 2015-09-29 | Compellent Technologies | Single-level cell and multi-level cell hybrid solid state drive |
US20140223072A1 (en) * | 2013-02-07 | 2014-08-07 | Lsi Corporation | Tiered Caching Using Single Level Cell and Multi-Level Cell Flash Technology |
US9489148B2 (en) | 2013-03-13 | 2016-11-08 | Seagate Technology Llc | Selecting between non-volatile memory units having different minimum addressable data unit sizes |
JP2016004387A (en) * | 2014-06-16 | 2016-01-12 | 株式会社東芝 | Storage system, memory controller, and control method |
KR102295208B1 (en) | 2014-12-19 | 2021-09-01 | 삼성전자주식회사 | Storage device dynamically allocating program area and program method thererof |
CN105739923A (en) * | 2016-01-28 | 2016-07-06 | 上海新储集成电路有限公司 | Configurable data management method |
US10339073B2 (en) | 2017-06-29 | 2019-07-02 | Keysight Technologies, Inc. | Systems and methods for reducing write latency |
US11614880B2 (en) | 2020-12-31 | 2023-03-28 | Pure Storage, Inc. | Storage system with selectable write paths |
US11847324B2 (en) | 2020-12-31 | 2023-12-19 | Pure Storage, Inc. | Optimizing resiliency groups for data regions of a storage system |
KR20230027957A (en) | 2021-08-20 | 2023-02-28 | 삼성전자주식회사 | Storage system including host and storage device and operation method thereof |
Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040210706A1 (en) * | 2002-07-26 | 2004-10-21 | Samsung Electronics Co., Ltd. | Method for managing flash memory |
US20050057995A1 (en) * | 2003-09-12 | 2005-03-17 | Renesas Technology Corp. | Semiconductor memory device |
Family Cites Families (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100205240B1 (en) | 1996-09-13 | 1999-07-01 | 윤종용 | Nonvolatile semiconductor memory device having a single-bit and multi-bit cell |
KR19990013057A (en) * | 1997-07-31 | 1999-02-25 | 윤종용 | Read and write method of flash memory device for selectively storing single bit data and multiple bit data on same chip |
KR100332950B1 (en) * | 1998-04-10 | 2002-08-21 | 삼성전자 주식회사 | Non-volatile semiconductor memory device with signle-bit and multi-bit modes of operation and method for perporming programming and reading operations therein |
JP2001006374A (en) | 1999-06-17 | 2001-01-12 | Hitachi Ltd | Semiconductor memory and system |
US6297988B1 (en) | 2000-02-25 | 2001-10-02 | Advanced Micro Devices, Inc. | Mode indicator for multi-level memory |
JP2001306393A (en) | 2000-04-20 | 2001-11-02 | Mitsubishi Electric Corp | Storage device |
KR100447969B1 (en) * | 2001-09-13 | 2004-09-10 | 주식회사 하이닉스반도체 | Flash memory apparatus for multilevel and singlelevel program/read |
JP2005267676A (en) | 2004-03-16 | 2005-09-29 | Matsushita Electric Ind Co Ltd | Nonvolatile storage device |
US7366013B2 (en) | 2005-12-09 | 2008-04-29 | Micron Technology, Inc. | Single level cell programming in a multiple level cell non-volatile memory device |
KR100771521B1 (en) * | 2006-10-30 | 2007-10-30 | 삼성전자주식회사 | Flash memory device having a multi-leveled cell and programming method thereof |
KR100816761B1 (en) * | 2006-12-04 | 2008-03-25 | 삼성전자주식회사 | Memory card system including nand flash memory and sram/nor flash memory and data storage method thereof |
-
2006
- 2006-11-03 KR KR1020060108382A patent/KR100833188B1/en active IP Right Grant
- 2006-12-18 US US11/640,304 patent/US7676626B2/en active Active
-
2010
- 2010-02-24 US US12/711,461 patent/US8214582B2/en active Active
Patent Citations (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20040210706A1 (en) * | 2002-07-26 | 2004-10-21 | Samsung Electronics Co., Ltd. | Method for managing flash memory |
US20050057995A1 (en) * | 2003-09-12 | 2005-03-17 | Renesas Technology Corp. | Semiconductor memory device |
Cited By (135)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20080209114A1 (en) * | 1999-08-04 | 2008-08-28 | Super Talent Electronics, Inc. | Reliability High Endurance Non-Volatile Memory Device with Zone-Based Non-Volatile Memory File System |
US20080215800A1 (en) * | 2000-01-06 | 2008-09-04 | Super Talent Electronics, Inc. | Hybrid SSD Using A Combination of SLC and MLC Flash Memory Arrays |
US8078794B2 (en) * | 2000-01-06 | 2011-12-13 | Super Talent Electronics, Inc. | Hybrid SSD using a combination of SLC and MLC flash memory arrays |
US20080244203A1 (en) * | 2007-03-30 | 2008-10-02 | Gorobets Sergey A | Apparatus combining lower-endurance/performance and higher-endurance/performance information storage to support data processing |
US20080239811A1 (en) * | 2007-04-02 | 2008-10-02 | Kabushiki Kaisha Toshiba | Method for controlling a non-volatile semiconductor memory, and semiconductor storage system |
US9208079B2 (en) * | 2007-08-14 | 2015-12-08 | Samsung Electronics Co., Ltd. | Solid state memory (SSM), computer system including an SSM, and method of operating an SSM |
US8200904B2 (en) | 2007-12-12 | 2012-06-12 | Sandisk Il Ltd. | System and method for clearing data from a cache |
US20090157974A1 (en) * | 2007-12-12 | 2009-06-18 | Menahem Lasser | System And Method For Clearing Data From A Cache |
US20090172276A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Storage device having remote storage access |
US8370850B2 (en) | 2008-01-02 | 2013-02-05 | Sandisk Il Ltd. | Cache management |
US20090172217A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Distributed storage service systems and architecture |
US20090171891A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il, Ltd. | Data indexing by local storage device |
US8583878B2 (en) | 2008-01-02 | 2013-11-12 | Sandisk Il Ltd. | Storage device having direct user access |
US8959285B2 (en) | 2008-01-02 | 2015-02-17 | Sandisk Technologies Inc. | Storage system with local and remote storage devices which are managed by the local storage device |
US20090172400A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Digital content distribution and consumption |
US8370402B2 (en) | 2008-01-02 | 2013-02-05 | Sandisk Il Ltd | Dual representation of stored digital content |
US8359654B2 (en) | 2008-01-02 | 2013-01-22 | Sandisk Technologies Inc. | Digital content distribution and consumption |
US20090172694A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Cache management |
US10289349B2 (en) * | 2008-01-02 | 2019-05-14 | Sandisk Il, Ltd. | Data usage profiling by local storage device |
US8452927B2 (en) | 2008-01-02 | 2013-05-28 | Sandisk Technologies Inc. | Distributed storage service systems and architecture |
US20090172275A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il, Ltd. | Data usage profiling by local storage device |
US20090172274A1 (en) * | 2008-01-02 | 2009-07-02 | Sandisk Il Ltd. | Storage device having direct user access |
US9098506B2 (en) | 2008-01-02 | 2015-08-04 | Sandisk Il, Ltd. | Data indexing by local storage device |
US7934053B2 (en) * | 2008-02-13 | 2011-04-26 | Genesys Logic, Inc. | Flash memory storage device for adjusting efficiency in accessing flash memory |
US20090204746A1 (en) * | 2008-02-13 | 2009-08-13 | Genesys Logic, Inc. | Flash memory storage device for adjusting efficiency in accessing flash memory |
US20090222628A1 (en) * | 2008-03-01 | 2009-09-03 | Kabushiki Kaisha Toshiba | Memory system |
EP2291746A4 (en) * | 2008-05-28 | 2012-10-24 | Micron Technology Inc | Hybrid memory management |
US20120059992A1 (en) * | 2008-05-28 | 2012-03-08 | Micron Technology, Inc. | Hybrid memory management |
US8751733B2 (en) | 2008-05-28 | 2014-06-10 | Round Rock Research, Llc | Hybrid memory management |
US9390004B2 (en) | 2008-05-28 | 2016-07-12 | Round Rock Research, Llc | Hybrid memory management |
US8296510B2 (en) * | 2008-05-28 | 2012-10-23 | Round Rock Research, Llc | Hybrid memory management |
US8060719B2 (en) * | 2008-05-28 | 2011-11-15 | Micron Technology, Inc. | Hybrid memory management |
US20090300269A1 (en) * | 2008-05-28 | 2009-12-03 | Radke William H | Hybrid memory management |
US20090319721A1 (en) * | 2008-06-19 | 2009-12-24 | Silicon Motion, Inc. | Flash memory apparatus and method for operating the same |
TWI416524B (en) * | 2008-06-25 | 2013-11-21 | Silicon Motion Inc | Memory device and data storing method |
TWI381274B (en) * | 2008-07-10 | 2013-01-01 | Phison Electronics Corp | Block management method and storage system and controller thereof |
WO2010033455A3 (en) * | 2008-09-16 | 2010-05-14 | Micron Technology, Inc. | Embedded mapping information for memory devices |
CN102160121A (en) * | 2008-09-22 | 2011-08-17 | 美光科技公司 | Programming a memory device to increase data reliability |
US8407400B2 (en) | 2008-11-12 | 2013-03-26 | Micron Technology, Inc. | Dynamic SLC/MLC blocks allocations for non-volatile memory |
US8667215B2 (en) | 2008-11-12 | 2014-03-04 | Micron Technology, Inc. | Dynamic SLC/MLC blocks allocations for non-volatile memory |
US9196368B2 (en) | 2008-11-12 | 2015-11-24 | Round Rock Research, Llc | Erasing physical memory blocks of non-volatile memory |
US20100122016A1 (en) * | 2008-11-12 | 2010-05-13 | Micron Technology | Dynamic slc/mlc blocks allocations for non-volatile memory |
TWI416323B (en) * | 2008-12-30 | 2013-11-21 | Intel Corp | Method,system and semiconductor device for management workload |
WO2010078044A3 (en) * | 2008-12-30 | 2010-09-23 | Intel Corporation | Hybrid memory device |
US8239613B2 (en) | 2008-12-30 | 2012-08-07 | Intel Corporation | Hybrid memory device |
US8261009B2 (en) * | 2008-12-30 | 2012-09-04 | Sandisk Il Ltd. | Method and apparatus for retroactive adaptation of data location |
EP2370902A2 (en) * | 2008-12-30 | 2011-10-05 | Intel Corporation | Hybrid memory device |
EP2370902A4 (en) * | 2008-12-30 | 2012-09-05 | Intel Corp | Hybrid memory device |
US20100169604A1 (en) * | 2008-12-30 | 2010-07-01 | Trika Sanjeev N | Hybrid memory device |
US20100169540A1 (en) * | 2008-12-30 | 2010-07-01 | Sinclair Alan W | Method and apparatus for relocating selected data between flash partitions in a memory device |
CN102301345A (en) * | 2008-12-30 | 2011-12-28 | 英特尔公司 | Hybrid memory device |
US20100169541A1 (en) * | 2008-12-30 | 2010-07-01 | Guy Freikorn | Method and apparatus for retroactive adaptation of data location |
WO2010078044A2 (en) | 2008-12-30 | 2010-07-08 | Intel Corporation | Hybrid memory device |
US8782325B1 (en) * | 2009-02-09 | 2014-07-15 | Marvell International Ltd. | Data type based alignment of data written to non-volatile memory |
US20100235715A1 (en) * | 2009-03-13 | 2010-09-16 | Jonathan Thatcher | Apparatus, system, and method for using multi-level cell solid-state storage as single-level cell solid-state storage |
US8443259B2 (en) | 2009-03-13 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for using multi-level cell solid-state storage as single level cell solid-state storage |
US8527841B2 (en) | 2009-03-13 | 2013-09-03 | Fusion-Io, Inc. | Apparatus, system, and method for using multi-level cell solid-state storage as reduced-level cell solid-state storage |
US8266503B2 (en) | 2009-03-13 | 2012-09-11 | Fusion-Io | Apparatus, system, and method for using multi-level cell storage in a single-level cell mode |
US8261158B2 (en) | 2009-03-13 | 2012-09-04 | Fusion-Io, Inc. | Apparatus, system, and method for using multi-level cell solid-state storage as single level cell solid-state storage |
US8171219B2 (en) * | 2009-03-31 | 2012-05-01 | Intel Corporation | Method and system to perform caching based on file-level heuristics |
US20100250834A1 (en) * | 2009-03-31 | 2010-09-30 | Trika Sanjeev N | Method and system to perform caching based on file-level heuristics |
US20100332738A1 (en) * | 2009-06-29 | 2010-12-30 | A-Data Technology (Suzhou) Co., Ltd. | Storage device and data processing method |
US20100332749A1 (en) * | 2009-06-30 | 2010-12-30 | International Business Machines Corporation | Wear leveling of solid state disks distributed in a plurality of redundant array of independent disk ranks |
US8639877B2 (en) | 2009-06-30 | 2014-01-28 | International Business Machines Corporation | Wear leveling of solid state disks distributed in a plurality of redundant array of independent disk ranks |
US20110010514A1 (en) * | 2009-07-07 | 2011-01-13 | International Business Machines Corporation | Adjusting Location of Tiered Storage Residence Based on Usage Patterns |
US20150026387A1 (en) * | 2009-07-22 | 2015-01-22 | Joseph Sheredy | Method and apparatus for selecting a memory block for writing data, based on a predicted frequency of updating the data |
US9898212B1 (en) | 2009-07-22 | 2018-02-20 | Marvell International Ltd. | Method and apparatus for selecting a memory block for writing data, based on a predicted frequency of updating the data |
TWI474325B (en) * | 2009-07-22 | 2015-02-21 | Toshiba Kk | Semiconductor memory device |
US9244834B2 (en) * | 2009-07-22 | 2016-01-26 | Marvell International Ltd. | Method and apparatus for selecting a memory block for writing data, based on a predicted frequency of updating the data |
US10209902B1 (en) | 2009-07-22 | 2019-02-19 | Marvell International Ltd. | Method and apparatus for selecting a memory block for writing data, based on a predicted frequency of updating the data |
US8510595B2 (en) | 2009-09-16 | 2013-08-13 | International Business Machines Corporation | Wear leveling of solid state disks based on usage information of data and parity received from a raid controller |
US20110066882A1 (en) * | 2009-09-16 | 2011-03-17 | International Business Machines Corporation | Wear leveling of solid state disks based on usage information of data and parity received from a raid controller |
US8234520B2 (en) | 2009-09-16 | 2012-07-31 | International Business Machines Corporation | Wear leveling of solid state disks based on usage information of data and parity received from a raid controller |
US8135903B1 (en) * | 2009-10-30 | 2012-03-13 | Western Digital Technologies, Inc. | Non-volatile semiconductor memory compressing data to improve performance |
US8661184B2 (en) | 2010-01-27 | 2014-02-25 | Fusion-Io, Inc. | Managing non-volatile media |
US8854882B2 (en) | 2010-01-27 | 2014-10-07 | Intelligent Intellectual Property Holdings 2 Llc | Configuring storage cells |
US8873286B2 (en) | 2010-01-27 | 2014-10-28 | Intelligent Intellectual Property Holdings 2 Llc | Managing non-volatile media |
US8706952B2 (en) * | 2010-02-04 | 2014-04-22 | Phison Electronics Corp. | Flash memory storage device, controller thereof, and data programming method thereof |
US20110191525A1 (en) * | 2010-02-04 | 2011-08-04 | Phison Electronics Corp. | Flash memory storage device, controller thereof, and data programming method thereof |
US9245653B2 (en) | 2010-03-15 | 2016-01-26 | Intelligent Intellectual Property Holdings 2 Llc | Reduced level cell mode for non-volatile memory |
US20110302355A1 (en) * | 2010-06-04 | 2011-12-08 | Solid State System Co., Ltd. | Mapping and writting method in memory device with multiple memory chips |
US20110320684A1 (en) * | 2010-06-23 | 2011-12-29 | Sergey Anatolievich Gorobets | Techniques of Maintaining Logical to Physical Mapping Information in Non-Volatile Memory Systems |
US8543757B2 (en) * | 2010-06-23 | 2013-09-24 | Sandisk Technologies Inc. | Techniques of maintaining logical to physical mapping information in non-volatile memory systems |
US20120030413A1 (en) * | 2010-07-30 | 2012-02-02 | Masaki Miyagawa | Memory management device, information processing device, and memory management method |
US11614893B2 (en) | 2010-09-15 | 2023-03-28 | Pure Storage, Inc. | Optimizing storage device access based on latency |
US11543983B2 (en) * | 2010-09-28 | 2023-01-03 | Amazon Technologies, Inc. | System and method for providing enhancements of block-level storage |
US9141528B2 (en) | 2011-05-17 | 2015-09-22 | Sandisk Technologies Inc. | Tracking and handling of super-hot data in non-volatile memory systems |
US9176864B2 (en) | 2011-05-17 | 2015-11-03 | SanDisk Technologies, Inc. | Non-volatile memory and method having block management with hot/cold data sorting |
WO2012158521A1 (en) * | 2011-05-17 | 2012-11-22 | Sandisk Technologies Inc. | Non-volatile memory and method having block management with hot/cold data sorting |
US9003101B1 (en) * | 2011-06-29 | 2015-04-07 | Western Digital Technologies, Inc. | Prioritized access for media with heterogeneous access rates |
US9417794B2 (en) * | 2011-07-26 | 2016-08-16 | Apple Inc. | Including performance-related hints in requests to composite memory |
US20130031298A1 (en) * | 2011-07-26 | 2013-01-31 | Apple Inc. | Including performance-related hints in requests to composite memory |
US9471424B2 (en) | 2011-08-30 | 2016-10-18 | Sony Corporation | Information processing device and method, and recording medium |
JP2013050779A (en) * | 2011-08-30 | 2013-03-14 | Sony Corp | Information processing device and method, and recording medium |
US9348741B1 (en) | 2011-12-19 | 2016-05-24 | Western Digital Technologies, Inc. | Systems and methods for handling write data access requests in data storage devices |
US9275096B2 (en) | 2012-01-17 | 2016-03-01 | Apple Inc. | Optimized b-tree |
CN104583978A (en) * | 2012-09-26 | 2015-04-29 | 英特尔公司 | Techniques associated with a read and write window budget for a two level memory system |
EP2901286A4 (en) * | 2012-09-26 | 2016-04-20 | Intel Corp | Techniques associated with a read and write window budget for a two level memory system |
US8954655B2 (en) | 2013-01-14 | 2015-02-10 | Western Digital Technologies, Inc. | Systems and methods of configuring a mode of operation in a solid-state memory |
WO2014110535A1 (en) * | 2013-01-14 | 2014-07-17 | Western Digital Technologies, Inc. | Systems and methods of configuring a mode of operation in a solid-state memory |
US9715445B2 (en) * | 2013-03-14 | 2017-07-25 | Sandisk Technologies Llc | File differentiation based on data block identification |
US20140281158A1 (en) * | 2013-03-14 | 2014-09-18 | Narendhiran Chinnaanangur Ravimohan | File differentiation based on data block identification |
US9081701B1 (en) | 2013-03-15 | 2015-07-14 | Pmc-Sierra, Inc. | Systems and methods for decoding data for solid-state memory |
US9009565B1 (en) | 2013-03-15 | 2015-04-14 | Pmc-Sierra, Inc. | Systems and methods for mapping for solid-state memory |
US9053012B1 (en) | 2013-03-15 | 2015-06-09 | Pmc-Sierra, Inc. | Systems and methods for storing data for solid-state memory |
US9208018B1 (en) | 2013-03-15 | 2015-12-08 | Pmc-Sierra, Inc. | Systems and methods for reclaiming memory for solid-state memory |
US9026867B1 (en) | 2013-03-15 | 2015-05-05 | Pmc-Sierra, Inc. | Systems and methods for adapting to changing characteristics of multi-level cells in solid-state memory |
US20150120991A1 (en) * | 2013-10-31 | 2015-04-30 | SK Hynix Inc. | Data processing system and operating method thereof |
US9632880B2 (en) | 2013-12-26 | 2017-04-25 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9645895B2 (en) | 2013-12-26 | 2017-05-09 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9684568B2 (en) | 2013-12-26 | 2017-06-20 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9645894B2 (en) | 2013-12-26 | 2017-05-09 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9645896B2 (en) | 2013-12-26 | 2017-05-09 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9727271B2 (en) | 2013-12-26 | 2017-08-08 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9842030B2 (en) | 2013-12-26 | 2017-12-12 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9542278B2 (en) | 2013-12-26 | 2017-01-10 | Silicon Motion, Inc. | Data storage device and flash memory control method |
US9710198B2 (en) | 2014-05-07 | 2017-07-18 | Sandisk Technologies Llc | Method and computing device for controlling bandwidth of swap operations |
US20150324119A1 (en) * | 2014-05-07 | 2015-11-12 | Sandisk Technologies Inc. | Method and System for Improving Swap Performance |
US9928169B2 (en) * | 2014-05-07 | 2018-03-27 | Sandisk Technologies Llc | Method and system for improving swap performance |
US20160026565A1 (en) * | 2014-07-25 | 2016-01-28 | Micron Technology, Inc. | Apparatuses and methods for concurrently accessing different memory planes of a memory |
US10402319B2 (en) * | 2014-07-25 | 2019-09-03 | Micron Technology, Inc. | Apparatuses and methods for concurrently accessing different memory planes of a memory |
US11550717B2 (en) | 2014-07-25 | 2023-01-10 | Micron Technology, Inc. | Apparatuses and methods for concurrently accessing different memory planes of a memory |
JP2016146219A (en) * | 2016-05-16 | 2016-08-12 | ソニー株式会社 | Information processor, method and recording medium |
US10895991B2 (en) * | 2018-11-14 | 2021-01-19 | Western Digital Technologies, Inc. | Solid state device with improved sustained data writing speed |
US20200150873A1 (en) * | 2018-11-14 | 2020-05-14 | Western Digital Technologies, Inc. | Solid state device with improved sustained data writing speed |
US11392318B2 (en) | 2019-06-12 | 2022-07-19 | Samsung Electronics Co., Ltd. | Electronic device and method of utilizing storage space thereof |
US11704072B2 (en) | 2019-06-12 | 2023-07-18 | Samsung Electronics Co., Ltd. | Electronic device and method of utilizing storage space thereof |
CN112306393A (en) * | 2019-08-02 | 2021-02-02 | 三星电子株式会社 | Storage device |
US11645007B2 (en) * | 2019-08-02 | 2023-05-09 | Samsung Electronics Co., Ltd. | Memory device including plurality of buffer areas for supporting fast write and fast read and storage device including the same |
US11194516B2 (en) | 2019-10-08 | 2021-12-07 | Micron Technology, Inc. | Media type selection |
US11656799B2 (en) | 2019-10-08 | 2023-05-23 | Micron Technology, Inc. | Media type selection |
US11397526B2 (en) | 2020-02-28 | 2022-07-26 | Micron Technology, Inc. | Media type selection for image data |
US11481150B2 (en) * | 2020-04-01 | 2022-10-25 | Western Digital Technologies, Inc. | Read modify write optimization for video performance |
US11537321B2 (en) | 2020-07-14 | 2022-12-27 | Micron Technology, Inc. | Data selection based on quality |
US20240061587A1 (en) * | 2022-08-22 | 2024-02-22 | Micron Technology, Inc. | Zone write operation techniques |
Also Published As
Publication number | Publication date |
---|---|
KR100833188B1 (en) | 2008-05-28 |
US20100153632A1 (en) | 2010-06-17 |
KR20080040426A (en) | 2008-05-08 |
US8214582B2 (en) | 2012-07-03 |
US7676626B2 (en) | 2010-03-09 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7676626B2 (en) | Non-volatile memory system storing data in single-level cell or multi-level cell according to data characteristics | |
US20230315294A1 (en) | Memory system and method for controlling nonvolatile memory | |
CN113138713B (en) | memory system | |
US10838859B2 (en) | Recency based victim block selection for garbage collection in a solid state device (SSD) | |
KR101388410B1 (en) | Selective data storage in lsb and msb pages | |
KR100526190B1 (en) | Remapping method for flash memory | |
US20080189490A1 (en) | Memory mapping | |
EP1906311A2 (en) | Mapping apparatus and method for non-volatile memory supporting different cell types | |
US20170242583A1 (en) | Memory device having a translation layer with multiple associative sectors | |
US10545862B2 (en) | Memory system and method for controlling nonvolatile memory | |
US20080235306A1 (en) | Garbage collection in nonvolatile memories using data attributes, computer program products and methods of operating the same | |
US9223694B2 (en) | Data storage device and operating method thereof | |
US9043516B2 (en) | Data storage device and operating method thereof | |
US10310766B2 (en) | Memory system and data relocating method | |
US7287117B2 (en) | Flash memory and mapping control apparatus and method for flash memory | |
JP2013137770A (en) | Lba bitmap usage | |
JP6139381B2 (en) | Memory system and method | |
CN111831583A (en) | Apparatus and method for transferring mapped segments in a memory system | |
KR20090081657A (en) | Write and merge methods in memory card systems for reducing the number of page copies | |
CN102859504B (en) | Copy the method and system of data and obtain the method for data trnascription | |
KR20130030238A (en) | Faster tree flattening for a system having non-volatile memory | |
CN110377233A (en) | SSD reading performance optimization method, device, computer equipment and storage medium | |
JP2013196161A (en) | Control method of semiconductor storage device | |
KR100982440B1 (en) | System for managing data in single flash memory | |
KR101609304B1 (en) | Apparatus and Method for Stroring Multi-Chip Flash |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: SAMSUNG ELECTRONICS CO., LTD., KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LEE, YANG-SUP;TALAWAR, PRAKASH;PARK, CHAN-IK;REEL/FRAME:018716/0082 Effective date: 20061213 Owner name: SAMSUNG ELECTRONICS CO., LTD.,KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:LEE, YANG-SUP;TALAWAR, PRAKASH;PARK, CHAN-IK;REEL/FRAME:018716/0082 Effective date: 20061213 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 8TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1552) Year of fee payment: 8 |
|
MAFP | Maintenance fee payment |
Free format text: PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY Year of fee payment: 12 |