Movatterモバイル変換


[0]ホーム

URL:


US7096313B1 - Tracking the least frequently erased blocks in non-volatile memory systems - Google Patents

Tracking the least frequently erased blocks in non-volatile memory systems
Download PDF

Info

Publication number
US7096313B1
US7096313B1US10/281,824US28182402AUS7096313B1US 7096313 B1US7096313 B1US 7096313B1US 28182402 AUS28182402 AUS 28182402AUS 7096313 B1US7096313 B1US 7096313B1
Authority
US
United States
Prior art keywords
erased
block
elements
blocks
erase count
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.)
Expired - Lifetime, expires
Application number
US10/281,824
Inventor
Robert C. Chang
Bahman Qawami
Farshid Sabet-Sharghi
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
SanDisk Technologies LLC
Original Assignee
SanDisk Corp
Priority date (The priority date 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 date listed.)
Filing date
Publication date
Application filed by SanDisk CorpfiledCriticalSanDisk Corp
Assigned to SANDISK CORPORATIONreassignmentSANDISK CORPORATIONASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: CHANG, ROBERT C., QAWAMI, BAHMAN, SABET-SHARGHI, FARSHID
Priority to US10/281,824priorityCriticalpatent/US7096313B1/en
Priority to EP03752227Aprioritypatent/EP1559017A1/en
Priority to JP2004548318Aprioritypatent/JP2006504199A/en
Priority to CNA038247801Aprioritypatent/CN1698036A/en
Priority to AU2003270529Aprioritypatent/AU2003270529A1/en
Priority to KR1020057007322Aprioritypatent/KR20050084879A/en
Priority to PCT/US2003/028429prioritypatent/WO2004040459A1/en
Priority to TW092125790Aprioritypatent/TWI249100B/en
Publication of US7096313B1publicationCriticalpatent/US7096313B1/en
Application grantedgrantedCritical
Assigned to SANDISK TECHNOLOGIES INC.reassignmentSANDISK TECHNOLOGIES INC.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: SANDISK CORPORATION
Assigned to INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC.reassignmentINTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: SanDisk Technologies, Inc.
Assigned to INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC.reassignmentINTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC.CORRECTIVE ASSIGNMENT TO CORRECT THE ADDRESS OF THE ASSIGNOR IN THE ASSIGNMENT DOCUMENT PREVIOUSLY RECORDED ON REEL 030953 FRAME 0416. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT.Assignors: SanDisk Technologies, Inc.
Assigned to SANDISK CORPORATIONreassignmentSANDISK CORPORATIONSECURITY AGREEMENTAssignors: INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC
Assigned to PS3 LUXCO SARLreassignmentPS3 LUXCO SARLASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC
Assigned to PS2 LUXCO SARLreassignmentPS2 LUXCO SARLASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: PS3 LUXCO SARL
Assigned to LONGITUDE FLASH MEMORY SYSTEMS S.A.R.L.reassignmentLONGITUDE FLASH MEMORY SYSTEMS S.A.R.L.CHANGE OF NAME (SEE DOCUMENT FOR DETAILS).Assignors: PS2 LUXCO S.A.R.L.
Assigned to SanDisk Technologies, Inc.reassignmentSanDisk Technologies, Inc.ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS).Assignors: LONGITUDE FLASH MEMORY SYSTEMS SARL
Assigned to SANDISK TECHNOLOGIES LLCreassignmentSANDISK TECHNOLOGIES LLCCHANGE OF NAME (SEE DOCUMENT FOR DETAILS).Assignors: SANDISK TECHNOLOGIES INC
Assigned to SANDISK CORPORATIONreassignmentSANDISK CORPORATIONTERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTSAssignors: SANDISK CORPORATION, SanDisk Technologies, Inc.
Adjusted expirationlegal-statusCritical
Expired - Lifetimelegal-statusCriticalCurrent

Links

Images

Classifications

Definitions

Landscapes

Abstract

Methods and apparatus for performing wear leveling in a non-volatile memory system are disclosed. According to one aspect of the present invention, one method for processing elements included in a non-volatile memory of a memory system includes obtaining erase counts associated with elements and grouping a number of the elements into a first set. Each element has an associated erase count that substantially indicates a number of times the element has been erased. Grouping the number of elements into the first set includes selecting elements included in the plurality of elements which have the lowest associated erase counts of the erase counts associated with the plurality of elements. The method also includes storing the erase counts associated with the first set in a memory component substantially within a table.

Description

CROSS REFERENCE TO RELATED APPLICATIONS
The present invention is related to co-pending U.S. patent application Ser. No. 10/281,739 entitled “WEAR-LEVELING IN NON-VOLATILE SYSTEMS”, filed Oct. 28, 2002; co-pending U.S. patent application Ser. No. 10/281,670 entitled “TRACKING THE MOST FREQUENTLY ERASED BLOCKS IN NON-VOLATILE MEMORY SYSTEMS,” filed Oct. 28, 2002: co-pending U.S. patent application Ser. No. 10/281,631 entitled “METHOD AND APPARATUS FOR SPLITTING A LOGICAL BLOCK”, filed Oct. 28, 2002; co-pending U.S. patent application Ser. No. 10/281,855 entitled “METHOD AND APPARATUS FOR GROUPING PAGES WITHIN A BLOCK”, filed Oct. 28, 2002; co-pending U.S. patent application Ser. No. 10/281,762 entitled “METHOD AND APPARATUS FOR RESOLVING PHYSICAL BLOCKS ASSOCIATED WITH A COMMON LOGICAL BLOCK,” filed Oct. 28, 2002; which are each incorporated herein by reference in their entireties.
BACKGROUND OF THE INVENTION
1. Field of Invention
The present invention relates generally to mass digital data storage systems. More particularly, the present invention relates to systems and methods for allowing the wear associated with storage areas in a non-volatile storage system to be spread out across substantially all storage areas.
2. Description of the Related Art
The use of non-volatile memory systems such as flash memory storage systems is increasing due to the compact physical size of such memory systems, and the ability for non-volatile memory to be repetitively reprogrammed. The compact physical size of flash memory storage systems facilitates the use of such storage systems in devices which are becoming increasingly prevalent. Devices which use flash memory storage systems include, but are not limited to, digital cameras, digital camcorders, digital music players, handheld personal computers, and global positioning devices. The ability to repetitively reprogram non-volatile memory included in flash memory storage systems enables flash memory storage systems to be used and reused.
In general, flash memory storage systems may include flash memory cards and flash memory chip sets. Flash memory chip sets generally include flash memory components and a controller components. Typically, a flash memory chip set may be arranged to be assembled into an embedded system. The manufacturers of such assemblies or host systems typically acquire flash memory in component-form, as well as other components, then assemble the flash memory and the other components into a host system.
Although non-volatile memory or, more specifically, flash memory storage blocks within flash memory systems may be repetitively programmed and erased, each block or physical location may only be erased a certain number of times before the block wears out, i.e., before memory begins to become smaller. That is, each block has a program and erase cycle limit. In some memory, a block may be erased up to approximately ten thousand times before the block is considered to be unusable. In other memory, a block may be erased up to approximately one hundred thousand times or even up to a million times before the block is considered to be worn out. When a block is worn out, thereby causing a loss of use or a significant degradation of performance to a portion of the overall storage volume of the flash memory system, a user of the flash memory system may be adversely affected, as for the example through the loss of stored data or the inability to store data.
The wear on blocks, or physical locations, within a flash memory system varies depending upon how much each of the blocks is programmed. If a block or, more generally, a storage element, is programmed once, then effectively never reprogrammed, the number of program and erase cycles and, hence, wear associated with that block will generally be relatively low. However, if a block is repetitively written to and erased, e.g., cycled, the wear associated with that block will generally be relatively high. As logical block addresses (LBAs) are used by hosts, e.g., systems which access or use a flash memory system, to access data stored in a flash memory system, if a host repeatedly uses the same LBAs to write and overwrite data, the same physical locations or blocks within the flash memory system are repeatedly written to and erased, as will be appreciated by those of skill in the art.
When some blocks are effectively worn out while other blocks are relatively unworn, the existence of the worn out blocks generally compromises the overall performance of the flash memory system. In addition to degradation of performance associated with worn out blocks themselves, the overall performance of the flash memory system may be compromised when an insufficient number of blocks which are not worn out are available to store desired data. Often, a flash memory system may be deemed unusable when a critical number worn out blocks are present in the flash memory system, even when many other cells in the flash memory system are relatively unworn. When a flash memory system which includes a substantial number of relatively unworn blocks is considered to be unusable, many resources associated with the flash memory system are effectively wasted.
In order to increase the likelihood that blocks within a flash memory system are worn fairly evenly, wear leveling operations are often performed. Wear leveling operations, as will be understood by those skilled in the art, are generally arranged to allow the physical locations or blocks which are associated with particular LBAs to be changed such that the same LBAs are not always associated with the same physical locations or blocks. By changing the block associations of LBAs, it is less likely that a particular block may wear out well before other blocks wear out.
One conventional wear leveling process involves swapping physical locations to which two relatively large portions of customer or host LBAs are mapped. That is, the LBAs associated with relatively large sections of storage cells are swapped. Such swapping is initiated through a manual command from a customer, e.g., through the use of a host and, as a result, is not transparent to the customer. Also, swapping operations that involve moving data between two relatively large sections of storage cells are time consuming and, hence, inefficient. Additionally, the performance of the overall flash memory system may be adversely affected by swapping operations of a relatively long duration which consume significant resources associated with the overall flash memory system. As will be appreciated by those skilled in the art, moving data from a first location typically involves copying the data into another location and erasing the data from the first location.
Another conventional wear leveling process involves allowing blocks to wear. Once the blocks have effectively worn out, the sectors assigned to the blocks may be reassigned by mapping the addresses associated with the sectors to spare areas once the blocks in which the sectors have been stored have worn out, or have become unusable. As the number of spare areas or blocks is limited and valuable, there may not always be spare areas to which sectors associated with unusable blocks may be mapped. In addition, effectively remapping sectors only after blocks have become unusable generally allows performance of the overall flash memory system to degrade.
Therefore, what are desired are a method and an apparatus for efficiently and substantially transparently performing wear leveling within a flash memory storage system. That is, what is needed is a wear leveling process which promotes more even wear in physical locations associated with the flash memory storage system without requiring a significant use of computational resources.
SUMMARY OF THE INVENTION
The present invention relates to a system and a method for performing wear leveling in a non-volatile memory system. According to one aspect of the present invention, one method for processing elements included in a non-volatile memory of a memory system includes obtaining erase counts associated with elements and grouping a number of the elements into a first set. Each element has an associated erase count that substantially indicates a number of times the element has been erased. Grouping the number of erased elements into the first set includes selecting erased elements included in the plurality of elements which have the lowest associated erase counts of the erase counts associated with the plurality of elements. The method also includes storing the erase counts associated with the first set in a memory component substantially within a table.
In one embodiment, the elements in the first set are sorted according to the erase count associated with each element. In such an embodiment, the method may also include identifying an erased element included in the first set that has the lowest erase count associated with the first set, disassociating the element from the first set, and associating a different erased element of the plurality of elements with the first set.
By maintaining worn elements, e.g., extended blocks, of a non-volatile memory in a group of worn elements, the wear of the worn elements may be managed essentially by preventing the worn elements from being allocated for use until less worn elements eventually become more worn. As such, the wear of all elements may be evened out, as the elements which have been erased more often are effectively prevented from being used and, hence, erased again, until other elements have been used and erased more. The overall life of a media, as for example a device which includes an embedded flash memory or a flash memory card, may generally be extended if blocks which have relatively low erase counts are used as spare blocks when a block containing not-needed data is erased, or when a block is needed to replace a substantially worn block. Maintaining spare blocks in a group of least erased blocks which are effectively tracked using a table stored in system memory facilitates the allocation of less worn blocks over blocks which are more worn.
According to another aspect of the present invention, a memory system includes a first memory that stores a table arranged to include entries associated with a first set of erased storage elements which have associated erase counters that are less than an average erase count. The associated erase counter for each storage element of the first set of storage elements is arranged to substantially indicate a number of times the storage element has been erased. The memory system also includes a second memory that includes a plurality of storage elements which includes the first set of storage elements. The average erase count is determined using erase counters associated with the plurality of storage elements. Finally, the memory system includes a processor that may access the first memory and the second memory. In one embodiment, the first set of storage elements may be identified using the table.
In accordance with yet another aspect of the present invention, a method for managing memory that includes a plurality of blocks includes identifying a set of erased blocks included in the plurality of blocks, and identifying a first group of erased blocks included in the set of erased blocks. The first group of erased blocks includes erased blocks with lower erase counts than substantially all other erased blocks in the set of erased blocks. A structure which includes entries is created in a memory component. The entries include erase counts of the erased blocks included in the first group. The entries are sorted, and a first block is identified using the sorted entries. The first block is arranged to be removed from the first group of erased blocks prior to the other erased blocks included in the first group of erased blocks. In other words, the first block may be the first block swapped out of the first group on an as-needed basis.
In one embodiment, sorting the entries includes sorting the entries using the erase counts of the erased blocks included in the first group. In such an embodiment, identifying the first block using the sorted entries may includes identifying the first block to have a lower erase count than substantially all other erased blocks included in the first group.
These and other advantages of the present invention will become apparent upon reading the following detailed descriptions and studying the various figures of the drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
The invention may best be understood by reference to the following description taken in conjunction with the accompanying drawings in which:
FIG. 1ais a diagrammatic representation of a general host system which includes a non-volatile memory device in accordance with an embodiment of the present invention.
FIG. 1bis a diagrammatic representation a memory device, e.g.,memory device120 ofFIG. 1a, in accordance with an embodiment of the present invention.
FIG. 2 is a diagrammatic representation of a portion of a flash memory in accordance with an embodiment of the present invention.
FIG. 3 is a process flow diagram which illustrates the steps associated with processing an initialization request with respect to a flash memory system, in accordance with an embodiment of the present invention.
FIG. 4 is a process flow diagram which illustrates the steps associated with one method of processing a static block in accordance with an embodiment of the present invention.
FIG. 5ais a diagrammatic block diagram representation of a system memory in accordance with an embodiment of the present invention.
FIG. 5bis a diagrammatic representation of normal blocks, least frequently erased blocks, and most frequently erased blocks in accordance with an embodiment of the present invention.
FIG. 6 is a diagrammatic representation of one method of performing a block swap or update in the system memory an overall memory system to allow for more even wear of the blocks in accordance with an embodiment of the present invention.
FIG. 7 is a diagrammatic block diagram representation of a system architecture in accordance with an embodiment of the present invention.
DETAILED DESCRIPTION OF THE EMBODIMENTS
Non-volatile memory storage blocks within flash memory storage systems may be repetitively programmed and erased, although each block may generally only be erased a finite number of times before the block wears out. When a block wears out, a relatively significant degradation of performance associated with the portion of the overall storage volume of the flash memory storage system that includes the worn out block occurs, and data stored in that portion may be lost, or it may become impossible to store data in that portion.
In order to increase the likelihood that blocks wear out more evenly within a flash memory storage system, blocks may be more evenly utilized. By keeping track of how many times each block has been erased, as for example through the utilization of an erase count, memory within a system may be more evenly used. An erase count management technique may store an erase count which keeps track of how many times a particular block has been erased in a redundant area associated with the block. Tables may be built in system memory which substantially enables blocks that are in use to effectively be separated from blocks which have relatively high erase counts and blocks which have relatively low erase counts. When a block in use is erased, the block may be “added” to either a table of blocks which have relatively high erase counts or a table of blocks which have relatively low erase counts, as appropriate. Likewise, blocks may be “moved” from either the table of blocks which have relatively high erase counts or the table of blocks which have relatively low erase counts into a block mapping table, i.e., a set of table of blocks which are in use, to substantially replace any block which has been reassigned from the block mapping table.
By categorizing blocks, blocks may be more evenly utilized as the use of each block may be more effectively managed to even out the wear associated with the blocks. Further, categorizing blocks into tables enables blocks with a low erase count and blocks with a high erase count to be readily identified and, hence, does not utilize a significant amount of computational resources. Hence, wear leveling occurs relatively efficiently. As a result, the life of the flash memory system may be extended substantially without significantly affecting the performance of the flash memory system.
Flash memory systems or, more generally, non-volatile memory devices generally include flash memory cards and chip sets. Typically, flash memory systems are used in conjunction with a host system such that the host system may write data to or read data from the flash memory systems. However, some flash memory systems include embedded flash memory and software which executes on a host to substantially act as a controller for the embedded flash memory. Referring initially toFIG. 1a, a general host system which includes a non-volatile memory device, e.g., a CompactFlash memory card or an embedded system, will be described. A host orcomputer system100 generally includes asystem bus104 which allows amicroprocessor108, a random access memory (RAM)112, and input/output circuits116 to communicate. It should be appreciated thathost system100 may generally include other components, e.g., display devices and networking device, which are not shown for purposes of illustration.
In general,host system100 may be capable of capturing information including, but not limited to, still image information, audio information, and video image information. Such information may be captured in real-time, and may be transmitted tohost system100 in a wireless manner. Whilehost system100 may be substantially any system,host system100 is typically a system such as a digital camera, a video camera, a cellular communications device, an audio player, or a video player. It should be appreciated, however, thathost system100 may generally be substantially any system which stores data or information, and retrieves data or information.
It should be appreciated thathost system100 may also be a system which either only captures data, or only retrieves data. That is,host system100 may be a dedicated system which stores data, orhost system100 may be a dedicated system which reads data. By way of example,host system100 may be a memory writer which is arranged only to write or store data. Alternatively,host system100 may be a device such as an MP3 player which is typically arranged to read or retrieve data, and not to capture data.
Anon-volatile memory device120 which, in one embodiment, is a removable non-volatile memory device, is arranged to interface withbus104 to store information. An optional input/output circuit block116 may allownon-volatile memory device120 to interface indirectly withbus104. When present, input/output circuit block116 serves to reduce loading onbus104, as will be understood by those skilled in the art.Non-volatile memory device120 includesnon-volatile memory124 and an optionalmemory control system128. In one embodiment,non-volatile memory device120 may be implemented on a single chip or a die. Alternatively,non-volatile memory device120 may be implemented on a multi-chip module, or on multiple discrete components which may form a chip set and may be used together asnon-volatile memory device120. One embodiment ofnon-volatile memory device120 will be described below in more detail with respect toFIG. 1b.
Non-volatile memory124, e.g., flash memory such as NAND flash memory, is arranged to store data such that data may be accessed and read as needed. Data stored innon-volatile memory124 may also be erased as appropriate, although it should be understood that some data innon-volatile memory124 may not be erasable. The processes of storing data, reading data, and erasing data are generally controlled bymemory control system128 or, whenmemory control system128 is not present, by software executed bymicroprocessor108. The operation ofnon-volatile memory124 may be managed such that the lifetime ofnon-volatile memory124 is substantially maximized by essentially causing sections ofnon-volatile memory124 to be worn out substantially equally.
Non-volatile memory device120 has generally been described as including an optionalmemory control system128, i.e., a controller. Often,non-volatile memory device120 may include separate chips fornon-volatile memory124 andmemory control system128, i.e., controller, functions. By way of example, while non-volatile memory devices including, but not limited to, PC cards, CompactFlash cards, MultiMedia cards, and Secure Digital cards include controllers which may be implemented on a separate chip, other non-volatile memory devices may not include controllers that are implemented on a separate chip. In an embodiment in whichnon-volatile memory device120 does not include separate memory and controller chips, the memory and controller functions may be integrated into a single chip, as will be appreciated by those skilled in the art. Alternatively, the functionality ofmemory control system128 may be provided bymicroprocessor108, as for example in an embodiment in whichnon-volatile memory device120 does not includememory controller128, as discussed above.
With reference toFIG. 1b,non-volatile memory device120 will be described in more detail in accordance with an embodiment of the present invention. As described above,non-volatile memory device120 includesnon-volatile memory124 and may includememory control system128.Memory124 andcontrol system128, or controller, may be primary components ofnon-volatile memory device120, although whenmemory124 is an embedded NAND device, for example,non-volatile memory device120 may not includecontrol system128.Memory124 may be an array of memory cells formed on a semiconductor substrate, wherein one or more bits of data are stored in the individual memory cells by storing one of two or more levels of charge on individual storage elements of the memory cells. A non-volatile flash electrically erasable programmable read only memory (EEPROM) is an example of a common type of memory for such systems.
When present,control system128 communicates over abus15 to a host computer or other system that is using the memory system to store data.Bus15 is generally a part ofbus104 ofFIG. 1a.Control system128 also controls operation ofmemory124, which may include amemory cell array11, to write data provided by the host, read data requested by the host and perform various housekeeping functions inoperating memory124.Control system128 generally includes a general purpose microprocessor which has associated non-volatile software memory, various logic circuits, and the like. One or more state machines are often also included for controlling the performance of specific routines.
Memory cell array11 is typically addressed bycontrol system128 ormicroprocessor108 throughaddress decoders17.Decoders17 apply the correct voltages to gate and bit lines ofarray11 in order to program data to, read data from, or erase a group of memory cells being addressed by thecontrol system128.Additional circuits19 include programming drivers that control voltages applied to elements of the array that depend upon the data being programmed into an addressed group of cells.Circuits19 also include sense amplifiers and other circuits necessary to read data from an addressed group of memory cells. Data to be programmed intoarray11, or data recently read fromarray11, are typically stored in abuffer memory21 withincontrol system128.Control system128 also usually contains various registers for temporarily storing command and status data, and the like.
Array11 is divided into a large number ofBLOCKS 0–N memory cells. As is common for flash EEPROM systems, the block is typically the smallest unit of erase. That is, each block contains the minimum number of memory cells that are erased together. Each block is typically divided into a number of pages, as also illustrated inFIG. 2. A page is typically the smallest unit of programming. That is, a basic programming operation writes data into or reads data from a minimum of one page of memory cells. One or more sectors of data are typically stored within each page. As shown inFIG. 1b, one sector includes user data and overhead data. Overhead data typically includes an error correction code (ECC) that has been calculated from the user data and overhead data of the page. Aportion23 of thecontrol system128 calculates the ECC when data is being programmed intoarray11, and also checks the ECC when data is being read fromarray11. Alternatively, the ECCs are stored in different pages, or different blocks, than the user data to which they pertain.
A sector of user data is typically 512 bytes, corresponding to the size of a sector in magnetic disk drives. Overhead data is typically an additional 16 bytes. One sector of data is most commonly included in each page but two or more sectors may instead form a page. Any number of pages may generally form a block. By way of example, a block may be formed from eight pages up to 512, 1024 or more pages. The number of blocks is chosen to provide a desired data storage capacity for the memory system.Array11 is typically divided into a few sub-arrays (not shown), each of which contains a proportion of the blocks, which operate somewhat independently of each other in order to increase the degree of parallelism in the execution of various memory operations. An example of the use of multiple sub-arrays is described in U.S. Pat. No. 5,890,192, which is incorporated herein by reference in its entirety.
When a particular section, e.g., storage element, ofnon-volatile memory124 is programmed continuously, e.g., written to and erased repeatedly, that particular area generally wears out more quickly than an area which is not programmed continuously. In order to effectively “even out” the wear of different areas withinnon-volatile memory124, wear leveling may be substantially automatically performed such that areas which are programmed continuously are programmed less, while areas that are not programmed continuously may be programmed more.
Generally, to perform wear leveling, a block, e.g., a set of sectors which are associated with a physical location, which is programmed repeatedly may be swapped with a block which is associated with a physical location which is not programmed repeatedly. That is, a physical block which has been programmed and, hence, erased repeatedly may be swapped with a physical block which has been programmed and erased less often.
In one embodiment of the present invention, in order for it to be readily determined whether a particular physical block has been programmed and erased repeatedly, an erase count may be stored with the block. That is, a counter which keeps track of how many times a block has been erased may be maintained and incremented each time the block is erased. Such an erase count may be used to facilitate a determination of whether a particular block should be swapped with another block which has been erased less often.FIG. 2 is a diagrammatic representation of a portion of a flash memory in accordance with an embodiment of the present invention. Flash memory200 may be divided into pages204. Each page204, which generally contains approximately 512 bytes of user data, effectively includes a redundant area206, e.g.,page204aincludesredundant area206a. Each redundant area206 or overhead area may include up to approximately sixteen bytes of information which typically includes, but is not limited to, a group identifier216, an update index212, and an erase count214.
Typically, any number of pages204 are included in ablock210. For ease of illustration,pages204a,204bare shown as being included inblock210, although it should be appreciated that the number of pages204 included inblock210 may vary widely. In the described embodiment, block210 may be arranged to include approximately 32 pages. For example, when flash memory200 includes approximately 512 MegaBytes (MB), flash memory200 may effectively be divided into approximately 4096 blocks of 32 pages each.
As previously mentioned, erase count214 may be incremented each time user data is erased from an associated block. For instance, erase count214, which is associated withblock210, may be incremented each time data is erased fromblock210. Since eachpage204a,204bincluded inblock210 generally has an erase count214, the erase count214 associated with eachpage204a,204bmay be incremented when block210 is erased.
When a block containing data is erased, both the data area and the redundant area are typically erased or emptied. The erased block is added to spare block pools, which contains the erased blocks containing smaller erase count comparing to erased blocks of other tables. The spare block table is essentially a least frequently erased bloc table. In one embodiment of the present invention, an erased block which has a relatively large erase count is added to the pool containing the erased blocks which have larger erase counts than the erased blocks contained in other tables. That pool, i.e., the pool containing the erased blocks which have larger erase counts, is the most frequently erased block table. The erase count of a just-erased block is incremented by one and is saved in the least frequently erased block table or the most frequently erased block table depending on the value of the erase count.
An erase count such as erase count214 may be accessed during an initialization request. An initialization request may be made, for example, when a system, e.g., a system which includes embedded flash memory, is powered up, when spare blocks within a system are running low, when a user makes a request to balance block allocation, and when a user makes a request for block usage to occur more evenly.FIG. 3 is a process flow diagram which illustrates the steps associated with processing an initialization request with respect to a flash memory system, in accordance with an embodiment of the present invention. In general, an initialization request may either be initiated by a user or substantially automatically initiated by a controller associated with flash memory system, e.g., periodically or when a triggering condition is met. Aprocess300 of responding to an initialization request begins atstep304 in which an initialization request is effectively received. An initialization request may be received by a controller or a processor which is in communication with flash memory which is to be initialized. Such a request may be provided by a user via a host at power up, or when block allocation is to be balanced, for example.
Once the initialization request is received, an average erase count is obtained instep306. In one embodiment, the average erase count is stored in an erase count block which is written into NAND memory associated with the system. The erase count block containing the average erase count and the erase count of each block is stored in a block of the flash memory. It should be appreciated that when an erase count block is created, e.g., when the system is initially formatted, the average erase count and the erased count of each block are typically initialized to a value of zero. After the average erase count is obtained, erase counts for substantially all blocks within the system are obtained. As described above with respect toFIG. 2, the erase count for a particular block containing data is stored in a redundant area that is associated with that block. Hence, obtaining the erase count for substantially all blocks containing data may include accessing a redundant area associated with each block, and storing each erase count into the erase count block at an initialization request.
After the initialization request is completed, the erase count of the erased block may not necessarily be updated in the erase count block. The erase count block generally retains its value because the redundant area of the erased block is erased. When the overall system is shut down, a termination request is made so that the erase count block is updated to contain the latest erased count of substantially all blocks. The erase count of an erased block belonging to a least frequently erased block is retrieved from the least frequently erased block table. The erase count of an erased block belonging to a most frequently erased block is retrieved from the most frequently erased block table. The erase count of substantially any remaining erased block may be retrieved from the erase count block.
Instep320, a block mapping table is allocated in the NAND memory. As will be appreciated by those skilled in the art, a block mapping table may be arranged to provide a mapping between a logical block address (LBA) and a physical block address (PBA). Additionally, a most frequently erased block table and a least frequently erased block table are also allocated instep320.
A most frequently erased block table is typically sized or otherwise configured to effectively hold information relating to erased blocks which have been erased most frequently. That is, a most frequently erased block is arranged to hold information, e.g., erase counts and mapping information, pertaining to erased blocks with the highest erase counts in the system. Similarly, a least frequently erased block table is generally sized or otherwise configured to accommodate information pertaining to erased blocks with the lowest erase counts. Although the size of the most frequently erased block table and the size of the least frequently erased block table may vary widely, the sizes are dependent upon the number of blocks which are to be designated as most frequently erased and the number of blocks which are to be designated as least frequently erased. Typically, the most frequently erased block table is generally sized to accommodate information for fewer erased blocks than the least frequently erased block table. By way of example, the least frequently erased block table may be sized to accommodate information for approximately seventy erased blocks, while the most frequently erased block table may be sized to accommodate information relating to approximately eighteen erased blocks. Alternatively, the least frequently erased block table may be sized to accommodate information for approximately fifty erased blocks, while the most frequently erased block table may be sized to accommodate information for approximately ten erased blocks.
After tables are allocated instep320, erased blocks are identified instep324. Then, instep328, “N” erased blocks may be assigned to the most frequently erased blocks and essentially be assigned to the most frequently erased table. In one embodiment, the “N” erased blocks may be the “N” erased blocks with the highest erase counts as determined by a comparison of all erase counts. Alternatively, the “N” erased blocks to store in the most frequently erased block table may be determined based upon a comparison against the average erase count obtained instep306. For instance, the “N” erased blocks may be “N” erased blocks which have an erase count that is at least a given percentage, e.g., approximately twenty-five percent, higher than the average erase count.
Once the most frequently erased block table is effectively populated, “M” erased blocks may be identified and effectively be assigned to the least frequently erased block table instep332. The “M” erased blocks may generally be the “M” erased blocks with the lowest erase counts of all erased blocks associated with the system, or the “M” erased blocks may be “M” erased blocks which have an erase count that is at least a given percentage lower than the average erase count. The “M” erased blocks are effectively spare blocks which will be assigned to the block mapping table as appropriate.
Remaining erased blocks, i.e., erased blocks which have not be assigned to either the least frequently erased block table or the most frequently erased block table, are assigned to the block mapping table along with “unerased” blocks instep336. In other words, remaining erased blocks as well as blocks containing data other than in associated redundant areas are associated with the block mapping table.
After the block mapping table, the least frequently erased block table, and the most frequently erased block table are effectively populated, e.g., with erase counts and mapping information pertaining to corresponding blocks, an average erase count may be determined instep338. Determining the average erase count typically involves summing the erase counts of individual blocks which were obtained instep308, and dividing the sum by the total number of blocks.
The average erase count calculated instep338 is stored into the erase count block associated with the system. As previously mentioned, the average erase count is stored in an erase count block which is written into NAND memory associated with the system. Upon storing the average erase count into the erase count block, static blocks, or blocks which contain data and have a relatively low associated erase count, may be processed instep342. The steps associated with one method of processing a static block will be described below with respect toFIG. 4. Once the static blocks are processed, the process of processing an initialization request is completed.
Within a group of blocks associated with a flash memory, there are usually blocks which are erased and blocks which contain data, i.e., user data, at any given time. Some of the blocks which contain data may be considered to be “normal” blocks, while others may be considered to be static blocks. Static blocks are blocks that contain data which is rarely changed. In other words, static blocks are rarely erased. Typically, static blocks may be associated with relatively old documents stored in flash memory, an executable program stored in the flash memory, or an operating system stored in the flash memory. A static block may generally have an erase count that is substantially lower than the erase count of the majority of blocks within flash memory. In one embodiment, a block which contains data may be considered to be a static block if the erase count of the block is below a certain percentage, e.g., approximately twenty percent, of the average erase count associated with a flash memory system.
Since a static block contains data that is rarely changed, the data contained in the static block may be copied into a block which has a relatively high erase count. That is, when the contents of a particular physical block are relatively static and, hence, are generally not changed, the contents may effectively be reassigned to a different physical block which has a relatively high erase count in order to enable the original physical block, which has a relatively low erase count, to be used to store contents which are changed more frequently. With reference toFIG. 4, the steps associated with processing a static block, i.e., step342 ofFIG. 3, will be described in accordance with an embodiment of the present invention. Aprocess342 of processing a static block of a system begins atstep404 in which the erase count of a block, e.g., block “A,” is accessed. Once the erase count of block “A” is accessed, a determination is made instep408 regarding whether the erase count of block “A” is very low compared to the average erase count associated with the system.
Although a determination of whether the erase count of non-erased block “A” is low compared to the average erase count may be based on substantially any suitable criteria, in one embodiment, the determination is made based on whether the erase count of block “A” has a value that is less than a value associated with a fraction of the average erase count. For example, the erase count of block “A” may be considered to be low when the erase count is less than a predetermined percentage of the average erase count.
If it is determined instep408 that the erase count of block “A” is not very low compared to the average erase count, then the indication is that block “A” is most likely not a static block. It should be appreciated that while block “A” may still be a static block even if the erase count of block “A” is not considered to be very low, the erase count of block “A” in such a case would effectively not trigger a swap of block “A” with another block. Accordingly, the processing of a static block is completed.
Alternatively, if it is determined instep408 that the erase count of block “A” is very low compared to the average erase count, then the implication is that the contents of block “A” may be written into a block with a relatively high erase count such that block “A” with its low erase count may be free to store data that is changed relatively frequently. In other words, the indication when the erase count of block “A” is very low compared to the average erase count is that block “A” is a static block. As such, process flow moves fromstep408 to step412 in which block “A” is identified as a static block. Once block “A” is identified as a static block, a block, namely block “B,” may be obtained from a group of most frequently erased blocks as identified by the most frequently erased block table instep416.
After block “B” is obtained, the contents of block “A” are copied into block “B” instep420. That is, the user data contained in block “A” is copied into block “B” instep420. Once the contents of block “A” are copied into block “B,” block “A” is erased instep424. Typically, when block “A” is erased, the erase count associated with block “A” is incremented. A block, e.g., block “C,” may be moved from the group of least frequently erased blocks into the group of most frequently erased blocks instep428 such that the association of block “C” is effectively changed to the most frequently erased block table from the least frequently erased block table. In other words, block “C” is disassociated from the least frequently erased block table and associated with the most frequently erased block table. Such a move allows a space in the least frequently erased block table to effectively be opened up to accommodate block “A,” which has a low erase count and, hence, is one of the least frequently erased blocks in the system. Typically, block “C” is the block with the highest erase count of the least frequently erased blocks.
Upon moving block “C” out of the group of least frequently erased blocks, or otherwise disassociating block “C” from the least frequently erased block table, process flow moves fromstep428 to step432 in which block “A” is effectively moved from the block mapping table into the least frequently erased block table instep432. Then, instep434, block “B.” which includes contents that were previously contained in block “A,” is associated with the block mapping table. As will be appreciated by those skilled in the art, “moving” block “B” into the block mapping table typically includes updating the mapping of a logical block address that was associated with block “A” to now be associated with block “B.” When information pertaining to block “C” is present in the most frequently erased block table, information pertaining to block “B” is present in the block mapping table, and information pertaining to block “A” is present in the least frequently erased block table, the process of processing a static block is completed. It should be understood thatprocess342 may be repeated until substantially all static blocks associated with a system have been identified and processed.
In general, a block mapping table, a least frequently erased block table, and a most frequently erased block table may be created in system memory, e.g.,RAM112 ofFIG. 1a, when an initialization request is sent to an overall flash memory system. The tables may also be built substantially anytime an initialization request is made, as discussed above. To build the tables, space may first be allocated in system memory to accommodate the tables.
As mentioned above, a block mapping table, a least frequently erased block table, and a most frequently erased block table are created in system memory, as is an average erase count. The average erase count and the erase count of each block are also written, in one embodiment, to the erase count block.FIG. 5ais a diagrammatic block diagram representation of a system memory in accordance with an embodiment of the present invention. Asystem memory454 and aflash memory460 are included in an overall system, and may, for example, effectively be components of a memory card or components of a host device in whichflash memory460 is embedded.System memory454 is arranged to store a block mapping table462 with which blocks may be associated. Typically, block mapping table462 may be used in order to associate LBAs with physical blocks associated withflash memory460.
System memory454 also holds a least frequently erased block table466 and a most frequently erased block table470 which, like block mapping table462, are generally formed in response to an initialization request. An average erasecount474, which is arranged to hold the average erase count of blocks withinflash memory460, is created when an overall flash memory system is formatted. In one embodiment, erasecount block480 is also arranged to contain the erase counts of substantially all blocks withinflash memory460. Each time an initialization request is made, an updated average erase count may be calculated, and stored into erasecount block480.
FIG. 5bis a diagrammatic representation of a group of “normal” blocks, a group of least frequently erased blocks, and a group of most frequently erased blocks in accordance with an embodiment of the present invention. A group ofblocks502 includesblocks514 which may be normal or static blocks which generally contain user data, which may be erased but does not fall into the categories of a least frequently erased block or a most frequently erased block, as will be described below. A group least frequently erasedblocks506 generally includesblocks518 which have the lowest erase counts within an overall system, while a group of most frequently erasedblocks510 generally includesblocks522 which have the highest erase counts of the erased blocks within the overall system. In general, blocks518 are effectively used as spare blocks.
When ablock514 is erased, it may be determined whether erasedblock514 has a relatively low associated erase count or a relatively high associated erase count. When erasedblock514 has a relatively low associated erase count, erasedblock514 may be added to group of least frequently erased blocks506. On the other hand, when erasedblock514 has a relatively high associated erase count, erasedblock514 may be reassigned to group of most frequently erased blocks510.
Group of least frequently erasedblocks506, which may be of substantially any size, may be a sorted group. That is, blocks518 may be substantially sorted based on erase counts. The sorting is typically reflected in a corresponding least frequently erased block table (not shown) which contains entries associated withblocks518. For instance, each time anew block518 is moved into or added to, or otherwise associated with, group of least frequently erasedblocks506, blocks518 may essentially be sorted based on erase counts such that the least frequently erasedblock518 in group of least frequently erasedblocks506 may be thenext block518 to be reassigned, as for example togroup502. In other words, when a new block into which data is to be copied is needed, the least erased block518 ofblocks518 is identified using a least frequently erased block table, and taken from group of least frequently erased blocks506. Typically, when ablock514 which contains data that is not needed is erased, thatblock514 may be stored into group of least frequently erasedblocks506, and the least frequently erased block table may be updated accordingly, i.e., an entry which corresponds to the added block may be included in the least frequently erased block table.
Blocks522 in group of most frequently erasedblocks510, likeblocks518 stored in group of least frequently erasedblocks506, may also be substantially sorted based on erase counts. The sorting is typically implemented by sorting entries in a most frequently erased block table (not shown) which serves to identifyblocks522. In one embodiment, an average erase count associated withblocks522 may be calculated, i.e., an average erase count for group of most frequently erasedblocks510 may be determined. When ablock514 fromgroup502 is erased, and the erase count of the erasedblock514 is found to exceed the average erase count for group of most frequently erasedblocks510 by more than a given percentage, e.g., more than approximately twenty percent, the erasedblock514 may be added to group of most frequently erased blocks510. When anew block522 is effectively added to group of most frequently erasedblocks510, ablock522 within group of frequently erasedblocks510 that has the lowest erase count may be reassigned intogroup502. Such reassignments are typically reflected by updating an associated block mapping table, least frequently erased block table, and most frequently erased block table (not shown).
The swapping of blocks betweengroup502, group of least frequently erasedblocks506, and most frequently erasedblocks510 may generally occur when ablock514 included ingroup502 is to be erased or updated. Alternatively, the swapping or updating of blocks may occur substantially any time it is desired for a spare block to be allocated for use ingroup502. Referring next toFIG. 6, one method of performing a block swap in an overall memory system such as a host system with embedded flash memory to allow for more even wear of the blocks will be described in accordance with an embodiment of the present invention. Aprocess600 of performing a block swap or update begins atstep604 in which a block, e.g., block “Y,” is “obtained” from a block mapping table or otherwise identified using the block mapping table. The block that is obtained is the block that is to be effectively swapped out of the block mapping table for copying or updating its contents.
Once block “Y” is obtained, a block, e.g., block “X,” is effectively obtained instep608 from the least frequently erased block table. That is, a spare block is obtained from the group of least frequently erased blocks using the least frequently erased block table to identify an appropriate spare block. In general, block “X” is the block with the lowest erase count in the group of least frequently erased blocks, although it should be appreciated that block “X” may be substantially any block associated with the group of least frequently erased blocks and, hence, the least frequently erased block table. The contents or, more specifically, data contents stored in block “Y” or the new contents which are to replace the original contents of “Y” are copied into block “X” instep612.
After the contents of block “Y” are copied into block “X,” block “X” is effectively moved into, or associated with, the block mapping table instep616. In other words, mappings associated with block “Y” and block “X” are effectively updated such that an LBA which was previously mapped to block “Y” is remapped to block “X.” When block “X” is effectively moved into the block mapping table, block “Y” is erased instep620. Specifically, the data contents, e.g., user contents, stored in block “Y” may be erased using substantially any suitable technique. The erase count associated with block “Y,” which is stored in a redundant area associated with block “Y,” is then incremented instep624 to indicate that block “Y” has once again been erased. It should be appreciated that in one embodiment, an erase count for “Y” which is effectively stored in an erase count block may be updated.
Instep628, the block with the lowest erase count in the most frequently erased block table is identified. As described above, in one embodiment, blocks referenced in the most frequently erased block table are sorted according to their respective erase counts. Sorting the blocks may include positioning the references to the blocks within the most frequently erased block table according to the erase counts of the blocks. Hence, identifying the block with the lowest erase count generally involves accessing the block reference in the position within the most frequently erased block table that is arranged to accommodate the block reference with the lowest erase count.
Once the block with the lowest erase count referenced in the most frequently erased block table is identified, process flow moves fromstep628 to step632 in which it is determined if the erase count of block “Y” is greater than the erase count of the block with the lowest erase count referenced in the most frequently erased block table. If it is determined that the erase count of block “Y” is not greater than the erase count of the block with the lowest erase count referenced in the most frequently erased block table, then the indication is that block “Y” is not considered to be frequently erased. Accordingly, process flow proceeds fromstep632 to step636 in which block “Y” is moved into the group of least frequently erased blocks and effectively moved into the least frequently erased block table, i.e., an entry corresponding to block “Y” is added into the least frequently erased block table. It should be appreciated that, in one embodiment, moving block “Y” into the group of least frequently erased blocks may include resorting substantially all block references in the least frequently erased block table using the erase count of each block. After block “Y” is effectively moved into the least frequently erased block table, the process of swapping or updating blocks is completed.
Returning to step632, if the determination isstep632 is that the erase count of block “Y” exceeds the lowest erase count associated with the most frequently erased block table, the indication is that block “Y” should be moved into the group of most frequently erased blocks and effectively into the most frequently erased block table. In order for there to be room for block “Y” to be referenced in the most frequently erased block table, a block, e.g., the block with the lowest erase count referenced in the most frequently erased block table, effectively needs to be removed from the most frequently erased block table. As such, instep640, the block with the lowest erase count referenced in the most frequently erased block table is moved into the group of least frequently erased blocks, and effectively moved into the least frequently erased block table. Moving the block into the group of least frequently erased blocks may include resorting the block references in the least frequently erased block table according to the erase count of each block.
After the block with the lowest erase count in the most frequently erased block table is effectively moved out of the most frequently erased block table, block “Y” is effectively moved into the most frequently erased block table instep644. In one embodiment, moving block “Y” into the group of most frequently erased blocks and, hence, effectively into the most frequently erased block table, may include resorting the most frequently erase blocks according to the erase count of each block, including block “Y.” When block “Y” is effectively moved into the most frequently erased block table, the process of swapping blocks is completed.
In general, the functionality associated with maintaining tables, handling initialization requests, and performing wear leveling, e.g., responding to requests to swap blocks, is provided in software, e.g., as program code devices, or as firmware to a host system. One embodiment of a suitable system architecture associated with the software or firmware provided to a host system to enable wear leveling to occur is shown inFIG. 7. Asystem architecture700 generally includes a variety of modules which may include, but are not limited to, anapplication interface module704, asystem manager module708, adata manager module712, adata integrity manager716, and a device manager andinterface module720. In general,system architecture700 may be implemented using software code devices or firmware which may be accessed by a processor, e.g.,processor108 ofFIG. 1a.
In general,application interface module704 may be arranged to communicate with a flash memory (not shown) or, more generally, a media, to initialize the media during the course of an initialization request.Application interface module704 may also read from, as well as write to, a sector, a cluster, or a page associated with the media. Typically, in addition to communicating with a media,application interface module704 is also in communication withsystem manager module708 anddata manager module712.
System manager module708 includes asystem initialization submodule724, an erase countblock management submodule726, and a powermanagement block submodule730.System initialization submodule724 is generally arranged to enable an initialization request to be processed, and typically communicates with erase countblock management submodule726. In one embodiment,system initialization submodule724 allows erase counts of blocks to be updated, and is substantially responsible for creating a least frequently erased block table and a most frequently erased block table.
Erase countblock management submodule726 includes functionality to cause erase counts of blocks to be stored, and functionality to cause an average erase count to be calculated, as well as updated, using individual erase counts. In other words, erase countblock management submodule726 effectively allows an average erase count to be maintained. Further, in one embodiment, erase countblock management submodule726 also substantially synchronizes the erase count of substantially all blocks in an erase count block during a power up of an overall system. While erase countblock management submodule726 may be arranged to cause an average erase count to be stored in an erase count block, it should be appreciated that powermanagement block submodule730 may instead be used to enable the average erase count to be stored.
In addition to being in communication withapplication interface module704,system manager module708 is also in communication withdata manager module712, as well as device manager andinterface module720.Data manager module712, which communicates with bothsystem manager module708 andapplication interface module704, may include functionality to provide page or block mapping.Data manager module712 may also include functionality associated with operating system and file system interface layers.
Device manager andinterface module720, which is in communication withsystem manager module708,data manager712, anddata integrity manager716, typically provides a flash memory interface, and includes functionality associated with hardware abstractions, e.g., an I/O interface. Dataintegrity manager module716 provides ECC handling, among other functions.
Although only a few embodiments of the present invention have been described, it should be understood that the present invention may be embodied in many other specific forms without departing from the spirit or the scope of the present invention. By way of example, in lieu of assigning blocks to a most frequently erased block table and a least frequently erased block table based on a comparison of each block against an average erase count, blocks may instead be assigned to a most frequently erased block table and a least frequently erased block table based on a substantially absolute determination of which blocks have the highest erase counts and which blocks have the lowest erase counts, respectively. In other words, rather than comparing individual block erase counts against an average erase count, block erase counts may effectively be compared against each other to determine an appropriate table in which to insert a block.
A least frequently erased block table has generally been described as holding references to blocks with a relatively low erase count as spare blocks. Spare blocks are effectively allocated for use through the use of a block mapping table such that substantially any time a spare block is needed, the block with the lowest erase count referenced in the least frequently erased block table is provided for use. In other words, when a block identified in a block mapping table is to be swapped out, a reference to the block with the lowest erase count in the group of least frequently erased blocks is moved into the block mapping table. It should be appreciated, however, that substantially any block may generally be taken from the group of least frequently erased blocks during a block swapping or updating process. Selecting substantially any block from the least frequently erased blocks using the least frequently erased block table to move into the block mapping table may reduce the overhead associated with an overall system, as the blocks within the least frequently erased block table may not necessarily be sorted.
Identifying and processing static blocks generally enhances the ability to enable blocks within an overall memory system to be worn evenly. In one embodiment, however, static blocks are not necessarily identified and processed. For example, if a relatively low number of static blocks is anticipated within a system, the identification and processing of static blocks may be substantially eliminated without departing from the spirit or the scope of the present invention.
While non-volatile memory systems have been described as being controlled by associated memory controllers or being controlled using software or firmware associated with a host system, it should be understood that wear leveling processes which include erase count management may be applied to non-volatile memory systems which are in communication with controllers which are substantially external to the non-volatile memory systems. Suitable memory systems which use controllers include, but are not limited to, PC cards, CompactFlash cards, MultiMedia cards, Secure Digital cards, and embedded chip sets which include flash memory and a flash memory controller. Memory systems which are controlled through the use of software or firmware loaded onto a host system include embedded memory devices. In one embodiment, memory systems which may use the erase management techniques described above and do not use controllers associated with the memory systems may use controllers associated with a host, e.g., a host computer system, to implement wear leveling. That is, a host may directly address and manage memory in which wear leveling is to occur through the use of a controller on the host.
In general, the steps associated with the various processes and methods of wear leveling may vary widely. Steps may generally be added, removed, altered, and reordered without departing from the spirit of the scope of the present invention. By way of example, processing static blocks may not necessarily be included in the processing an initiation request. Also, in one embodiment, the determination of whether to effectively place a newly erased block into a most frequently erased block table may be based upon other criteria in lieu of being based upon whether the erased block has an erase count that is greater than the lowest erase count associated with the most frequently erased block table. For instance, such a determination may be based upon whether the erase count of the erased block exceeds an average erase count of substantially all blocks associated with the most frequently erased block table for a certain percentage, e.g., approximately twenty percent. When the erase count of the erased block exceeds the average erase count by more than the certain percentage, then the block with the lowest erase count referenced in the most frequently erased block table may be moved into a least frequently erased block table, while the erased block is moved into the most frequently erased block table. Therefore, the present examples are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope of the appended claims.

Claims (24)

1. A method for processing elements included in a non-volatile memory of a memory system, each element having an associated erase count, the method comprising:
identifying a first set of erased elements, wherein the erased elements included in the first set of erased elements are less worn than erased elements not included in the first set of erased elements, by identifying a number of erased elements for which the associated erase counts are relatively low and grouping the identified erased elements into the first set;
placing entries associated with the first set of elements into a data structure;
sorting the entries within the data structure; and
identifying a first element within the first set of elements using the sorted entries, wherein the first element is less worn than other elements included in the first set of elements;
determining when a second element not included in the first set is to be erased;
removing the first element from the first set when it is determined that the second element is to be erased;
copying one of contents of the second element and new contents to replace the contents of the second element into the first element;
erasing the contents from the second element; and
adding the second element to the first set.
2. The method ofclaim 1, wherein the step of identifying the first set of elements comprises:
obtaining erase counts associated with a plurality of elements, the plurality of elements including erased elements and elements containing data, wherein each element included in the plurality of elements has an associated erase count, the associated erase count of each element being arranged to indicate a number of times the element has been erased; and
defining a first set of erased elements by selecting erased elements having the lowest associated erase counts relative to the erase counts associated with the plurality of elements;
and wherein the placing step comprises:
storing the erase counts associated with the first set in a memory component substantially within a table, wherein the memory component is associated with the memory system.
18. A flash memory system, comprising:
an array of non-volatile memory cells, arranged into a plurality of physical blocks;
system memory, comprising non-volatile memory for storing at least one data structure comprised of a plurality of entries, the entries including erase counts of physical blocks of the array; and
memory controller circuitry, coupled to the array and the system memory, and programmed to perform a plurality of operations comprising:
identifying a first set of erased physical blocks, wherein the erased physical blocks included in the first set of erased physical blocks are less worn than erased physical blocks not included in the first set of erased physical blocks, by identifying a number of erased physical blocks for which the associated erase counts stored in the system memory are relatively low and grouping the identified erased physical blocks into the first set;
placing entries associated with the first set of physical blocks into a first data structure;
sorting the entries within the first data structure;
identifying a first physical block within the first set of physical blocks using the sorted entries, wherein the first physical block is less worn than other physical blocks included in the first set of physical blocks;
determining when a second physical block not included in the first set is to be erased;
removing the first physical block from the first set when it is determined that the second physical block is to be erased;
copying one of contents of the second physical block and new contents to replace the contents of the second physical block into the first physical block;
erasing the contents from the second physical block; and
adding the second physical block to the first set.
US10/281,8242002-10-282002-10-28Tracking the least frequently erased blocks in non-volatile memory systemsExpired - LifetimeUS7096313B1 (en)

Priority Applications (8)

Application NumberPriority DateFiling DateTitle
US10/281,824US7096313B1 (en)2002-10-282002-10-28Tracking the least frequently erased blocks in non-volatile memory systems
AU2003270529AAU2003270529A1 (en)2002-10-282003-09-10Tracking the least frequently erased blocks in non-volatile memory systems
JP2004548318AJP2006504199A (en)2002-10-282003-09-10 Tracking least frequently erased blocks in non-volatile memory systems
CNA038247801ACN1698036A (en)2002-10-282003-09-10 Tracking the least frequently erased blocks in a non-volatile memory system
EP03752227AEP1559017A1 (en)2002-10-282003-09-10Tracking the least frequently erased blocks in non-volatile memory systems
KR1020057007322AKR20050084879A (en)2002-10-282003-09-10Tracking the least frequently erased blocks in non-volatile memory systems
PCT/US2003/028429WO2004040459A1 (en)2002-10-282003-09-10Tracking the least frequently erased blocks in non-volatile memory systems
TW092125790ATWI249100B (en)2002-10-282003-09-18Tracking the least frequently erased blocks in non-volatile memory systems

Applications Claiming Priority (1)

Application NumberPriority DateFiling DateTitle
US10/281,824US7096313B1 (en)2002-10-282002-10-28Tracking the least frequently erased blocks in non-volatile memory systems

Publications (1)

Publication NumberPublication Date
US7096313B1true US7096313B1 (en)2006-08-22

Family

ID=32228777

Family Applications (1)

Application NumberTitlePriority DateFiling Date
US10/281,824Expired - LifetimeUS7096313B1 (en)2002-10-282002-10-28Tracking the least frequently erased blocks in non-volatile memory systems

Country Status (8)

CountryLink
US (1)US7096313B1 (en)
EP (1)EP1559017A1 (en)
JP (1)JP2006504199A (en)
KR (1)KR20050084879A (en)
CN (1)CN1698036A (en)
AU (1)AU2003270529A1 (en)
TW (1)TWI249100B (en)
WO (1)WO2004040459A1 (en)

Cited By (75)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US20050108301A1 (en)*2003-11-142005-05-19Changjian LouMethod for balancing wear when writing data in a flash memory
US20060004951A1 (en)*2004-06-302006-01-05Rudelic John CMethod and apparatus to alter code in a memory
US20060069850A1 (en)*2004-09-302006-03-30Rudelic John CMethods and apparatus to perform a reclaim operation in a nonvolatile memory
US20060069849A1 (en)*2004-09-302006-03-30Rudelic John CMethods and apparatus to update information in a memory
US20060149891A1 (en)*2004-12-302006-07-06Rudelic John CRelocated reclaim block
US20060256623A1 (en)*2005-05-122006-11-16Micron Technology, Inc.Partial string erase scheme in a flash memory device
US20070047305A1 (en)*2002-12-092007-03-01Conley Kevin MZone Boundary Adjustments for Defects in Non-Volatile Memories
US20070079054A1 (en)*2005-09-302007-04-05Rudelic John CMethod and apparatus for optimizing flash device erase distribution
US20070083698A1 (en)*2002-10-282007-04-12Gonzalez Carlos JAutomated Wear Leveling in Non-Volatile Storage Systems
US20070198626A1 (en)*2006-02-202007-08-23Kabushiki Kaisha ToshibaSemiconductor memory device
US20070198902A1 (en)*2006-01-202007-08-23Kabushiki Kaisha ToshibaSemiconductor memory device
US20070220400A1 (en)*2006-02-272007-09-20Kabushiki Kaisha ToshibaSemiconductor memory device
US20070266291A1 (en)*2006-05-152007-11-15Kabushiki Kaisha ToshibaSemiconductor memory device
US20080126724A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for reducing memory write operations using difference information
US20080126685A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for reducing memory write operations using an instruction set
US20080126719A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for delaying an operation that reduces a lifetime of memory
US20080126720A1 (en)*2006-11-242008-05-29Radoslav DanilakMulti-memory device system and method for managing a lifetime thereof
US20080126891A1 (en)*2006-11-242008-05-29Radoslav DanilakMemory lifetime gauging system, method and computer program product
US20080141054A1 (en)*2006-12-082008-06-12Radoslav DanilakSystem, method, and computer program product for providing data redundancy in a plurality of storage devices
US20080141055A1 (en)*2006-12-082008-06-12Radoslav DanilakSystem and method for providing data redundancy after reducing memory writes
US20080147998A1 (en)*2006-12-182008-06-19Samsung Electronics Co., Ltd.Method and apparatus for detecting static data area, wear-leveling, and merging data units in nonvolatile data storage device
WO2008078844A1 (en)*2006-12-222008-07-03Seoul National University Industry FoundationMethod and apparatus for mapping flash memory
US20080231810A1 (en)*2007-03-192008-09-25Catania Louis JMethod of fitting contact lenses
US20080276035A1 (en)*2007-05-032008-11-06Atmel CorporationWear Leveling
US20080294813A1 (en)*2007-05-242008-11-27Sergey Anatolievich GorobetsManaging Housekeeping Operations in Flash Memory
US20080294814A1 (en)*2007-05-242008-11-27Sergey Anatolievich GorobetsFlash Memory System with Management of Housekeeping Operations
US20090132778A1 (en)*2007-11-192009-05-21Radoslav DanilakSystem, method and a computer program product for writing data to different storage devices based on write frequency
US20090129163A1 (en)*2007-11-192009-05-21Radoslav DanilakSystem, method, and computer program product for increasing a lifetime of a plurality of blocks of memory
US20090138671A1 (en)*2007-11-282009-05-28Radoslav DanilakSystem, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
US20090196103A1 (en)*2008-02-042009-08-06Mosaid Technologies IncorporatedNon-volatile memory device having configurable page size
US20090196102A1 (en)*2008-02-042009-08-06Mosaid Technologies IncorporatedFlexible memory operations in nand flash devices
US20100017566A1 (en)*2008-07-152010-01-21Radoslav DanilakSystem, method, and computer program product for interfacing computing device hardware of a computing device and an operating system utilizing a virtualization layer
US20100017588A1 (en)*2008-07-152010-01-21Radoslav DanilakSystem, method, and computer program product for providing an extended capability to a system
US20100023672A1 (en)*2007-11-132010-01-28Sergey Anatolievich GorobetsMethod And System For Virtual Fast Access Non-Volatile RAM
US20100049909A1 (en)*2005-09-262010-02-25Menahem LasserNAND Flash Memory Controller Exporting a NAND Interface
US20100064093A1 (en)*2008-09-092010-03-11Radoslav DanilakSystem, method, and computer program product for converting data in a binary representation to a non-power of two representation
US20100146236A1 (en)*2008-12-082010-06-10Radoslav DanilakSystem, method, and computer program product for rendering at least a portion of data useless in immediate response to a delete command
US20100250830A1 (en)*2009-03-272010-09-30Ross John StenfortSystem, method, and computer program product for hardening data stored on a solid state disk
US20100251009A1 (en)*2009-03-272010-09-30Ross John StenfortSystem, method, and computer program product for converting logical block address de-allocation information in a first format to a second format
US20100246266A1 (en)*2009-03-252010-09-30Samsung Electronics Co., Ltd.Nonvolatile memory device and related programming method
US20100268864A1 (en)*2009-04-202010-10-21Arunprasad Ramiya MothilalLogical-to-Physical Address Translation for a Removable Data Storage Device
US20100268865A1 (en)*2009-04-202010-10-21Arunprasad Ramiya MothilalStatic Wear Leveling
US20110004718A1 (en)*2009-07-022011-01-06Ross John StenfortSystem, method, and computer program product for ordering a plurality of write commands associated with a storage device
US20110004710A1 (en)*2009-07-062011-01-06Ross John StenfortSystem, method, and computer program product for interfacing one or more storage devices with a plurality of bridge chips
US20110016239A1 (en)*2009-07-202011-01-20Ross John StenfortSystem, method, and computer program product for reducing a rate of data transfer to at least a portion of memory
US20110016233A1 (en)*2009-07-172011-01-20Ross John StenfortSystem, method, and computer program product for inserting a gap in information sent from a drive to a host device
US20110029715A1 (en)*2009-07-292011-02-03International Business Machines CorporationWrite-erase endurance lifetime of memory storage devices
US20110041005A1 (en)*2009-08-112011-02-17Selinger Robert DController and Method for Providing Read Status and Spare Block Management Information in a Flash Memory System
US20110083047A1 (en)*2009-10-052011-04-07Ross John StenfortSystem, method, and computer program product for sending failure information from a serial ata (sata) solid state drive (ssd) to a host device
US8230159B2 (en)2009-03-272012-07-24Lsi CorporationSystem, method, and computer program product for sending logical block address de-allocation status information
US8291295B2 (en)2005-09-262012-10-16Sandisk Il Ltd.NAND flash memory controller exporting a NAND interface
US20120317345A1 (en)*2011-06-092012-12-13Tsinghua UniversityWear leveling method and apparatus
US8612804B1 (en)2010-09-302013-12-17Western Digital Technologies, Inc.System and method for improving wear-leveling performance in solid-state memory
US8671259B2 (en)2009-03-272014-03-11Lsi CorporationStorage system data hardening
US8898373B1 (en)2011-06-292014-11-25Western Digital Technologies, Inc.System and method for improving wear-leveling performance in solid-state memory
US20160011782A1 (en)*2013-02-272016-01-14Hitachi, Ltd.Semiconductor storage
US20160139826A1 (en)*2014-11-132016-05-19Micron Technology, Inc.Memory Wear Leveling
US20160162354A1 (en)*2014-12-042016-06-09HGST Netherlands B.V.Systems and methods for multi-zone data tiering for endurance extension in solid state drives
CN106527969A (en)*2016-09-212017-03-22中国科学院地质与地球物理研究所NandFlash memory read-write method capable of guaranteeing service life balance
US20170139826A1 (en)*2015-11-172017-05-18Kabushiki Kaisha ToshibaMemory system, memory control device, and memory control method
US20170300408A1 (en)*2016-04-152017-10-19Nxp Usa, Inc.System and method for reducing stress on memory device
US9875039B2 (en)2014-09-302018-01-23Sandisk Technologies LlcMethod and apparatus for wear-leveling non-volatile memory
US9970288B2 (en)2016-08-312018-05-15Institute of geology and geophysics, Chinese Academy of ScienceReceiving apparatus for downhole near-bit wireless transmission
US10025003B1 (en)2017-01-192018-07-17Institute Of Geology And Geophysics, Chinese Academy Of SciencesCalibration method under near-bit wireless short-transmission ground envrionment based on electric field theory
US10030504B2 (en)2016-11-212018-07-24Institute Of Geology And Geophysics, Chinese Academy Of SciencesReceiving apparatus suitable for azimuthally acoustic logging while drilling
US10082021B2 (en)2016-11-212018-09-25Institute Of Geology And Geophysics, Chinese Academy Of SciencesAzimuthally acoustic while drilling signal receiving transducer encapsulating apparatus
US10202841B2 (en)2016-08-292019-02-12Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit tool attitude measurement while drilling apparatus and method
US10282111B2 (en)2016-07-292019-05-07Western Digital Technologies, Inc.Adaptive wear levelling
US10317204B2 (en)2016-08-312019-06-11Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit dynamic well deviation angle measurement method and apparatus
US10338817B2 (en)2014-12-302019-07-02Sandisk Technologies LlcSystems and methods for storage recovery
US10428646B2 (en)2016-08-312019-10-01Institute Of Geology And Geophysics, Chinese Academy Of SciencesApparatus for downhole near-bit wireless transmission
US10578754B2 (en)2017-01-192020-03-03Institute Of Geology And Geophysics, Chinese Academy Of SciencesSinusoidal excitation method and apparatus for multi-pole acoustic logging while drilling
US10662764B2 (en)2016-08-312020-05-26Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit constant-power wireless short-distance transmission method and apparatus
US10741254B2 (en)*2018-10-172020-08-11SK Hynix Inc.Memory system and operating method thereof
US11099744B2 (en)2016-09-142021-08-24Ant Financial (Hang Zhou) Network Technology Co., Ltd.Method and device for writing stored data into storage medium based on flash memory

Families Citing this family (27)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
EP1702338B1 (en)*2003-12-302009-02-18SanDisk CorporationRobust data duplication and improved update method in a multibit non-volatile memory
US7383375B2 (en)2003-12-302008-06-03Sandisk CorporationData run programming
US7139864B2 (en)2003-12-302006-11-21Sandisk CorporationNon-volatile memory and method with block management system
US7433993B2 (en)2003-12-302008-10-07San Disk CorportionAdaptive metablocks
US7441067B2 (en)2004-11-152008-10-21Sandisk CorporationCyclic flash memory wear leveling
US7315917B2 (en)2005-01-202008-01-01Sandisk CorporationScheduling of housekeeping operations in flash memory systems
CN100533409C (en)*2005-07-292009-08-26松下电器产业株式会社Memory controller, nonvolatile memory device, nonvolatile memory system, and nonvolatile memory address management method
US7631162B2 (en)2005-10-272009-12-08Sandisck CorporationNon-volatile memory with adaptive handling of data writes
US7509471B2 (en)2005-10-272009-03-24Sandisk CorporationMethods for adaptively handling data writes in non-volatile memories
JP4227149B2 (en)*2006-04-192009-02-18三菱電機株式会社 Information storage method for electronic control unit
KR100791325B1 (en)*2006-10-272008-01-03삼성전자주식회사 Apparatus and method for managing nonvolatile memory
CN101256534B (en)*2007-03-012010-10-06创惟科技股份有限公司High-efficiency static average erasing method for flash memory
CN101409108B (en)*2007-10-092011-04-13群联电子股份有限公司 Wear Averaging Method and Controller Using It
TWI362044B (en)2007-11-092012-04-11Transcend Information IncStorage apparatus and method for accessing data and for managing memory block
JP4461170B2 (en)2007-12-282010-05-12株式会社東芝 Memory system
CN101419842B (en)*2008-11-072012-04-04成都市华为赛门铁克科技有限公司Loss equalizing method, apparatus and system for hard disc
US8244960B2 (en)2009-01-052012-08-14Sandisk Technologies Inc.Non-volatile memory and method with write cache partition management methods
US8094500B2 (en)2009-01-052012-01-10Sandisk Technologies Inc.Non-volatile memory and method with write cache partitioning
US8700840B2 (en)2009-01-052014-04-15SanDisk Technologies, Inc.Nonvolatile memory with write cache having flush/eviction methods
CN101740110B (en)*2009-12-172013-06-12中兴通讯股份有限公司Method and device for erasure balance of Nand Flash
KR20120096212A (en)*2011-02-222012-08-30삼성전자주식회사Non-volatile memory device, memory controller, and methods thereof
US8750045B2 (en)2012-07-272014-06-10Sandisk Technologies Inc.Experience count dependent program algorithm for flash memory
TWI515736B (en)*2013-07-252016-01-01慧榮科技股份有限公司Data storage device and flash memory control method
US9466377B2 (en)*2014-02-262016-10-11Infineon Technologies AgMethod and device for processing an erase counter
US10114562B2 (en)2014-09-162018-10-30Sandisk Technologies LlcAdaptive block allocation in nonvolatile memory
US9817593B1 (en)2016-07-112017-11-14Sandisk Technologies LlcBlock management in non-volatile memory system with non-blocking control sync system
US11080205B2 (en)2019-08-292021-08-03Micron Technology, Inc.Classifying access frequency of a memory sub-system component

Citations (34)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
JPS62283497A (en)1986-05-311987-12-09Canon Inc Memory write control method
JPS62283496A (en)1986-05-311987-12-09Canon Inc Programmable read-only memory write count management method
US5222109A (en)1990-12-281993-06-22Ibm CorporationEndurance management for solid state files
US5297148A (en)1989-04-131994-03-22Sundisk CorporationFlash eeprom system
EP0589597A2 (en)1992-09-221994-03-30International Business Machines CorporationFlash non-volatile memory
US5388083A (en)1993-03-261995-02-07Cirrus Logic, Inc.Flash memory mass storage architecture
US5438573A (en)1991-09-131995-08-01Sundisk CorporationFlash EEPROM array data and header file structure
US5485595A (en)1993-03-261996-01-16Cirrus Logic, Inc.Flash memory mass storage architecture incorporating wear leveling technique without using cam cells
US5568423A (en)*1995-04-141996-10-22Unisys CorporationFlash memory wear leveling system providing immediate direct access to microprocessor
US5568439A (en)1988-06-081996-10-22Harari; EliyahouFlash EEPROM system which maintains individual memory block cycle counts
US5598370A (en)1993-02-241997-01-28International Business Machines CorporationNonvolatile memory with cluster-erase flash capability and solid state file apparatus using the same
US5737742A (en)1994-06-291998-04-07Hitachi, Ltd.Memory system using flash memory and method of controlling the memory system
US5832493A (en)1997-04-241998-11-03Trimble Navigation LimitedFlash file management system
US5835935A (en)1995-09-131998-11-10Lexar Media, Inc.Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory
US5845313A (en)1995-07-311998-12-01LexarDirect logical block addressing flash memory mass storage architecture
US5860082A (en)1996-03-281999-01-12Datalight, Inc.Method and apparatus for allocating storage in a flash memory
US5907856A (en)1995-07-311999-05-25Lexar Media, Inc.Moving sectors within a block of information in a flash memory mass storage architecture
US5956473A (en)1996-11-251999-09-21Macronix International Co., Ltd.Method and system for managing a flash memory mass storage system
US5954828A (en)1995-01-051999-09-21Macronix International Co., Ltd.Non-volatile memory device for fault tolerant data
US5963473A (en)1996-05-231999-10-05Micron Technology, Inc.Flash memory system and method for monitoring the disturb effect on memory cell blocks due to high voltage conditions of other memory cell blocks
US6009496A (en)1997-10-301999-12-28Winbond Electronics Corp.Microcontroller with programmable embedded flash memory
US6016275A (en)1998-03-132000-01-18Lg Semicon Co., Ltd.Flash memory wear leveling system and method
WO2000014641A1 (en)1998-09-042000-03-16Mueller OttoAccess control for a memory having a limited erasure frequency
US6081447A (en)1991-09-132000-06-27Western Digital CorporationWear leveling techniques for flash EEPROM systems
US6125435A (en)1995-09-132000-09-26Lexar Media, Inc.Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory
US6226759B1 (en)1998-09-282001-05-01International Business Machines CorporationMethod and apparatus for immediate data backup by duplicating pointers and freezing pointer/data counterparts
US6260156B1 (en)1998-12-042001-07-10Datalight, Inc.Method and system for managing bad areas in flash memory
US6282605B1 (en)1999-04-262001-08-28Moore Computer Consultants, Inc.File system for non-volatile computer memory
US6381176B1 (en)2000-10-112002-04-30Samsung Electronics Co., Ltd.Method of driving remapping in flash memory and flash memory architecture suitable therefor
US6426893B1 (en)2000-02-172002-07-30Sandisk CorporationFlash eeprom system with simultaneous multiple data sector programming and storage of physical block characteristics in other designated blocks
US6604168B2 (en)1995-09-282003-08-05Canon Kabushiki KaishaFlash eeprom management using ratio of used to unused sectors
US6683817B2 (en)*2002-02-212004-01-27Qualcomm, IncorporatedDirect memory swapping between NAND flash and SRAM with error correction coding
US6732221B2 (en)2001-06-012004-05-04M-Systems Flash Disk Pioneers LtdWear leveling of static areas in flash memory
US6741486B2 (en)*2001-02-212004-05-25Kabushiki Kaisha ToshibaSemiconductor memory device and memory system

Patent Citations (41)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
JPS62283496A (en)1986-05-311987-12-09Canon Inc Programmable read-only memory write count management method
JPS62283497A (en)1986-05-311987-12-09Canon Inc Memory write control method
US5568439A (en)1988-06-081996-10-22Harari; EliyahouFlash EEPROM system which maintains individual memory block cycle counts
US5297148A (en)1989-04-131994-03-22Sundisk CorporationFlash eeprom system
US6523132B1 (en)1989-04-132003-02-18Sandisk CorporationFlash EEprom system
US5222109A (en)1990-12-281993-06-22Ibm CorporationEndurance management for solid state files
US6230233B1 (en)1991-09-132001-05-08Sandisk CorporationWear leveling techniques for flash EEPROM systems
US6081447A (en)1991-09-132000-06-27Western Digital CorporationWear leveling techniques for flash EEPROM systems
US5438573A (en)1991-09-131995-08-01Sundisk CorporationFlash EEPROM array data and header file structure
US5406529A (en)1992-09-221995-04-11International Business Machines CorporationFlash non-volatile memory
EP0589597A2 (en)1992-09-221994-03-30International Business Machines CorporationFlash non-volatile memory
US5598370A (en)1993-02-241997-01-28International Business Machines CorporationNonvolatile memory with cluster-erase flash capability and solid state file apparatus using the same
US5485595A (en)1993-03-261996-01-16Cirrus Logic, Inc.Flash memory mass storage architecture incorporating wear leveling technique without using cam cells
US5388083A (en)1993-03-261995-02-07Cirrus Logic, Inc.Flash memory mass storage architecture
US5930193A (en)*1994-06-291999-07-27Hitachi, Ltd.Memory system using a flash memory and method of controlling the memory system
US5737742A (en)1994-06-291998-04-07Hitachi, Ltd.Memory system using flash memory and method of controlling the memory system
US5954828A (en)1995-01-051999-09-21Macronix International Co., Ltd.Non-volatile memory device for fault tolerant data
US5568423A (en)*1995-04-141996-10-22Unisys CorporationFlash memory wear leveling system providing immediate direct access to microprocessor
US5907856A (en)1995-07-311999-05-25Lexar Media, Inc.Moving sectors within a block of information in a flash memory mass storage architecture
US5924113A (en)1995-07-311999-07-13Lexar Media, Inc.Direct logical block addressing flash memory mass storage architecture
US5845313A (en)1995-07-311998-12-01LexarDirect logical block addressing flash memory mass storage architecture
US6115785A (en)1995-07-312000-09-05Lexar Media, Inc.Direct logical block addressing flash memory mass storage architecture
US5835935A (en)1995-09-131998-11-10Lexar Media, Inc.Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory
US6125435A (en)1995-09-132000-09-26Lexar Media, Inc.Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory
US6604168B2 (en)1995-09-282003-08-05Canon Kabushiki KaishaFlash eeprom management using ratio of used to unused sectors
US5860082A (en)1996-03-281999-01-12Datalight, Inc.Method and apparatus for allocating storage in a flash memory
US5963473A (en)1996-05-231999-10-05Micron Technology, Inc.Flash memory system and method for monitoring the disturb effect on memory cell blocks due to high voltage conditions of other memory cell blocks
US5956473A (en)1996-11-251999-09-21Macronix International Co., Ltd.Method and system for managing a flash memory mass storage system
US5832493A (en)1997-04-241998-11-03Trimble Navigation LimitedFlash file management system
US6009496A (en)1997-10-301999-12-28Winbond Electronics Corp.Microcontroller with programmable embedded flash memory
US6016275A (en)1998-03-132000-01-18Lg Semicon Co., Ltd.Flash memory wear leveling system and method
WO2000014641A1 (en)1998-09-042000-03-16Mueller OttoAccess control for a memory having a limited erasure frequency
US6694402B1 (en)1998-09-042004-02-17Hyperstone AgAccess control for a memory having a limited erasure frequency
US6226759B1 (en)1998-09-282001-05-01International Business Machines CorporationMethod and apparatus for immediate data backup by duplicating pointers and freezing pointer/data counterparts
US6260156B1 (en)1998-12-042001-07-10Datalight, Inc.Method and system for managing bad areas in flash memory
US6282605B1 (en)1999-04-262001-08-28Moore Computer Consultants, Inc.File system for non-volatile computer memory
US6426893B1 (en)2000-02-172002-07-30Sandisk CorporationFlash eeprom system with simultaneous multiple data sector programming and storage of physical block characteristics in other designated blocks
US6381176B1 (en)2000-10-112002-04-30Samsung Electronics Co., Ltd.Method of driving remapping in flash memory and flash memory architecture suitable therefor
US6741486B2 (en)*2001-02-212004-05-25Kabushiki Kaisha ToshibaSemiconductor memory device and memory system
US6732221B2 (en)2001-06-012004-05-04M-Systems Flash Disk Pioneers LtdWear leveling of static areas in flash memory
US6683817B2 (en)*2002-02-212004-01-27Qualcomm, IncorporatedDirect memory swapping between NAND flash and SRAM with error correction coding

Non-Patent Citations (4)

* Cited by examiner, † Cited by third party
Title
Chang, et al., "An Adaptive Striping Architecture for Flash Memory Storage Systems of Embedded Systems," 8th Real-Time and Embedded Tech. and Appl. Symp. (IEEE, Sep. 24, 2002).
Chiang, et al., "Managing Flash Memory in Personal Communication Devices", International Symposium on Consumer Electronics (IEEE, 1997), pp. 177-182.
Kim, Jesung et al., "A Space-Efficient Flash Translation Layer for Compactflash Systems", IEEE Transactions on Consumer Electronics, vol. 48, No. 2, May 2002.
Mei-Ling Chiang et al. "Managing Flash Memory in Personal Communication Devices", 1997, IEEE, pp. 177-182.*

Cited By (139)

* Cited by examiner, † Cited by third party
Publication numberPriority datePublication dateAssigneeTitle
US7552272B2 (en)2002-10-282009-06-23Sandisk CorporationAutomated wear leveling in non-volatile storage systems
US20070083698A1 (en)*2002-10-282007-04-12Gonzalez Carlos JAutomated Wear Leveling in Non-Volatile Storage Systems
US20070047305A1 (en)*2002-12-092007-03-01Conley Kevin MZone Boundary Adjustments for Defects in Non-Volatile Memories
US9665478B2 (en)*2002-12-092017-05-30Innovative Memory Systems, Inc.Zone boundary adjustments for defects in non-volatile memories
US20050108301A1 (en)*2003-11-142005-05-19Changjian LouMethod for balancing wear when writing data in a flash memory
US20060004951A1 (en)*2004-06-302006-01-05Rudelic John CMethod and apparatus to alter code in a memory
US20060069849A1 (en)*2004-09-302006-03-30Rudelic John CMethods and apparatus to update information in a memory
US20060069850A1 (en)*2004-09-302006-03-30Rudelic John CMethods and apparatus to perform a reclaim operation in a nonvolatile memory
US20060149891A1 (en)*2004-12-302006-07-06Rudelic John CRelocated reclaim block
US20060256623A1 (en)*2005-05-122006-11-16Micron Technology, Inc.Partial string erase scheme in a flash memory device
US8291295B2 (en)2005-09-262012-10-16Sandisk Il Ltd.NAND flash memory controller exporting a NAND interface
US7886212B2 (en)*2005-09-262011-02-08Sandisk Il Ltd.NAND flash memory controller exporting a NAND interface
US20100049909A1 (en)*2005-09-262010-02-25Menahem LasserNAND Flash Memory Controller Exporting a NAND Interface
US20070079054A1 (en)*2005-09-302007-04-05Rudelic John CMethod and apparatus for optimizing flash device erase distribution
US7426605B2 (en)*2005-09-302008-09-16Rudelic John CMethod and apparatus for optimizing flash device erase distribution
US20070198902A1 (en)*2006-01-202007-08-23Kabushiki Kaisha ToshibaSemiconductor memory device
US7836377B2 (en)2006-01-202010-11-16Kabushiki Kaisha ToshibaSemiconductor memory device
US7941733B2 (en)2006-02-202011-05-10Kabushiki Kaisha ToshibaSemiconductor memory device
US20110185261A1 (en)*2006-02-202011-07-28Kabushiki Kaisha ToshibaSemiconductor memory device
US8201055B2 (en)2006-02-202012-06-12Kabushiki Kaisha ToshibaSemiconductor memory device
US20070198626A1 (en)*2006-02-202007-08-23Kabushiki Kaisha ToshibaSemiconductor memory device
US7890843B2 (en)2006-02-272011-02-15Kabushiki Kaisha ToshibaSemiconductor memory device
US20070220400A1 (en)*2006-02-272007-09-20Kabushiki Kaisha ToshibaSemiconductor memory device
US20070266291A1 (en)*2006-05-152007-11-15Kabushiki Kaisha ToshibaSemiconductor memory device
US7809900B2 (en)2006-11-242010-10-05Sandforce, Inc.System, method, and computer program product for delaying an operation that reduces a lifetime of memory
US20080126891A1 (en)*2006-11-242008-05-29Radoslav DanilakMemory lifetime gauging system, method and computer program product
US20080126724A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for reducing memory write operations using difference information
US20080126685A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for reducing memory write operations using an instruction set
US20080126719A1 (en)*2006-11-242008-05-29Radoslav DanilakSystem, method, and computer program product for delaying an operation that reduces a lifetime of memory
US8402184B2 (en)2006-11-242013-03-19Lsi CorporationTechniques for reducing memory write operations using coalescing memory buffers and difference information
US20110167199A1 (en)*2006-11-242011-07-07Sandforce Inc.Techniques for prolonging a lifetime of memory by controlling operations that affect the lifetime of the memory
US7904764B2 (en)2006-11-242011-03-08Sandforce, Inc.Memory lifetime gauging system, method and computer program product
US8230183B2 (en)2006-11-242012-07-24Lsi CorporationTechniques for prolonging a lifetime of memory by controlling operations that affect the lifetime of the memory
US7904619B2 (en)2006-11-242011-03-08Sandforce, Inc.System, method, and computer program product for reducing memory write operations using difference information
US20110125956A1 (en)*2006-11-242011-05-26Sandforce Inc.Techniques for multi-memory device lifetime management
US7747813B2 (en)2006-11-242010-06-29Sandforce, Inc.Multi-memory device system and method for managing a lifetime thereof
US8230164B2 (en)2006-11-242012-07-24Lsi CorporationTechniques for multi-memory device lifetime management
US20080126720A1 (en)*2006-11-242008-05-29Radoslav DanilakMulti-memory device system and method for managing a lifetime thereof
US7904672B2 (en)2006-12-082011-03-08Sandforce, Inc.System and method for providing data redundancy after reducing memory writes
US20080141054A1 (en)*2006-12-082008-06-12Radoslav DanilakSystem, method, and computer program product for providing data redundancy in a plurality of storage devices
US20080141055A1 (en)*2006-12-082008-06-12Radoslav DanilakSystem and method for providing data redundancy after reducing memory writes
US8504783B2 (en)2006-12-082013-08-06Lsi CorporationTechniques for providing data redundancy after reducing memory writes
US8090980B2 (en)2006-12-082012-01-03Sandforce, Inc.System, method, and computer program product for providing data redundancy in a plurality of storage devices
US20080147998A1 (en)*2006-12-182008-06-19Samsung Electronics Co., Ltd.Method and apparatus for detecting static data area, wear-leveling, and merging data units in nonvolatile data storage device
US8028121B2 (en)*2006-12-182011-09-27Samsung Electronics Co., Ltd.Method and apparatus for detecting static data area, wear-leveling, and merging data units in nonvolatile data storage device
WO2008078844A1 (en)*2006-12-222008-07-03Seoul National University Industry FoundationMethod and apparatus for mapping flash memory
US20080231810A1 (en)*2007-03-192008-09-25Catania Louis JMethod of fitting contact lenses
US7689762B2 (en)2007-05-032010-03-30Atmel CorporationStorage device wear leveling
US20080276035A1 (en)*2007-05-032008-11-06Atmel CorporationWear Leveling
US20080294814A1 (en)*2007-05-242008-11-27Sergey Anatolievich GorobetsFlash Memory System with Management of Housekeeping Operations
US20080294813A1 (en)*2007-05-242008-11-27Sergey Anatolievich GorobetsManaging Housekeeping Operations in Flash Memory
US20100023672A1 (en)*2007-11-132010-01-28Sergey Anatolievich GorobetsMethod And System For Virtual Fast Access Non-Volatile RAM
US8296498B2 (en)2007-11-132012-10-23Sandisk Technologies Inc.Method and system for virtual fast access non-volatile RAM
US8339881B2 (en)2007-11-192012-12-25Lsi CorporationTechniques for increasing a lifetime of blocks of memory
US20090132778A1 (en)*2007-11-192009-05-21Radoslav DanilakSystem, method and a computer program product for writing data to different storage devices based on write frequency
US7849275B2 (en)2007-11-192010-12-07Sandforce, Inc.System, method and a computer program product for writing data to different storage devices based on write frequency
US20090129163A1 (en)*2007-11-192009-05-21Radoslav DanilakSystem, method, and computer program product for increasing a lifetime of a plurality of blocks of memory
US7903486B2 (en)2007-11-192011-03-08Sandforce, Inc.System, method, and computer program product for increasing a lifetime of a plurality of blocks of memory
US8230184B2 (en)2007-11-192012-07-24Lsi CorporationTechniques for writing data to different portions of storage devices based on write frequency
US10318181B2 (en)2007-11-282019-06-11Seagate Technology LlcSystem, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
US9183133B2 (en)2007-11-282015-11-10Seagate Technology LlcSystem, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
US9645750B2 (en)2007-11-282017-05-09Seagate Technology LlcSystem, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
US20090138671A1 (en)*2007-11-282009-05-28Radoslav DanilakSystem, method, and computer program product for increasing spare space in memory to extend a lifetime of the memory
US8619493B2 (en)2008-02-042013-12-31Mosaid Technologies IncorporatedFlexible memory operations in NAND flash devices
US20090196102A1 (en)*2008-02-042009-08-06Mosaid Technologies IncorporatedFlexible memory operations in nand flash devices
US20090196103A1 (en)*2008-02-042009-08-06Mosaid Technologies IncorporatedNon-volatile memory device having configurable page size
US8120990B2 (en)2008-02-042012-02-21Mosaid Technologies IncorporatedFlexible memory operations in NAND flash devices
US8675408B2 (en)2008-02-042014-03-18Mosaid Technologies IncorporatedNon-volatile memory device having configurable page size
US8068365B2 (en)2008-02-042011-11-29Mosaid Technologies IncorporatedNon-volatile memory device having configurable page size
US8379450B2 (en)2008-02-042013-02-19Mosaid Technologies IncorporatedNon-volatile memory device having configurable page size
US20100017566A1 (en)*2008-07-152010-01-21Radoslav DanilakSystem, method, and computer program product for interfacing computing device hardware of a computing device and an operating system utilizing a virtualization layer
US20100017588A1 (en)*2008-07-152010-01-21Radoslav DanilakSystem, method, and computer program product for providing an extended capability to a system
US20100064093A1 (en)*2008-09-092010-03-11Radoslav DanilakSystem, method, and computer program product for converting data in a binary representation to a non-power of two representation
US20100146236A1 (en)*2008-12-082010-06-10Radoslav DanilakSystem, method, and computer program product for rendering at least a portion of data useless in immediate response to a delete command
US8300463B2 (en)*2009-03-252012-10-30Samsung Electronics Co., Ltd.Nonvolatile memory device and related programming method
US20100246266A1 (en)*2009-03-252010-09-30Samsung Electronics Co., Ltd.Nonvolatile memory device and related programming method
US8446766B2 (en)2009-03-252013-05-21Samsung Electronics Co., Ltd.Nonvolatile memory device and related programming method
US8090905B2 (en)2009-03-272012-01-03Sandforce, Inc.System, method, and computer program product for converting logical block address de-allocation information in a first format to a second format
US20100250830A1 (en)*2009-03-272010-09-30Ross John StenfortSystem, method, and computer program product for hardening data stored on a solid state disk
US20100251009A1 (en)*2009-03-272010-09-30Ross John StenfortSystem, method, and computer program product for converting logical block address de-allocation information in a first format to a second format
US8671259B2 (en)2009-03-272014-03-11Lsi CorporationStorage system data hardening
US8230159B2 (en)2009-03-272012-07-24Lsi CorporationSystem, method, and computer program product for sending logical block address de-allocation status information
US8510532B2 (en)2009-04-202013-08-13Imation Corp.Logical-to-physical address translation for a removable data storage device
US8725985B2 (en)2009-04-202014-05-13Imation Corp.Logical-to-physical address translation for a removable data storage device
US8176295B2 (en)2009-04-202012-05-08Imation Corp.Logical-to-physical address translation for a removable data storage device
US8065469B2 (en)*2009-04-202011-11-22Imation Corp.Static wear leveling
US9520992B2 (en)2009-04-202016-12-13Kingston Digital, Inc.Logical-to-physical address translation for a removable data storage device
US20100268865A1 (en)*2009-04-202010-10-21Arunprasad Ramiya MothilalStatic Wear Leveling
US8407408B2 (en)2009-04-202013-03-26Imation Corp.Static wear leveling
US9286243B2 (en)2009-04-202016-03-15Imation Corp.Logical-to-physical address translation for a removable data storage device
US20100268864A1 (en)*2009-04-202010-10-21Arunprasad Ramiya MothilalLogical-to-Physical Address Translation for a Removable Data Storage Device
US20110004718A1 (en)*2009-07-022011-01-06Ross John StenfortSystem, method, and computer program product for ordering a plurality of write commands associated with a storage device
US8930606B2 (en)2009-07-022015-01-06Lsi CorporationOrdering a plurality of write commands associated with a storage device
US20110004710A1 (en)*2009-07-062011-01-06Ross John StenfortSystem, method, and computer program product for interfacing one or more storage devices with a plurality of bridge chips
US9792074B2 (en)2009-07-062017-10-17Seagate Technology LlcSystem, method, and computer program product for interfacing one or more storage devices with a plurality of bridge chips
US8140712B2 (en)2009-07-172012-03-20Sandforce, Inc.System, method, and computer program product for inserting a gap in information sent from a drive to a host device
US20110016233A1 (en)*2009-07-172011-01-20Ross John StenfortSystem, method, and computer program product for inserting a gap in information sent from a drive to a host device
US8516166B2 (en)2009-07-202013-08-20Lsi CorporationSystem, method, and computer program product for reducing a rate of data transfer to at least a portion of memory
US20110016239A1 (en)*2009-07-202011-01-20Ross John StenfortSystem, method, and computer program product for reducing a rate of data transfer to at least a portion of memory
US8402242B2 (en)2009-07-292013-03-19International Business Machines CorporationWrite-erase endurance lifetime of memory storage devices
US20110029715A1 (en)*2009-07-292011-02-03International Business Machines CorporationWrite-erase endurance lifetime of memory storage devices
TWI489468B (en)*2009-07-292015-06-21Sk Hynix IncWrite-erase endurance lifetime of memory storage devices
US9776673B2 (en)2009-07-292017-10-03SK Hynix Inc.Write-erase endurance lifetime of memory storage devices
US20110041005A1 (en)*2009-08-112011-02-17Selinger Robert DController and Method for Providing Read Status and Spare Block Management Information in a Flash Memory System
US20110083047A1 (en)*2009-10-052011-04-07Ross John StenfortSystem, method, and computer program product for sending failure information from a serial ata (sata) solid state drive (ssd) to a host device
US8108737B2 (en)2009-10-052012-01-31Sandforce, Inc.System, method, and computer program product for sending failure information from a serial ATA (SATA) solid state drive (SSD) to a host device
US8612804B1 (en)2010-09-302013-12-17Western Digital Technologies, Inc.System and method for improving wear-leveling performance in solid-state memory
US9405670B2 (en)*2011-06-092016-08-02Tsinghua UniversityWear leveling method and apparatus
US20120317345A1 (en)*2011-06-092012-12-13Tsinghua UniversityWear leveling method and apparatus
US8898373B1 (en)2011-06-292014-11-25Western Digital Technologies, Inc.System and method for improving wear-leveling performance in solid-state memory
US20160011782A1 (en)*2013-02-272016-01-14Hitachi, Ltd.Semiconductor storage
US10635326B2 (en)2014-09-302020-04-28Sandisk Technologies LlcMethod and apparatus for wear-levelling non-volatile memory
US9875039B2 (en)2014-09-302018-01-23Sandisk Technologies LlcMethod and apparatus for wear-leveling non-volatile memory
US20160139826A1 (en)*2014-11-132016-05-19Micron Technology, Inc.Memory Wear Leveling
US9830087B2 (en)*2014-11-132017-11-28Micron Technology, Inc.Memory wear leveling
US20180067661A1 (en)*2014-11-132018-03-08Micron Technology, Inc.Memory wear leveling
US11640333B2 (en)2014-12-042023-05-02Western Digital Technologies, Inc.Systems and methods for allocating blocks of memory to multiple zones associated with corresponding error correction mechanisms
US11150984B2 (en)2014-12-042021-10-19Western Digital Technologies, Inc.Systems and methods for multi-zone data tiering for endurance extension in solid state drives
US10691531B2 (en)*2014-12-042020-06-23Western Digital Technologies, Inc.Systems and methods for multi-zone data tiering for endurance extension in solid state drives
US20160162354A1 (en)*2014-12-042016-06-09HGST Netherlands B.V.Systems and methods for multi-zone data tiering for endurance extension in solid state drives
US10338817B2 (en)2014-12-302019-07-02Sandisk Technologies LlcSystems and methods for storage recovery
US20170139826A1 (en)*2015-11-172017-05-18Kabushiki Kaisha ToshibaMemory system, memory control device, and memory control method
US9971682B2 (en)*2016-04-152018-05-15Nxp Usa, Inc.Wear-leveling system and method for reducing stress on memory device using erase counters
US20170300408A1 (en)*2016-04-152017-10-19Nxp Usa, Inc.System and method for reducing stress on memory device
US10282111B2 (en)2016-07-292019-05-07Western Digital Technologies, Inc.Adaptive wear levelling
US10202841B2 (en)2016-08-292019-02-12Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit tool attitude measurement while drilling apparatus and method
US10662764B2 (en)2016-08-312020-05-26Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit constant-power wireless short-distance transmission method and apparatus
US10317204B2 (en)2016-08-312019-06-11Institute Of Geology And Geophysics, Chinese Academy Of SciencesNear-bit dynamic well deviation angle measurement method and apparatus
US10428646B2 (en)2016-08-312019-10-01Institute Of Geology And Geophysics, Chinese Academy Of SciencesApparatus for downhole near-bit wireless transmission
US9970288B2 (en)2016-08-312018-05-15Institute of geology and geophysics, Chinese Academy of ScienceReceiving apparatus for downhole near-bit wireless transmission
US11099744B2 (en)2016-09-142021-08-24Ant Financial (Hang Zhou) Network Technology Co., Ltd.Method and device for writing stored data into storage medium based on flash memory
US11287984B2 (en)2016-09-142022-03-29Beijing Oceanbase Technology Co., Ltd.Method and device for writing stored data into storage medium based on flash memory
CN106527969A (en)*2016-09-212017-03-22中国科学院地质与地球物理研究所NandFlash memory read-write method capable of guaranteeing service life balance
US10120795B2 (en)2016-09-212018-11-06Institute Of Geology And Geophysics, Chinese Academy Of SciencesWear-leveling nandflash memory reading/writing method
US10082021B2 (en)2016-11-212018-09-25Institute Of Geology And Geophysics, Chinese Academy Of SciencesAzimuthally acoustic while drilling signal receiving transducer encapsulating apparatus
US10030504B2 (en)2016-11-212018-07-24Institute Of Geology And Geophysics, Chinese Academy Of SciencesReceiving apparatus suitable for azimuthally acoustic logging while drilling
US10578754B2 (en)2017-01-192020-03-03Institute Of Geology And Geophysics, Chinese Academy Of SciencesSinusoidal excitation method and apparatus for multi-pole acoustic logging while drilling
US10025003B1 (en)2017-01-192018-07-17Institute Of Geology And Geophysics, Chinese Academy Of SciencesCalibration method under near-bit wireless short-transmission ground envrionment based on electric field theory
US10741254B2 (en)*2018-10-172020-08-11SK Hynix Inc.Memory system and operating method thereof

Also Published As

Publication numberPublication date
TWI249100B (en)2006-02-11
KR20050084879A (en)2005-08-29
WO2004040459A1 (en)2004-05-13
AU2003270529A1 (en)2004-05-25
CN1698036A (en)2005-11-16
EP1559017A1 (en)2005-08-03
TW200428213A (en)2004-12-16
JP2006504199A (en)2006-02-02

Similar Documents

PublicationPublication DateTitle
US7096313B1 (en)Tracking the least frequently erased blocks in non-volatile memory systems
US6973531B1 (en)Tracking the most frequently erased blocks in non-volatile memory systems
US6985992B1 (en)Wear-leveling in non-volatile storage systems
US7287118B2 (en)Maintaining an average erase count in a non-volatile storage system
US6831865B2 (en)Maintaining erase counts in non-volatile storage systems
US7103732B1 (en)Method and apparatus for managing an erase count block

Legal Events

DateCodeTitleDescription
ASAssignment

Owner name:SANDISK CORPORATION, CALIFORNIA

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:CHANG, ROBERT C.;QAWAMI, BAHMAN;SABET-SHARGHI, FARSHID;REEL/FRAME:013435/0501;SIGNING DATES FROM 20020610 TO 20020611

STCFInformation on status: patent grant

Free format text:PATENTED CASE

FPAYFee payment

Year of fee payment:4

ASAssignment

Owner name:SANDISK TECHNOLOGIES INC., TEXAS

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SANDISK CORPORATION;REEL/FRAME:026334/0068

Effective date:20110404

ASAssignment

Owner name:INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC., D

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SANDISK TECHNOLOGIES, INC.;REEL/FRAME:030953/0416

Effective date:20130801

ASAssignment

Owner name:INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC., D

Free format text:CORRECTIVE ASSIGNMENT TO CORRECT THE ADDRESS OF THE ASSIGNOR IN THE ASSIGNMENT DOCUMENT PREVIOUSLY RECORDED ON REEL 030953 FRAME 0416. ASSIGNOR(S) HEREBY CONFIRMS THE ASSIGNMENT;ASSIGNOR:SANDISK TECHNOLOGIES, INC.;REEL/FRAME:030994/0046

Effective date:20130801

ASAssignment

Owner name:SANDISK CORPORATION, CALIFORNIA

Free format text:SECURITY AGREEMENT;ASSIGNOR:INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC;REEL/FRAME:031074/0651

Effective date:20130820

ASAssignment

Owner name:PS3 LUXCO SARL, LUXEMBOURG

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTELLIGENT INTELLECTUAL PROPERTY HOLDINGS LLC;REEL/FRAME:031723/0836

Effective date:20130821

ASAssignment

Owner name:PS2 LUXCO SARL, LUXEMBOURG

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:PS3 LUXCO SARL;REEL/FRAME:031734/0555

Effective date:20130821

ASAssignment

Owner name:LONGITUDE FLASH MEMORY SYSTEMS S.A.R.L., LUXEMBOUR

Free format text:CHANGE OF NAME;ASSIGNOR:PS2 LUXCO S.A.R.L.;REEL/FRAME:031814/0068

Effective date:20131112

FPAYFee payment

Year of fee payment:8

ASAssignment

Owner name:SANDISK TECHNOLOGIES, INC., TEXAS

Free format text:ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:LONGITUDE FLASH MEMORY SYSTEMS SARL;REEL/FRAME:038166/0445

Effective date:20160318

ASAssignment

Owner name:SANDISK TECHNOLOGIES LLC, TEXAS

Free format text:CHANGE OF NAME;ASSIGNOR:SANDISK TECHNOLOGIES INC;REEL/FRAME:038813/0004

Effective date:20160516

ASAssignment

Owner name:SANDISK CORPORATION, CALIFORNIA

Free format text:TERMINATION AND RELEASE OF SECURITY INTEREST IN PATENTS;ASSIGNORS:SANDISK CORPORATION;SANDISK TECHNOLOGIES, INC.;REEL/FRAME:038825/0137

Effective date:20160427

MAFPMaintenance fee payment

Free format text:PAYMENT OF MAINTENANCE FEE, 12TH YEAR, LARGE ENTITY (ORIGINAL EVENT CODE: M1553)

Year of fee payment:12


[8]ページ先頭

©2009-2025 Movatter.jp