US20090204750A1 - Direct logical block addressing flash memory mass storage architecture - Google Patents
Direct logical block addressing flash memory mass storage architecture Download PDFInfo
- Publication number
- US20090204750A1 US20090204750A1 US12/426,662 US42666209A US2009204750A1 US 20090204750 A1 US20090204750 A1 US 20090204750A1 US 42666209 A US42666209 A US 42666209A US 2009204750 A1 US2009204750 A1 US 2009204750A1
- Authority
- US
- United States
- Prior art keywords
- volatile memory
- memory location
- address
- location
- status
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/70—Masking faults in memories by using spares or by reconfiguring
- G11C29/76—Masking faults in memories by using spares or by reconfiguring using address translation or modifications
- G11C29/765—Masking faults in memories by using spares or by reconfiguring using address translation or modifications in solid state disks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/0223—User address space allocation, e.g. contiguous or non contiguous base addressing
- G06F12/023—Free address space management
- G06F12/0238—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory
- G06F12/0246—Memory management in non-volatile memory, e.g. resistive RAM or ferroelectric memory in block erasable memory, e.g. flash memory
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/061—Improving I/O performance
- G06F3/0613—Improving I/O performance in relation to throughput
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0602—Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
- G06F3/0614—Improving the reliability of storage systems
- G06F3/0616—Improving the reliability of storage systems in relation to life time, e.g. increasing Mean Time Between Failures [MTBF]
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0628—Interfaces specially adapted for storage systems making use of a particular technique
- G06F3/0638—Organizing or formatting or addressing of data
- G06F3/064—Management of blocks
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F3/00—Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
- G06F3/06—Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
- G06F3/0601—Interfaces specially adapted for storage systems
- G06F3/0668—Interfaces specially adapted for storage systems adopting a particular infrastructure
- G06F3/0671—In-line storage system
- G06F3/0673—Single storage device
- G06F3/0679—Non-volatile semiconductor memory device, e.g. flash memory, one time programmable memory [OTP]
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/08—Address circuits; Decoders; Word-line control circuits
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C16/00—Erasable programmable read-only memories
- G11C16/02—Erasable programmable read-only memories electrically programmable
- G11C16/06—Auxiliary circuits, e.g. for writing into memory
- G11C16/10—Programming or data input circuits
- G11C16/102—External programming circuits, e.g. EPROM programmers; In-circuit programming or reprogramming; EPROM emulators
-
- G—PHYSICS
- G11—INFORMATION STORAGE
- G11C—STATIC STORES
- G11C29/00—Checking stores for correct operation ; Subsequent repair; Testing stores during standby or offline operation
- G11C29/70—Masking faults in memories by using spares or by reconfiguring
- G11C29/78—Masking faults in memories by using spares or by reconfiguring using programmable devices
- G11C29/80—Masking faults in memories by using spares or by reconfiguring using programmable devices with improved layout
- G11C29/816—Masking faults in memories by using spares or by reconfiguring using programmable devices with improved layout for an application-specific layout
- G11C29/82—Masking faults in memories by using spares or by reconfiguring using programmable devices with improved layout for an application-specific layout for EEPROMs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F11/00—Error detection; Error correction; Monitoring
- G06F11/07—Responding to the occurrence of a fault, e.g. fault tolerance
- G06F11/08—Error detection or correction by redundancy in data representation, e.g. by using checking codes
- G06F11/10—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's
- G06F11/1008—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices
- G06F11/1068—Adding special bits or symbols to the coded information, e.g. parity check, casting out 9's or 11's in individual solid state devices in sector programmable memories, e.g. flash disk
Definitions
- This invention relates to the field of mass storage for computers. More particularly, this invention relates to an architecture for replacing a hard disk with a semiconductor nonvolatile memory and in particular flash memory.
- Solid state memory is an ideal choice for replacing a hard disk drive for mass storage because it can resolve the problems cited above.
- Potential solutions have been proposed for replacing a hard disk drive with a semiconductor memory.
- the memory must be nonvolatile and alterable.
- the inventors have determined that FLASH memory is preferred for such a replacement.
- FLASH memory is a transistor memory cell which is programmable through hot electron, source injection, or tunneling, and erasable through Fowler-Nordheim tunneling.
- the programming and erasing of such a memory cell requires current to pass through the dielectric surrounding a floating gate electrode. Because of this, such types of memory have a finite number of erase-write cycles. Eventually, the dielectric deteriorates.
- Manufacturers of FLASH cell devices specify the limit for the number of erase-write cycles between 100,000 and 1,000,000.
- One requirement for a semiconductor mass storage device to be successful is that its use in lieu of a rotating media hard disk mass storage device be transparent to the designer and the user of a system using such a device. In other words, the designer or user of a computer incorporating such a semiconductor mass storage device could simply remove the hard disk and replace it with a semiconductor mass storage device. All presently available commercial software should operate on a system employing such a semiconductor mass storage device without the necessity of any modification.
- SunDisk proposed an architecture for a semiconductor mass storage using FLASH memory at the Silicon Valley PC Design Conference on Jul. 9, 1991. That mass storage system included read-write block sizes of 512 Bytes to conform with commercial hard disk sector sizes.
- This process would have a major deterioration on overall system throughput.
- a host When a host writes a new data file to the storage media, it provides a logical block address to the peripheral storage device associated with this data file. The storage device then translates this given logical block address to an actual physical block address on the media and performs the write operation.
- the new data can be written over the previous old data with no modification to the media. Therefore, once the physical block address is calculated from the given logical block address by the controller, it will simply write the data file into that location.
- solid state storage if the location associated with the calculated, physical block address was previously programmed, before this block can be reprogrammed with the new data, it has to be erased.
- hard disk users typically store two types of information, one is rarely modified and another which is frequently changed.
- a commercial spread sheet or word processing software program stored on a user's system are rarely, if ever, changed.
- the spread sheet data files or word processing documents are frequently changed.
- different sectors of a hard disk typically have dramatically different usage in terms of the number of times the information stored thereon is changed. While this disparity has no impact on a hard disk because of its insensitivity to data changes, in a FLASH memory device, this variance can cause sections of the mass storage to wear out and be unusable significantly sooner than other sections of the mass storage.
- the inventors' previous solution discloses two primary algorithms and an associated hardware architecture for a semiconductor mass storage device.
- data file in this patent document refers to any computer file including commercial software, a user program, word processing software document, spread sheet file and the like.
- the first algorithm in the previous solution provides means for avoiding an erase operation when writing a modified data file back onto the mass storage device. Instead, no erase is performed and the modified data file is written onto an empty portion of the mass storage.
- the semiconductor mass storage architecture has blocks sized to conform with commercial hard disk sector sizes.
- the blocks are individually erasable.
- the semiconductor mass storage can be substituted for a rotating hard disk with no impact to the user, so that such a substitution will be transparent. Means are provided for avoiding the erase-before-write cycle each time information stored in the mass storage is changed.
- erase cycles are avoided by programming an altered data file into an empty block. This would ordinarily not be possible when using conventional mass storage because the central processor and commercial software available in conventional computer systems are not configured to track continually changing physical locations of data files.
- the previous solution includes a programmable map to maintain a correlation between the logical address and the physical address of the updated information files.
- All the flags, and the table correlating the logical block address to the physical block address are maintained within an array of CAM cells.
- the use of the CAM cells provides very rapid determination of the physical address desired within the mass storage, generally within one or two clock cycles.
- CAM cells require multiple transistors, typically six. Accordingly, an integrated circuit built for a particular size memory using CAM storage for the tables and flags will need to be significantly larger than a circuit using other means for just storing the memory.
- This additional previous solution invented by these same inventors is also for a nonvolatile memory storage device.
- the device is also configured to avoid having to perform an erase-before-write each time a data file is changed by keeping a correlation between logical block address and physical block address in a volatile space management RAM. Further, this invention avoids the overhead associated with CAM cell approaches which require additional circuitry.
- the device includes circuitry for performing the two primary algorithms and an associated hardware architecture for a semiconductor mass storage device.
- the CAM cell is avoided in this previous solution by using RAM cells.
- Reading is performed in this previous solution by providing the logical block address to the memory storage.
- the system sequentially compares the stored logical block addresses until it finds a match. That data file is then coupled to the digital system. Accordingly, the performance offered by this solution suffers because potentially all of the memory locations must be searched and compared to the desired logical block address before the physical location of the desired information can be determined.
- FIG. 1 shows a schematic block diagram of an architecture for a semiconductor mass storage according to the present invention.
- FIG. 2 shows an alternative embodiment to the physical block address 102 of the RAM storage of FIG. 1 .
- FIG. 3 shows a block diagram of a system incorporating the mass storage device of the present invention.
- FIGS. 4 through 8 show the status of several of the flags and information for achieving the advantages of the present invention.
- FIG. 9 shows a flow chart block diagram of the first algorithm according to the present invention.
- FIG. 1 shows an architecture for implementation of a solid state storage media according to the present invention.
- the storage media is for use with a host or other external digital system.
- the mass storage is partitioned into two portions, a volatile RAM array 100 and a nonvolatile array 104 .
- all of the nonvolatile memory storage is FLASH.
- the FLASH may be replaced by EEPROM.
- the RAM can be of any convenient type.
- the memory storage 104 is arranged into N blocks of data from zero through N ⁇ 1.
- Each of the blocks of data is M Bytes long.
- each data block is 512 Bytes long to correspond with a sector length in a commercially available hard disk drive plus the extra numbers of bytes to store the flags and logical block address information and the associated ECC.
- the memory 104 can contain as much memory storage as a user desires.
- An example of a mass storage device might include 100 M Byte of addressable storage.
- Each RAM location 102 is uniquely addressable by a controller using an appropriate one of the logical block addresses provided by the host system or the actual physical address of the nonvolatile media.
- the RAM location 102 contains the physical block address of the data associated with the logical block address and the flags associated with a physical block address on the nonvolatile media.
- the physical block address can be split into two fields as shown in FIG. 2 . These fields can be used for cluster addresses of a group of data blocks. The first such field 290 is used to select a cluster address and the second such field 292 can be used to select the start address of the logical block address associated with this cluster.
- a collection of information flags is also stored for each nonvolatile memory location 106 . These flags include an old/new flag 110 , a used/free flag 112 , a defect flag, 114 , and a single/sector flag 116 . Additionally, there is also a data store 122 .
- a controller determines the first available physical block for storing the data.
- the RAM location 102 corresponding to the logical block address selected by the host is written with the physical block address where the data is actually stored within the nonvolatile memory array in 104 ( FIG. 1 ).
- the document will be stored in the mass storage system.
- the host system will assign it a logical block address.
- the mass storage system of the present invention will select a physical address of an unused block or blocks in the mass storage for storing the document.
- the address of the physical block address will be stored into the RAM location 102 corresponding to the logical block address.
- the system of the present invention also sets the used/free flag 112 in 104 and 293 to indicate that this block location is used.
- One used/free flag 112 is provided for each entry of the nonvolatile array 104 .
- the system of the present invention provides means for locating a block having its used/free flag 112 in 100 unset (not programmed) which indicates that the associated block is erased.
- the system sets the used/free flag for the new block 112 of 106 and 293 of 100 and then stores the modified document in that new physical block location 106 in the nonvolatile array 104 .
- the address of the new physical block location is also stored into the RAM location 102 corresponding to the logical block address, thereby writing over the previous physical block location in 102 .
- the system sets the old/new flag 110 of the previous version of the document indicating that this is an old unneeded version of the document in 110 of 104 and 293 of 100 In this way, the system of the present invention avoids the overhead of an erase cycle which is required in the erase-before-write of conventional systems to store a modified version of a previous document.
- the logical block address with the active physical block address in the media is also stored as a shadow memory 108 in the nonvolatile array 104 . It will be understood the shadow information will be stored into the appropriate RAM locations 102 by the controller. During power up sequence, the RAM locations in 100 are appropriately updated from every physical locations in 104 , by reading the information 106 of 104 . The logical address 108 of 106 is used to address the RAM location of 100 to update the actual physical block address associated with the given logical block address.
- the flags 110 , 112 , 114 , and 116 are updated in 293 of 102 with the physical block address of 106 in 100 . It will be apparent to one of ordinary skill in the art that the flags can be stored in either the appropriate nonvolatile memory location 106 or in both the nonvolatile memory location and also in the RAM location 102 associated with the physical block address.
- the controller will first reads the Flags 110 , 112 , 114 , and 116 portion of the nonvolatile memory 104 and updates the flags portion 293 in the volatile memory 100 . Then it reads the logical block address 108 of every physical block address of the nonvolatile media 104 and by tracking the flags of the given physical block address in the volatile memory 100 , and the read logical block address of the physical block address in the nonvolatile memory 104 , it can update the most recent physical block address assigned to the read logical block address in the volatile memory 100 .
- FIG. 3 shows a block diagram of a system incorporating the mass storage device of the present invention.
- An external digital system 300 such as a host computer, personal computer and the like is coupled to the mass storage device 302 of the present invention.
- a logical block address is coupled via an address bus 306 to the volatile RAM array 100 and to a controller circuit 304 .
- Control signals are also coupled to the controller 304 via a control bus 308 .
- the volatile RAM array 100 is coupled via data paths 140 for providing the physical block address to the nonvolatile RAM array 104 .
- the controller 304 is coupled to control both the volatile RAM 100 , the nonvolatile array 104 , and for the generation of all flags.
- FIGS. 4 through 8 A simplified example, showing the operation of the write operation according to the present invention is shown in FIGS. 4 through 8 . Not all the information flags are shown to avoid obscuring these features of the invention in excessive detail.
- the data entries are shown using decimal numbers to further simplify the understanding of the invention. It will be apparent to one of ordinary skill in the art that in a preferred embodiment binary counting will be used.
- FIG. 4 shows an eleven entry mass storage device according to the present invention. There is no valid nor usable data stored in the mass storage device of FIG. 4 . Accordingly, all the physical block addresses are empty. The data stored in the nonvolatile mass storage location ‘ 6 ’ is filled and old. Additionally, location ‘ 9 ’ is defective and cannot be used.
- the host directs the mass storage device of the example to write data pursuant to the logical block address ‘ 3 ’ and then to ‘ 4 ’
- the mass storage device will first write the data associated with the logical block address ‘ 3 ’.
- the device determines which is the first unused location in the nonvolatile memory. In this example, the first empty location is location ‘ 0 ’. Accordingly, FIG. 5 shows that for the logical block address ‘ 3 ’, the corresponding physical block address ‘ 0 ’ is stored and the used flag is set in physical block address ‘ 0 ’. The next empty location is location ‘ 1 ’.
- FIG. 6 shows that for the logical block address ‘ 4 ’, the corresponding physical block address ‘ 1 ’ is stored and the used flag is set in physical block address ‘ 1 ’.
- FIG. 7 shows that the old flag in location ‘ 0 ’ is set to indicate that this data is no longer usable, the used flag is set in location ‘ 2 ’ and the physical block address in location ‘ 3 ’ is changed to ‘ 2 ’.
- FIG. 8 shows that the old flag in location ‘ 1 ’ is set to indicate that this data is no longer usable, the used flag is set in location ‘ 3 ’ and the physical block address in location ‘ 4 ’ is changed to ‘ 3 ’. (Recall that there is generally no relation between the physical block address and the data stored in the same location.)
- FIG. 9 shows algorithm 1 according to the present invention.
- the system of the present invention receives an instruction to program data into the mass storage (step 200 ), then the system attempts to locate a free block (step 202 ), i.e., a block having an unset (not programmed) used/free flag. If successful, the system sets the used/free flag for that block and programs the data into that block (step 206 ).
- the system If on the other hand, the system is unable to locate a block having an unset used/free flag, the system erases the flags (used/free and old/new) and data for all blocks having a set old/new flag and unset defect flag (step 204 ) and then searches for a block having an unset used/free flag (step 202 ). Such a block has just been formed by step 204 . The system then sets the used/flag for that block and programs the data file into that block (step 206 ).
- the system determines whether the data file supersedes a previous data file (step 208 ). If so, the system sets the old/new flag associated with the superseded block (step 210 ). If on the other hand, the data file to be stored is a newly created data file, the step of setting the old/new flag (step 210 ) is skipped because there is no superseded block. Lastly, the map for correlating the logical address 108 to the physical address 130 is updated (step 212 ).
- the programming of the flash memory follows the procedure commonly understood by those of ordinary skill in the art.
- the program impulses are appropriately applied to the bits to be programmed and then compared to the data being programmed to ensure that proper programming has occurred.
- a defect flag 114 (in FIG. 1 ) is set which prevent that block from being used again.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Human Computer Interaction (AREA)
- Techniques For Improving Reliability Of Storages (AREA)
- Read Only Memory (AREA)
Abstract
Description
- This application is a continuation of U.S. patent application Ser. No. 11/165,864, (allowed) filed on Jun. 24, 2005 and entitled: “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”, which is a continuation of U.S. Pat. No. 6,912,618, issued on Jun. 28, 2005 and entitled: “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”, which is a continuation of U.S. Pat. No. 6,230,234, issued on May 8, 2001 and entitled “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”, which is a continuation of U.S. Pat. No. 6,115,785, issued on Sep. 5, 2000 and entitled “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”, which is a continuation of prior U.S. Pat. No. 5,924,113 issued on Jul. 13, 1999, entitled “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”, which is a continuation of U.S. Pat. No. 5,845,313, issued on Dec. 1, 1998, entitled “DIRECT LOGICAL BLOCK ADDRESSING FLASH MEMORY MASS STORAGE ARCHITECTURE”.
- This invention relates to the field of mass storage for computers. More particularly, this invention relates to an architecture for replacing a hard disk with a semiconductor nonvolatile memory and in particular flash memory.
- Computers conventionally use rotating magnetic media for mass storage of documents, data, programs and information. Though widely used and commonly accepted, such hard disk drives suffer from a variety of deficiencies. Because of the rotation of the disk, there is an inherent latency in extracting information from a hard disk drive.
- Other problems are especially dramatic in portable computers. In particular, hard disks are unable to withstand many of the kinds of physical shock that a portable computer will likely sustain. Further, the motor for rotating the disk consumes significant amounts of power decreasing the battery life for portable computers.
- Solid state memory is an ideal choice for replacing a hard disk drive for mass storage because it can resolve the problems cited above. Potential solutions have been proposed for replacing a hard disk drive with a semiconductor memory. For such a system to be truly useful, the memory must be nonvolatile and alterable. The inventors have determined that FLASH memory is preferred for such a replacement.
- FLASH memory is a transistor memory cell which is programmable through hot electron, source injection, or tunneling, and erasable through Fowler-Nordheim tunneling. The programming and erasing of such a memory cell requires current to pass through the dielectric surrounding a floating gate electrode. Because of this, such types of memory have a finite number of erase-write cycles. Eventually, the dielectric deteriorates. Manufacturers of FLASH cell devices specify the limit for the number of erase-write cycles between 100,000 and 1,000,000.
- One requirement for a semiconductor mass storage device to be successful is that its use in lieu of a rotating media hard disk mass storage device be transparent to the designer and the user of a system using such a device. In other words, the designer or user of a computer incorporating such a semiconductor mass storage device could simply remove the hard disk and replace it with a semiconductor mass storage device. All presently available commercial software should operate on a system employing such a semiconductor mass storage device without the necessity of any modification.
- SunDisk proposed an architecture for a semiconductor mass storage using FLASH memory at the Silicon Valley PC Design Conference on Jul. 9, 1991. That mass storage system included read-write block sizes of 512 Bytes to conform with commercial hard disk sector sizes.
- Earlier designs incorporated erase-before-write architectures. In this process, in order to update a file on the media, if the physical location on the media was previously programmed, it has to be erased before the new data can be reprogrammed.
- This process would have a major deterioration on overall system throughput. When a host writes a new data file to the storage media, it provides a logical block address to the peripheral storage device associated with this data file. The storage device then translates this given logical block address to an actual physical block address on the media and performs the write operation. In magnetic hard disk drives, the new data can be written over the previous old data with no modification to the media. Therefore, once the physical block address is calculated from the given logical block address by the controller, it will simply write the data file into that location. In solid state storage, if the location associated with the calculated, physical block address was previously programmed, before this block can be reprogrammed with the new data, it has to be erased. In one previous art, in erase-before-write architecture where the correlation between logical block address given by the host is one to one mapping with physical block address on the media. This method has many deficiencies. First, it introduces a delay in performance due to the erase operation before reprogramming the altered information. In solid state flash, erase is a very slow process.
- Secondly, hard disk users typically store two types of information, one is rarely modified and another which is frequently changed. For example, a commercial spread sheet or word processing software program stored on a user's system are rarely, if ever, changed. However, the spread sheet data files or word processing documents are frequently changed. Thus, different sectors of a hard disk typically have dramatically different usage in terms of the number of times the information stored thereon is changed. While this disparity has no impact on a hard disk because of its insensitivity to data changes, in a FLASH memory device, this variance can cause sections of the mass storage to wear out and be unusable significantly sooner than other sections of the mass storage.
- In another architecture, the inventors previously proposed a solution to store a table correlating the logical block address to the physical block address. The inventions relating to that solution are disclosed in U.S. Pat. No. 5,388,083, issued on Feb. 7, 1995. U.S. Pat. No. 5,479,638 issued on Dec. 26, 1995. Those applications are incorporated herein by reference.
- The inventors' previous solution discloses two primary algorithms and an associated hardware architecture for a semiconductor mass storage device. It will be understood that “data file” in this patent document refers to any computer file including commercial software, a user program, word processing software document, spread sheet file and the like. The first algorithm in the previous solution provides means for avoiding an erase operation when writing a modified data file back onto the mass storage device. Instead, no erase is performed and the modified data file is written onto an empty portion of the mass storage.
- The semiconductor mass storage architecture has blocks sized to conform with commercial hard disk sector sizes. The blocks are individually erasable. In one embodiment, the semiconductor mass storage can be substituted for a rotating hard disk with no impact to the user, so that such a substitution will be transparent. Means are provided for avoiding the erase-before-write cycle each time information stored in the mass storage is changed.
- According to the first algorithm, erase cycles are avoided by programming an altered data file into an empty block. This would ordinarily not be possible when using conventional mass storage because the central processor and commercial software available in conventional computer systems are not configured to track continually changing physical locations of data files. The previous solution includes a programmable map to maintain a correlation between the logical address and the physical address of the updated information files.
- All the flags, and the table correlating the logical block address to the physical block address are maintained within an array of CAM cells. The use of the CAM cells provides very rapid determination of the physical address desired within the mass storage, generally within one or two clock cycles. Unfortunately, as is well known, CAM cells require multiple transistors, typically six. Accordingly, an integrated circuit built for a particular size memory using CAM storage for the tables and flags will need to be significantly larger than a circuit using other means for just storing the memory.
- The inventors proposed another solution to this problem which is disclosed in U.S. Pat. No. 5,485,595, issued on Jan. 16, 1996. That application is incorporated herein by reference.
- This additional previous solution invented by these same inventors is also for a nonvolatile memory storage device. The device is also configured to avoid having to perform an erase-before-write each time a data file is changed by keeping a correlation between logical block address and physical block address in a volatile space management RAM. Further, this invention avoids the overhead associated with CAM cell approaches which require additional circuitry.
- Like the solutions disclosed above by these same inventors, the device includes circuitry for performing the two primary algorithms and an associated hardware architecture for a semiconductor mass storage device. In addition, the CAM cell is avoided in this previous solution by using RAM cells.
- Reading is performed in this previous solution by providing the logical block address to the memory storage. The system sequentially compares the stored logical block addresses until it finds a match. That data file is then coupled to the digital system. Accordingly, the performance offered by this solution suffers because potentially all of the memory locations must be searched and compared to the desired logical block address before the physical location of the desired information can be determined.
- What is needed is a semiconductor hard disk architecture which provides rapid access to stored data without the excessive overhead of CAM cell storage.
-
FIG. 1 shows a schematic block diagram of an architecture for a semiconductor mass storage according to the present invention. -
FIG. 2 shows an alternative embodiment to thephysical block address 102 of the RAM storage ofFIG. 1 . -
FIG. 3 shows a block diagram of a system incorporating the mass storage device of the present invention. -
FIGS. 4 through 8 show the status of several of the flags and information for achieving the advantages of the present invention. -
FIG. 9 shows a flow chart block diagram of the first algorithm according to the present invention. -
FIG. 1 shows an architecture for implementation of a solid state storage media according to the present invention. The storage media is for use with a host or other external digital system. The mass storage is partitioned into two portions, avolatile RAM array 100 and anonvolatile array 104. According to the preferred embodiment, all of the nonvolatile memory storage is FLASH. The FLASH may be replaced by EEPROM. The RAM can be of any convenient type. - The
memory storage 104 is arranged into N blocks of data from zero through N−1. Each of the blocks of data is M Bytes long. In the preferred embodiment, each data block is 512 Bytes long to correspond with a sector length in a commercially available hard disk drive plus the extra numbers of bytes to store the flags and logical block address information and the associated ECC. Thememory 104 can contain as much memory storage as a user desires. An example of a mass storage device might include 100 M Byte of addressable storage. There are a plurality ofRAM locations 102. - Each
RAM location 102 is uniquely addressable by a controller using an appropriate one of the logical block addresses provided by the host system or the actual physical address of the nonvolatile media. TheRAM location 102 contains the physical block address of the data associated with the logical block address and the flags associated with a physical block address on the nonvolatile media. - It is possible that the physical block address can be split into two fields as shown in
FIG. 2 . These fields can be used for cluster addresses of a group of data blocks. The firstsuch field 290 is used to select a cluster address and the secondsuch field 292 can be used to select the start address of the logical block address associated with this cluster. - A collection of information flags is also stored for each
nonvolatile memory location 106. These flags include an old/new flag 110, a used/free flag 112, a defect flag, 114, and a single/sector flag 116. Additionally, there is also adata store 122. - When writing data to the mass storage device of the present invention, a controller determines the first available physical block for storing the data. The
RAM location 102 corresponding to the logical block address selected by the host is written with the physical block address where the data is actually stored within the nonvolatile memory array in 104 (FIG. 1 ). - Assume for example that a user is preparing a word processing document and instructs the computer to save the document. The document will be stored in the mass storage system. The host system will assign it a logical block address. The mass storage system of the present invention will select a physical address of an unused block or blocks in the mass storage for storing the document. The address of the physical block address will be stored into the
RAM location 102 corresponding to the logical block address. As the data is programmed, the system of the present invention also sets the used/free flag 112 in 104 and 293 to indicate that this block location is used. One used/free flag 112 is provided for each entry of thenonvolatile array 104. - Later, assume the user retrieves the document, makes a change and again instructs the computer to store the document. To avoid an erase-before-write cycle, the system of the present invention provides means for locating a block having its used/
free flag 112 in 100 unset (not programmed) which indicates that the associated block is erased. The system then sets the used/free flag for thenew block 112 of 106 and 293 of 100 and then stores the modified document in that newphysical block location 106 in thenonvolatile array 104. The address of the new physical block location is also stored into theRAM location 102 corresponding to the logical block address, thereby writing over the previous physical block location in 102. Next, the system sets the old/new flag 110 of the previous version of the document indicating that this is an old unneeded version of the document in 110 of 104 and 293 of 100 In this way, the system of the present invention avoids the overhead of an erase cycle which is required in the erase-before-write of conventional systems to store a modified version of a previous document. - Because of
RAM array 100 will lose its memory upon a power down condition, the logical block address with the active physical block address in the media is also stored as ashadow memory 108 in thenonvolatile array 104. It will be understood the shadow information will be stored into theappropriate RAM locations 102 by the controller. During power up sequence, the RAM locations in 100 are appropriately updated from every physical locations in 104, by reading theinformation 106 of 104. Thelogical address 108 of 106 is used to address the RAM location of 100 to update the actual physical block address associated with the given logical block address. Also since 106 is the actual physical block address associated with thenew data 122, theflags nonvolatile memory location 106 or in both the nonvolatile memory location and also in theRAM location 102 associated with the physical block address. - During power up, in order to assign the most recent physical block address assigned to a logical block address in the
volatile memory 100, the controller will first reads theFlags nonvolatile memory 104 and updates theflags portion 293 in thevolatile memory 100. Then it reads thelogical block address 108 of every physical block address of thenonvolatile media 104 and by tracking the flags of the given physical block address in thevolatile memory 100, and the read logical block address of the physical block address in thenonvolatile memory 104, it can update the most recent physical block address assigned to the read logical block address in thevolatile memory 100. -
FIG. 3 shows a block diagram of a system incorporating the mass storage device of the present invention. An externaldigital system 300 such as a host computer, personal computer and the like is coupled to themass storage device 302 of the present invention. A logical block address is coupled via anaddress bus 306 to thevolatile RAM array 100 and to acontroller circuit 304. Control signals are also coupled to thecontroller 304 via acontrol bus 308. Thevolatile RAM array 100 is coupled viadata paths 140 for providing the physical block address to thenonvolatile RAM array 104. Thecontroller 304 is coupled to control both thevolatile RAM 100, thenonvolatile array 104, and for the generation of all flags. - A simplified example, showing the operation of the write operation according to the present invention is shown in
FIGS. 4 through 8 . Not all the information flags are shown to avoid obscuring these features of the invention in excessive detail. The data entries are shown using decimal numbers to further simplify the understanding of the invention. It will be apparent to one of ordinary skill in the art that in a preferred embodiment binary counting will be used. -
FIG. 4 shows an eleven entry mass storage device according to the present invention. There is no valid nor usable data stored in the mass storage device ofFIG. 4 . Accordingly, all the physical block addresses are empty. The data stored in the nonvolatile mass storage location ‘6’ is filled and old. Additionally, location ‘9’ is defective and cannot be used. - The host directs the mass storage device of the example to write data pursuant to the logical block address ‘3’ and then to ‘4’ The mass storage device will first write the data associated with the logical block address ‘3’. The device determines which is the first unused location in the nonvolatile memory. In this example, the first empty location is location ‘0’. Accordingly,
FIG. 5 shows that for the logical block address ‘3’, the corresponding physical block address ‘0’ is stored and the used flag is set in physical block address ‘0’. The next empty location is location ‘1’.FIG. 6 shows that for the logical block address ‘4’, the corresponding physical block address ‘1’ is stored and the used flag is set in physical block address ‘1’. - The host instructs that something is to be written to logical block address ‘3’ again. The next empty location is determined to be location ‘2’.
FIG. 7 shows that the old flag in location ‘0’ is set to indicate that this data is no longer usable, the used flag is set in location ‘2’ and the physical block address in location ‘3’ is changed to ‘2’. - Next, the host instructs that something is to be written to logical block address ‘4’ again. The next empty location is determined to be location ‘3’.
FIG. 8 shows that the old flag in location ‘1’ is set to indicate that this data is no longer usable, the used flag is set in location ‘3’ and the physical block address in location ‘4’ is changed to ‘3’. (Recall that there is generally no relation between the physical block address and the data stored in the same location.) -
FIG. 9 showsalgorithm 1 according to the present invention. When the system of the present invention receives an instruction to program data into the mass storage (step 200), then the system attempts to locate a free block (step 202), i.e., a block having an unset (not programmed) used/free flag. If successful, the system sets the used/free flag for that block and programs the data into that block (step 206). - If on the other hand, the system is unable to locate a block having an unset used/free flag, the system erases the flags (used/free and old/new) and data for all blocks having a set old/new flag and unset defect flag (step 204) and then searches for a block having an unset used/free flag (step 202). Such a block has just been formed by
step 204. The system then sets the used/flag for that block and programs the data file into that block (step 206). - If the data is a modified version of a previously existing file, the system must prevent the superseded version from being accessed. The system determines whether the data file supersedes a previous data file (step 208). If so, the system sets the old/new flag associated with the superseded block (step 210). If on the other hand, the data file to be stored is a newly created data file, the step of setting the old/new flag (step 210) is skipped because there is no superseded block. Lastly, the map for correlating the
logical address 108 to thephysical address 130 is updated (step 212). - By Following the procedure outlined above, the overhead associated with an erase cycle is avoided for each write to the
memory 104 except for periodically. This vastly improves the performance of the overall computer system employing the architecture of the present invention. - In the preferred embodiment of the present invention, the programming of the flash memory follows the procedure commonly understood by those of ordinary skill in the art. In other words, the program impulses are appropriately applied to the bits to be programmed and then compared to the data being programmed to ensure that proper programming has occurred. In the event that a bit fails to be erased or programmed properly, a defect flag 114 (in
FIG. 1 ) is set which prevent that block from being used again. - The present invention is described relative to a preferred embodiment. Modifications or improvements which are apparent to one of ordinary skill in the art after reading this disclosure are deemed within the spirit and scope of this invention.
Claims (25)
Priority Applications (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/426,662 US7774576B2 (en) | 1995-07-31 | 2009-04-20 | Direct logical block addressing flash memory mass storage architecture |
US12/844,354 US8032694B2 (en) | 1995-07-31 | 2010-07-27 | Direct logical block addressing flash memory mass storage architecture |
Applications Claiming Priority (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US08/509,706 US5845313A (en) | 1995-07-31 | 1995-07-31 | Direct logical block addressing flash memory mass storage architecture |
US09/087,720 US5924113A (en) | 1995-07-31 | 1998-05-29 | Direct logical block addressing flash memory mass storage architecture |
US09/311,045 US6115785A (en) | 1995-07-31 | 1999-05-13 | Direct logical block addressing flash memory mass storage architecture |
US09/521,420 US6230234B1 (en) | 1995-07-31 | 2000-03-08 | Direct logical block addressing flash memory mass storage architecture |
US09/850,790 US6912618B2 (en) | 1995-07-31 | 2001-05-07 | Direct logical block addressing flash memory mass storage architecture |
US11/165,864 US7523249B1 (en) | 1995-07-31 | 2005-06-24 | Direct logical block addressing flash memory mass storage architecture |
US12/426,662 US7774576B2 (en) | 1995-07-31 | 2009-04-20 | Direct logical block addressing flash memory mass storage architecture |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US11/165,864 Continuation US7523249B1 (en) | 1995-07-31 | 2005-06-24 | Direct logical block addressing flash memory mass storage architecture |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/844,354 Continuation US8032694B2 (en) | 1995-07-31 | 2010-07-27 | Direct logical block addressing flash memory mass storage architecture |
Publications (2)
Publication Number | Publication Date |
---|---|
US20090204750A1 true US20090204750A1 (en) | 2009-08-13 |
US7774576B2 US7774576B2 (en) | 2010-08-10 |
Family
ID=24027781
Family Applications (8)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/509,706 Expired - Lifetime US5845313A (en) | 1995-07-31 | 1995-07-31 | Direct logical block addressing flash memory mass storage architecture |
US09/087,720 Expired - Lifetime US5924113A (en) | 1995-07-31 | 1998-05-29 | Direct logical block addressing flash memory mass storage architecture |
US09/311,045 Expired - Lifetime US6115785A (en) | 1995-07-31 | 1999-05-13 | Direct logical block addressing flash memory mass storage architecture |
US09/521,420 Expired - Lifetime US6230234B1 (en) | 1995-07-31 | 2000-03-08 | Direct logical block addressing flash memory mass storage architecture |
US09/850,790 Expired - Fee Related US6912618B2 (en) | 1995-07-31 | 2001-05-07 | Direct logical block addressing flash memory mass storage architecture |
US11/165,864 Expired - Fee Related US7523249B1 (en) | 1995-07-31 | 2005-06-24 | Direct logical block addressing flash memory mass storage architecture |
US12/426,662 Expired - Fee Related US7774576B2 (en) | 1995-07-31 | 2009-04-20 | Direct logical block addressing flash memory mass storage architecture |
US12/844,354 Expired - Fee Related US8032694B2 (en) | 1995-07-31 | 2010-07-27 | Direct logical block addressing flash memory mass storage architecture |
Family Applications Before (6)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US08/509,706 Expired - Lifetime US5845313A (en) | 1995-07-31 | 1995-07-31 | Direct logical block addressing flash memory mass storage architecture |
US09/087,720 Expired - Lifetime US5924113A (en) | 1995-07-31 | 1998-05-29 | Direct logical block addressing flash memory mass storage architecture |
US09/311,045 Expired - Lifetime US6115785A (en) | 1995-07-31 | 1999-05-13 | Direct logical block addressing flash memory mass storage architecture |
US09/521,420 Expired - Lifetime US6230234B1 (en) | 1995-07-31 | 2000-03-08 | Direct logical block addressing flash memory mass storage architecture |
US09/850,790 Expired - Fee Related US6912618B2 (en) | 1995-07-31 | 2001-05-07 | Direct logical block addressing flash memory mass storage architecture |
US11/165,864 Expired - Fee Related US7523249B1 (en) | 1995-07-31 | 2005-06-24 | Direct logical block addressing flash memory mass storage architecture |
Family Applications After (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/844,354 Expired - Fee Related US8032694B2 (en) | 1995-07-31 | 2010-07-27 | Direct logical block addressing flash memory mass storage architecture |
Country Status (1)
Country | Link |
---|---|
US (8) | US5845313A (en) |
Cited By (39)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20110099339A1 (en) * | 2009-10-28 | 2011-04-28 | Canon Kabushiki Kaisha | Information processing apparatus, method for controlling information processing apparatus and storage medium |
US8189407B2 (en) | 2006-12-06 | 2012-05-29 | Fusion-Io, Inc. | Apparatus, system, and method for biasing data in a solid-state storage device |
US8194340B1 (en) | 2010-03-18 | 2012-06-05 | Western Digital Technologies, Inc. | Disk drive framing write data with in-line mapping data during write operations |
US8316277B2 (en) | 2007-12-06 | 2012-11-20 | Fusion-Io, Inc. | Apparatus, system, and method for ensuring data validity in a data storage process |
US20120320517A1 (en) * | 2011-06-17 | 2012-12-20 | Bae Systems Controls Inc. | Obsolescence tolerant flash memory architecture and physical building block (pbb) implementation |
US8443134B2 (en) | 2006-12-06 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for graceful cache device degradation |
US8443167B1 (en) | 2009-12-16 | 2013-05-14 | Western Digital Technologies, Inc. | Data storage device employing a run-length mapping table and a single address mapping table |
US8489817B2 (en) | 2007-12-06 | 2013-07-16 | Fusion-Io, Inc. | Apparatus, system, and method for caching data |
US8612706B1 (en) | 2011-12-21 | 2013-12-17 | Western Digital Technologies, Inc. | Metadata recovery in a disk drive |
US8667248B1 (en) | 2010-08-31 | 2014-03-04 | Western Digital Technologies, Inc. | Data storage device using metadata and mapping table to identify valid user data on non-volatile media |
US8687306B1 (en) | 2010-03-22 | 2014-04-01 | Western Digital Technologies, Inc. | Systems and methods for improving sequential data rate performance using sorted data zones |
US8693133B1 (en) | 2010-03-22 | 2014-04-08 | Western Digital Technologies, Inc. | Systems and methods for improving sequential data rate performance using sorted data zones for butterfly format |
US8699185B1 (en) | 2012-12-10 | 2014-04-15 | Western Digital Technologies, Inc. | Disk drive defining guard bands to support zone sequentiality when butterfly writing shingled data tracks |
US8706968B2 (en) | 2007-12-06 | 2014-04-22 | Fusion-Io, Inc. | Apparatus, system, and method for redundant write caching |
US8719501B2 (en) | 2009-09-08 | 2014-05-06 | Fusion-Io | Apparatus, system, and method for caching data on a solid-state storage device |
US8756361B1 (en) | 2010-10-01 | 2014-06-17 | Western Digital Technologies, Inc. | Disk drive modifying metadata cached in a circular buffer when a write operation is aborted |
US8756382B1 (en) | 2011-06-30 | 2014-06-17 | Western Digital Technologies, Inc. | Method for file based shingled data storage utilizing multiple media types |
US8782344B2 (en) | 2012-01-12 | 2014-07-15 | Fusion-Io, Inc. | Systems and methods for managing cache admission |
US8793429B1 (en) | 2011-06-03 | 2014-07-29 | Western Digital Technologies, Inc. | Solid-state drive with reduced power up time |
US8819367B1 (en) | 2011-12-19 | 2014-08-26 | Western Digital Technologies, Inc. | Accelerated translation power recovery |
US8825937B2 (en) | 2011-02-25 | 2014-09-02 | Fusion-Io, Inc. | Writing cached data forward on read |
US8856438B1 (en) | 2011-12-09 | 2014-10-07 | Western Digital Technologies, Inc. | Disk drive with reduced-size translation table |
US8954664B1 (en) | 2010-10-01 | 2015-02-10 | Western Digital Technologies, Inc. | Writing metadata files on a disk |
US8953269B1 (en) | 2014-07-18 | 2015-02-10 | Western Digital Technologies, Inc. | Management of data objects in a data object zone |
US8966184B2 (en) | 2011-01-31 | 2015-02-24 | Intelligent Intellectual Property Holdings 2, LLC. | Apparatus, system, and method for managing eviction of data |
US9104599B2 (en) | 2007-12-06 | 2015-08-11 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for destaging cached data |
US9116823B2 (en) | 2006-12-06 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for adaptive error-correction coding |
US9170754B2 (en) | 2007-12-06 | 2015-10-27 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment |
US9213493B1 (en) | 2011-12-16 | 2015-12-15 | Western Digital Technologies, Inc. | Sorted serpentine mapping for storage drives |
US9251086B2 (en) | 2012-01-24 | 2016-02-02 | SanDisk Technologies, Inc. | Apparatus, system, and method for managing a cache |
US9251052B2 (en) | 2012-01-12 | 2016-02-02 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for profiling a non-volatile cache having a logical-to-physical translation layer |
US9330715B1 (en) | 2010-03-22 | 2016-05-03 | Western Digital Technologies, Inc. | Mapping of shingled magnetic recording media |
US9495241B2 (en) | 2006-12-06 | 2016-11-15 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for adaptive data storage |
US9519540B2 (en) | 2007-12-06 | 2016-12-13 | Sandisk Technologies Llc | Apparatus, system, and method for destaging cached data |
US9767032B2 (en) | 2012-01-12 | 2017-09-19 | Sandisk Technologies Llc | Systems and methods for cache endurance |
WO2017161083A1 (en) * | 2016-03-18 | 2017-09-21 | Alibaba Group Holding Limited | Implementing fault tolerance in computer system memory |
US9875055B1 (en) | 2014-08-04 | 2018-01-23 | Western Digital Technologies, Inc. | Check-pointing of metadata |
US10019353B2 (en) | 2012-03-02 | 2018-07-10 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for referencing data on a storage medium |
US10102117B2 (en) | 2012-01-12 | 2018-10-16 | Sandisk Technologies Llc | Systems and methods for cache and storage device coordination |
Families Citing this family (182)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5430859A (en) * | 1991-07-26 | 1995-07-04 | Sundisk Corporation | Solid state memory system including plural memory chips and a serialized bus |
JP3782840B2 (en) | 1995-07-14 | 2006-06-07 | 株式会社ルネサステクノロジ | External storage device and memory access control method thereof |
US6081878A (en) | 1997-03-31 | 2000-06-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6978342B1 (en) | 1995-07-31 | 2005-12-20 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
US6757800B1 (en) | 1995-07-31 | 2004-06-29 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6801979B1 (en) | 1995-07-31 | 2004-10-05 | Lexar Media, Inc. | Method and apparatus for memory control circuit |
US5845313A (en) | 1995-07-31 | 1998-12-01 | Lexar | Direct logical block addressing flash memory mass storage architecture |
US8171203B2 (en) | 1995-07-31 | 2012-05-01 | Micron Technology, Inc. | Faster write operations to nonvolatile memory using FSInfo sector manipulation |
US6728851B1 (en) | 1995-07-31 | 2004-04-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6125435A (en) * | 1995-09-13 | 2000-09-26 | Lexar Media, Inc. | Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory |
US6035369A (en) * | 1995-10-19 | 2000-03-07 | Rambus Inc. | Method and apparatus for providing a memory with write enable information |
US6031758A (en) | 1996-02-29 | 2000-02-29 | Hitachi, Ltd. | Semiconductor memory device having faulty cells |
US5890192A (en) * | 1996-11-05 | 1999-03-30 | Sandisk Corporation | Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM |
US5953737A (en) * | 1997-03-31 | 1999-09-14 | Lexar Media, Inc. | Method and apparatus for performing erase operations transparent to a solid state storage system |
US6411546B1 (en) | 1997-03-31 | 2002-06-25 | Lexar Media, Inc. | Nonvolatile memory using flexible erasing methods and method and system for using same |
KR100251636B1 (en) * | 1997-04-10 | 2000-05-01 | 윤종용 | Memory device for connecting in a accordance with scsi |
JP3718578B2 (en) * | 1997-06-25 | 2005-11-24 | ソニー株式会社 | Memory management method and memory management device |
JPH11110267A (en) * | 1997-10-02 | 1999-04-23 | Oki Electric Ind Co Ltd | Device and method for data storing and storage medium |
JP3714969B2 (en) | 1998-03-02 | 2005-11-09 | レクサー・メディア・インコーポレイテッド | Flash memory card with improved operating mode detection and user-friendly interfacing system |
US6915375B2 (en) * | 1998-08-31 | 2005-07-05 | Sony Corporation | Memory apparatus and a data-processing apparatus, and method for using the memory apparatus |
DE59811962D1 (en) | 1998-09-04 | 2004-10-21 | Hyperstone Ag | ACCESS CONTROL OF A RESTRICTED ERASE FREQUENCY |
US6901457B1 (en) | 1998-11-04 | 2005-05-31 | Sandisk Corporation | Multiple mode communications system |
WO2000030116A1 (en) | 1998-11-17 | 2000-05-25 | Lexar Media, Inc. | Method and apparatus for memory control circuit |
FR2787601A1 (en) * | 1998-12-22 | 2000-06-23 | Gemplus Card Int | Memory system with anti-wear memory management and method of managing an anti-wear memory so as to increase duration life of memory |
US6345349B1 (en) * | 1998-12-30 | 2002-02-05 | Intel Corporation | Combined memory and mass storage device |
JP2000227871A (en) * | 1999-02-05 | 2000-08-15 | Seiko Epson Corp | Non-volatile storage device, control method therefor and information recording medium |
US6148354A (en) | 1999-04-05 | 2000-11-14 | M-Systems Flash Disk Pioneers Ltd. | Architecture for a universal serial bus-based PC flash disk |
US6606628B1 (en) * | 2000-02-14 | 2003-08-12 | Cisco Technology, Inc. | File system for nonvolatile memory |
US6426893B1 (en) | 2000-02-17 | 2002-07-30 | Sandisk Corporation | Flash eeprom system with simultaneous multiple data sector programming and storage of physical block characteristics in other designated blocks |
EP1130516A1 (en) * | 2000-03-01 | 2001-09-05 | Hewlett-Packard Company, A Delaware Corporation | Address mapping in solid state storage device |
US7167944B1 (en) | 2000-07-21 | 2007-01-23 | Lexar Media, Inc. | Block management for mass storage |
US7155559B1 (en) * | 2000-08-25 | 2006-12-26 | Lexar Media, Inc. | Flash memory architecture with separate storage of overhead and user data |
US6772274B1 (en) | 2000-09-13 | 2004-08-03 | Lexar Media, Inc. | Flash memory system and method implementing LBA to PBA correlation within flash memory array |
US7113432B2 (en) | 2000-09-14 | 2006-09-26 | Sandisk Corporation | Compressed event counting technique and application to a flash memory system |
US6763424B2 (en) | 2001-01-19 | 2004-07-13 | Sandisk Corporation | Partial block data programming and reading operations in a non-volatile memory |
US20020108018A1 (en) * | 2001-02-05 | 2002-08-08 | Han-Ping Chen | Memory module control and status |
KR100389867B1 (en) | 2001-06-04 | 2003-07-04 | 삼성전자주식회사 | Flash memory management method |
US7275135B2 (en) * | 2001-08-31 | 2007-09-25 | Intel Corporation | Hardware updated metadata for non-volatile mass storage cache |
GB0123421D0 (en) * | 2001-09-28 | 2001-11-21 | Memquest Ltd | Power management system |
GB0123416D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Non-volatile memory control |
GB0123410D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Memory system for data storage and retrieval |
GB0123415D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Method of writing data to non-volatile memory |
GB0123417D0 (en) * | 2001-09-28 | 2001-11-21 | Memquest Ltd | Improved data processing |
US20030074524A1 (en) * | 2001-10-16 | 2003-04-17 | Intel Corporation | Mass storage caching processes for power reduction |
US6977847B2 (en) * | 2001-11-23 | 2005-12-20 | M-Systems Flash Disk Pioneers Ltd. | Detecting partially erased units in flash devices |
JP3967121B2 (en) * | 2001-12-11 | 2007-08-29 | 株式会社ルネサステクノロジ | File system, file system control method, and program for controlling file system |
KR20040080928A (en) * | 2002-01-31 | 2004-09-20 | 마츠시타 덴끼 산교 가부시키가이샤 | Information processing apparatus, memory management apparatus, memory management method, and information processing method |
US6839826B2 (en) * | 2002-02-06 | 2005-01-04 | Sandisk Corporation | Memory device with pointer structure to map logical to physical addresses |
US7231643B1 (en) | 2002-02-22 | 2007-06-12 | Lexar Media, Inc. | Image rescue system including direct communication between an application program and a device driver |
WO2003071853A2 (en) * | 2002-02-22 | 2003-09-04 | Lexar Media, Inc. | Removable memory media with integral indicator light |
JP2003256228A (en) * | 2002-02-28 | 2003-09-10 | Denso Corp | Program rewriting device |
WO2004031961A1 (en) * | 2002-09-30 | 2004-04-15 | Insignia Solutions Plc | Efficient system and method for updating a memory device |
WO2004031966A1 (en) * | 2002-10-02 | 2004-04-15 | Matsushita Electric Industrial Co., Ltd. | Non-volatile storage device control method |
US20040083334A1 (en) * | 2002-10-28 | 2004-04-29 | Sandisk Corporation | Method and apparatus for managing the integrity of data in non-volatile memory system |
US7039788B1 (en) | 2002-10-28 | 2006-05-02 | Sandisk Corporation | Method and apparatus for splitting a logical block |
US7103732B1 (en) | 2002-10-28 | 2006-09-05 | Sandisk Corporation | Method and apparatus for managing an erase count block |
US6985992B1 (en) | 2002-10-28 | 2006-01-10 | Sandisk Corporation | Wear-leveling in non-volatile storage systems |
US7174440B2 (en) * | 2002-10-28 | 2007-02-06 | Sandisk Corporation | Method and apparatus for performing block caching in a non-volatile memory system |
US7035967B2 (en) * | 2002-10-28 | 2006-04-25 | Sandisk Corporation | Maintaining an average erase count in a non-volatile storage system |
US8412879B2 (en) * | 2002-10-28 | 2013-04-02 | Sandisk Technologies Inc. | Hybrid implementation for error correction codes within a non-volatile memory system |
US7526599B2 (en) * | 2002-10-28 | 2009-04-28 | Sandisk Corporation | Method and apparatus for effectively enabling an out of sequence write process within a non-volatile memory system |
US6831865B2 (en) * | 2002-10-28 | 2004-12-14 | Sandisk Corporation | Maintaining erase counts in non-volatile storage systems |
US6973531B1 (en) | 2002-10-28 | 2005-12-06 | Sandisk Corporation | Tracking the most frequently erased blocks in non-volatile memory systems |
US7254668B1 (en) | 2002-10-28 | 2007-08-07 | Sandisk Corporation | Method and apparatus for grouping pages within a block |
US7171536B2 (en) * | 2002-10-28 | 2007-01-30 | Sandisk Corporation | Unusable block management within a non-volatile memory system |
US7096313B1 (en) | 2002-10-28 | 2006-08-22 | Sandisk Corporation | Tracking the least frequently erased blocks in non-volatile memory systems |
US7234036B1 (en) | 2002-10-28 | 2007-06-19 | Sandisk Corporation | Method and apparatus for resolving physical blocks associated with a common logical block |
US7181611B2 (en) * | 2002-10-28 | 2007-02-20 | Sandisk Corporation | Power management block for use in a non-volatile memory system |
US6973519B1 (en) | 2003-06-03 | 2005-12-06 | Lexar Media, Inc. | Card identification compatibility |
US7559004B1 (en) | 2003-10-01 | 2009-07-07 | Sandisk Corporation | Dynamic redundant area configuration in a non-volatile memory system |
US7188228B1 (en) * | 2003-10-01 | 2007-03-06 | Sandisk Corporation | Hybrid mapping implementation within a non-volatile memory system |
US7032087B1 (en) | 2003-10-28 | 2006-04-18 | Sandisk Corporation | Erase count differential table within a non-volatile memory system |
US7089349B2 (en) * | 2003-10-28 | 2006-08-08 | Sandisk Corporation | Internal maintenance schedule request for non-volatile memory system |
US8706990B2 (en) | 2003-10-28 | 2014-04-22 | Sandisk Technologies Inc. | Adaptive internal table backup for non-volatile memory system |
JP2005190288A (en) * | 2003-12-26 | 2005-07-14 | Tdk Corp | Memory controller, flash memory system therewith, and method for controlling flash memory |
US8504798B2 (en) * | 2003-12-30 | 2013-08-06 | Sandisk Technologies Inc. | Management of non-volatile memory systems having large erase blocks |
US7631138B2 (en) * | 2003-12-30 | 2009-12-08 | Sandisk Corporation | Adaptive mode switching of flash memory address mapping based on host usage characteristics |
US7725628B1 (en) | 2004-04-20 | 2010-05-25 | Lexar Media, Inc. | Direct secondary device interface by a host |
US7370166B1 (en) | 2004-04-30 | 2008-05-06 | Lexar Media, Inc. | Secure portable storage device |
JP4253272B2 (en) * | 2004-05-27 | 2009-04-08 | 株式会社東芝 | Memory card, semiconductor device, and control method of semiconductor memory |
US7240065B2 (en) * | 2004-05-27 | 2007-07-03 | Oracle International Corporation | Providing mappings between logical time values and real time values |
US7251660B2 (en) | 2004-06-10 | 2007-07-31 | Oracle International Corporation | Providing mappings between logical time values and real time values in a multinode system |
US7492953B2 (en) * | 2004-06-17 | 2009-02-17 | Smith Micro Software, Inc. | Efficient method and system for reducing update requirements for a compressed binary image |
US7594063B1 (en) | 2004-08-27 | 2009-09-22 | Lexar Media, Inc. | Storage capacity status |
US7464306B1 (en) | 2004-08-27 | 2008-12-09 | Lexar Media, Inc. | Status of overall health of nonvolatile memory |
KR100725390B1 (en) * | 2005-01-06 | 2007-06-07 | 삼성전자주식회사 | Apparatus and method for storing data in nonvolatile cache memory considering update ratio |
JP2006227818A (en) * | 2005-02-16 | 2006-08-31 | Fujitsu Ltd | Diagnosing method for identification information and input/output device |
US20070006000A1 (en) * | 2005-06-30 | 2007-01-04 | Sandeep Jain | Using fine-grained power management of physical system memory to improve system sleep |
EP1934727B1 (en) * | 2005-08-23 | 2019-01-16 | Red Bend Ltd. | Method and system for in-place updating content stored in a storage device |
KR101260632B1 (en) | 2005-09-30 | 2013-05-03 | 모사이드 테크놀로지스 인코퍼레이티드 | Memory with output control |
US11948629B2 (en) | 2005-09-30 | 2024-04-02 | Mosaid Technologies Incorporated | Non-volatile memory device with concurrent bank operations |
US7652922B2 (en) | 2005-09-30 | 2010-01-26 | Mosaid Technologies Incorporated | Multiple independent serial link memory |
US20070083697A1 (en) * | 2005-10-07 | 2007-04-12 | Microsoft Corporation | Flash memory management |
US7631162B2 (en) | 2005-10-27 | 2009-12-08 | Sandisck Corporation | Non-volatile memory with adaptive handling of data writes |
WO2007081598A2 (en) * | 2005-10-27 | 2007-07-19 | Sandisk Corporation | Adaptive handling data writes in non-volatile memories |
US7509471B2 (en) * | 2005-10-27 | 2009-03-24 | Sandisk Corporation | Methods for adaptively handling data writes in non-volatile memories |
US7831783B2 (en) * | 2005-12-22 | 2010-11-09 | Honeywell International Inc. | Effective wear-leveling and concurrent reclamation method for embedded linear flash file systems |
US7464240B2 (en) * | 2006-05-23 | 2008-12-09 | Data Ram, Inc. | Hybrid solid state disk drive with controller |
US7461229B2 (en) * | 2006-05-23 | 2008-12-02 | Dataram, Inc. | Software program for managing and protecting data written to a hybrid solid-state disk drive |
US7783956B2 (en) | 2006-07-12 | 2010-08-24 | Cronera Systems Incorporated | Data recorder |
JP4868298B2 (en) * | 2006-07-20 | 2012-02-01 | 日本電気株式会社 | Memory access control device, memory access control method, data storage method, and memory access control program |
US20080071968A1 (en) * | 2006-09-18 | 2008-03-20 | Phison Electronics Corp. | Method of managing blocks fo flash memory suitable for flexible correspondence between logic block and physical block |
US8935302B2 (en) * | 2006-12-06 | 2015-01-13 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for data block usage information synchronization for a non-volatile storage volume |
TW200828320A (en) * | 2006-12-28 | 2008-07-01 | Genesys Logic Inc | Method for performing static wear leveling on flash memory |
US7721040B2 (en) | 2007-01-18 | 2010-05-18 | Sandisk Il Ltd. | Method and system for facilitating fast wake-up of a flash memory system |
WO2008087634A1 (en) * | 2007-01-18 | 2008-07-24 | Sandisk Il Ltd. | A method and system for facilitating fast wake-up of a flash memory system |
US7814360B2 (en) * | 2007-01-25 | 2010-10-12 | Oralce International Corporation | Synchronizing cluster time to a master node with a faster clock |
US20080189473A1 (en) * | 2007-02-07 | 2008-08-07 | Micron Technology, Inc | Mlc selected multi-program for system management |
JP4874844B2 (en) * | 2007-03-26 | 2012-02-15 | 株式会社東芝 | Information recording apparatus and control method thereof |
US8239639B2 (en) * | 2007-06-08 | 2012-08-07 | Sandisk Technologies Inc. | Method and apparatus for providing data type and host file information to a mass storage system |
US8713283B2 (en) * | 2007-06-08 | 2014-04-29 | Sandisk Technologies Inc. | Method of interfacing a host operating through a logical address space with a direct file storage medium |
US20080307156A1 (en) * | 2007-06-08 | 2008-12-11 | Sinclair Alan W | System For Interfacing A Host Operating Through A Logical Address Space With A Direct File Storage Medium |
US8892831B2 (en) * | 2008-01-16 | 2014-11-18 | Apple Inc. | Memory subsystem hibernation |
US8307180B2 (en) | 2008-02-28 | 2012-11-06 | Nokia Corporation | Extended utilization area for a memory device |
JP5218228B2 (en) * | 2008-04-23 | 2013-06-26 | 新東工業株式会社 | Conveying device and blasting device |
US8285919B2 (en) * | 2008-05-27 | 2012-10-09 | Initio Corporation | SSD with improved bad block management |
WO2009149059A1 (en) * | 2008-06-04 | 2009-12-10 | Initio Corporation | Ssd with a controller accelerator |
US8843691B2 (en) * | 2008-06-25 | 2014-09-23 | Stec, Inc. | Prioritized erasure of data blocks in a flash storage device |
US8139390B2 (en) * | 2008-07-08 | 2012-03-20 | Mosaid Technologies Incorporated | Mixed data rates in memory devices and systems |
US20100082903A1 (en) * | 2008-09-30 | 2010-04-01 | Kabushiki Kaisha Toshiba | Non-volatile semiconductor memory drive, information processing apparatus and data access control method of the non-volatile semiconductor memory drive |
US9128821B2 (en) * | 2008-10-10 | 2015-09-08 | Seagate Technology Llc | Data updating in non-volatile memory |
US8169856B2 (en) * | 2008-10-24 | 2012-05-01 | Oracle International Corporation | Time synchronization in cluster systems |
US8205060B2 (en) * | 2008-12-16 | 2012-06-19 | Sandisk Il Ltd. | Discardable files |
US20100153474A1 (en) * | 2008-12-16 | 2010-06-17 | Sandisk Il Ltd. | Discardable files |
US9015209B2 (en) | 2008-12-16 | 2015-04-21 | Sandisk Il Ltd. | Download management of discardable files |
US8375192B2 (en) * | 2008-12-16 | 2013-02-12 | Sandisk Il Ltd. | Discardable files |
US9020993B2 (en) | 2008-12-16 | 2015-04-28 | Sandisk Il Ltd. | Download management of discardable files |
US9104686B2 (en) | 2008-12-16 | 2015-08-11 | Sandisk Technologies Inc. | System and method for host management of discardable objects |
US8849856B2 (en) * | 2008-12-16 | 2014-09-30 | Sandisk Il Ltd. | Discardable files |
US8180995B2 (en) | 2009-01-21 | 2012-05-15 | Micron Technology, Inc. | Logical address offset in response to detecting a memory formatting operation |
US20100235473A1 (en) * | 2009-03-10 | 2010-09-16 | Sandisk Il Ltd. | System and method of embedding second content in first content |
TWI457940B (en) * | 2009-05-15 | 2014-10-21 | Macronix Int Co Ltd | Byte-access in block-based flash memory |
US8874824B2 (en) | 2009-06-04 | 2014-10-28 | Memory Technologies, LLC | Apparatus and method to share host system RAM with mass storage memory RAM |
US9342445B2 (en) | 2009-07-23 | 2016-05-17 | Hgst Technologies Santa Ana, Inc. | System and method for performing a direct memory access at a predetermined address in a flash storage |
US9122579B2 (en) | 2010-01-06 | 2015-09-01 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for a storage layer |
WO2011031903A2 (en) | 2009-09-09 | 2011-03-17 | Fusion-Io, Inc. | Apparatus, system, and method for allocating storage |
US9110594B2 (en) * | 2009-11-04 | 2015-08-18 | Seagate Technology Llc | File management system for devices containing solid-state media |
JP5269213B2 (en) * | 2010-02-02 | 2013-08-21 | 株式会社東芝 | Communication device with storage function |
US20110302224A1 (en) * | 2010-06-08 | 2011-12-08 | Rahav Yairi | Data storage device with preloaded content |
TWI457941B (en) * | 2010-06-25 | 2014-10-21 | Macronix Int Co Ltd | Method and apparatus for high-speed byte-access in block-based flash memory |
CN102314396B (en) * | 2010-07-06 | 2014-01-29 | 旺宏电子股份有限公司 | Method and device for accessing bytes by taking a block as base flash |
US8239619B2 (en) | 2010-07-09 | 2012-08-07 | Macronix International Co., Ltd. | Method and apparatus for high-speed byte-access in block-based flash memory |
US8463802B2 (en) | 2010-08-19 | 2013-06-11 | Sandisk Il Ltd. | Card-based management of discardable files |
US8549229B2 (en) | 2010-08-19 | 2013-10-01 | Sandisk Il Ltd. | Systems and methods for managing an upload of files in a shared cache storage system |
US20120239860A1 (en) | 2010-12-17 | 2012-09-20 | Fusion-Io, Inc. | Apparatus, system, and method for persistent data management on a non-volatile storage media |
US9003104B2 (en) | 2011-02-15 | 2015-04-07 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for a file-level cache |
US8874823B2 (en) | 2011-02-15 | 2014-10-28 | Intellectual Property Holdings 2 Llc | Systems and methods for managing data input/output operations |
US9201677B2 (en) | 2011-05-23 | 2015-12-01 | Intelligent Intellectual Property Holdings 2 Llc | Managing data input/output operations |
US8788849B2 (en) | 2011-02-28 | 2014-07-22 | Sandisk Technologies Inc. | Method and apparatus for protecting cached streams |
US9563555B2 (en) | 2011-03-18 | 2017-02-07 | Sandisk Technologies Llc | Systems and methods for storage allocation |
WO2012129191A2 (en) | 2011-03-18 | 2012-09-27 | Fusion-Io, Inc. | Logical interfaces for contextual storage |
US20120317377A1 (en) * | 2011-06-09 | 2012-12-13 | Alexander Palay | Dual flash translation layer |
CN102231136B (en) * | 2011-07-12 | 2014-06-11 | 晨星软件研发(深圳)有限公司 | Data storage method and device for flash memory storage equipment |
KR20130044657A (en) * | 2011-10-24 | 2013-05-03 | 삼성전자주식회사 | File system and method for controlling the same |
US9069657B2 (en) | 2011-12-12 | 2015-06-30 | Apple Inc. | LBA bitmap usage |
US9274937B2 (en) | 2011-12-22 | 2016-03-01 | Longitude Enterprise Flash S.A.R.L. | Systems, methods, and interfaces for vector input/output operations |
US9116812B2 (en) | 2012-01-27 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for a de-duplication cache |
US9311226B2 (en) | 2012-04-20 | 2016-04-12 | Memory Technologies Llc | Managing operational state data of a memory module using host memory in association with state change |
US9164804B2 (en) * | 2012-06-20 | 2015-10-20 | Memory Technologies Llc | Virtual memory module |
US8910017B2 (en) | 2012-07-02 | 2014-12-09 | Sandisk Technologies Inc. | Flash memory with random partition |
US9612966B2 (en) | 2012-07-03 | 2017-04-04 | Sandisk Technologies Llc | Systems, methods and apparatus for a virtual machine cache |
US10339056B2 (en) | 2012-07-03 | 2019-07-02 | Sandisk Technologies Llc | Systems, methods and apparatus for cache transfers |
US9116820B2 (en) | 2012-08-28 | 2015-08-25 | Memory Technologies Llc | Dynamic central cache memory |
US10346095B2 (en) | 2012-08-31 | 2019-07-09 | Sandisk Technologies, Llc | Systems, methods, and interfaces for adaptive cache persistence |
US10509776B2 (en) | 2012-09-24 | 2019-12-17 | Sandisk Technologies Llc | Time sequence data management |
US10318495B2 (en) | 2012-09-24 | 2019-06-11 | Sandisk Technologies Llc | Snapshots for a non-volatile device |
JP6088837B2 (en) | 2013-02-12 | 2017-03-01 | 株式会社東芝 | Storage control device, storage control method, storage system, and program |
US9842053B2 (en) | 2013-03-15 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for persistent cache logging |
US10558561B2 (en) | 2013-04-16 | 2020-02-11 | Sandisk Technologies Llc | Systems and methods for storage metadata management |
US10102144B2 (en) | 2013-04-16 | 2018-10-16 | Sandisk Technologies Llc | Systems, methods and interfaces for data virtualization |
US9842128B2 (en) | 2013-08-01 | 2017-12-12 | Sandisk Technologies Llc | Systems and methods for atomic storage operations |
US10019320B2 (en) | 2013-10-18 | 2018-07-10 | Sandisk Technologies Llc | Systems and methods for distributed atomic storage operations |
US10073630B2 (en) | 2013-11-08 | 2018-09-11 | Sandisk Technologies Llc | Systems and methods for log coordination |
CN103559144A (en) * | 2013-11-12 | 2014-02-05 | 上海华兴数字科技有限公司 | Method and device for secure data storage of embedded system |
US9466383B2 (en) | 2013-12-30 | 2016-10-11 | Sandisk Technologies Llc | Non-volatile memory and method with adaptive logical groups |
US9946607B2 (en) | 2015-03-04 | 2018-04-17 | Sandisk Technologies Llc | Systems and methods for storage error management |
US9996273B1 (en) * | 2016-06-30 | 2018-06-12 | EMC IP Holding Company LLC | Storage system with data durability signaling for directly-addressable storage devices |
CN106201352B (en) * | 2016-07-07 | 2019-11-29 | 广东高云半导体科技股份有限公司 | The secrecy system and decryption method of non-volatile FPGA on piece data streaming file |
US10684947B2 (en) * | 2018-04-20 | 2020-06-16 | International Business Machines Corporation | Increasing high performance data storage utilization by reducing write operations |
US10754785B2 (en) * | 2018-06-28 | 2020-08-25 | Intel Corporation | Checkpointing for DRAM-less SSD |
KR20220053376A (en) * | 2020-10-22 | 2022-04-29 | 에스케이하이닉스 주식회사 | Controller and operating method thereof |
US11765100B1 (en) | 2022-04-19 | 2023-09-19 | Bank Of America Corporation | System for intelligent capacity planning for resources with high load variance |
Citations (96)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US34881A (en) * | 1862-04-08 | Improved arrastra | ||
US4309627A (en) * | 1978-04-14 | 1982-01-05 | Kabushiki Kaisha Daini Seikosha | Detecting circuit for a power source voltage |
US4450559A (en) * | 1981-12-24 | 1984-05-22 | International Business Machines Corporation | Memory system with selective assignment of spare locations |
US4456971A (en) * | 1981-02-09 | 1984-06-26 | Sony Corporation | Semiconductor RAM that is accessible in magnetic disc storage format |
US4498146A (en) * | 1982-07-30 | 1985-02-05 | At&T Bell Laboratories | Management of defects in storage media |
US4525839A (en) * | 1981-10-30 | 1985-06-25 | Hitachi, Ltd. | Method of controlling storage device |
US4654847A (en) * | 1984-12-28 | 1987-03-31 | International Business Machines | Apparatus for automatically correcting erroneous data and for storing the corrected data in a common pool alternate memory array |
US4746998A (en) * | 1985-11-20 | 1988-05-24 | Seagate Technology, Inc. | Method for mapping around defective sectors in a disc drive |
US4748320A (en) * | 1985-10-29 | 1988-05-31 | Toppan Printing Co., Ltd. | IC card |
US4797543A (en) * | 1985-07-31 | 1989-01-10 | 501 Toppan Moore Company, Ltd. | Selectable data readout IC card |
US4800520A (en) * | 1985-10-29 | 1989-01-24 | Kabushiki Kaisha Toshiba | Portable electronic device with garbage collection function |
US4829169A (en) * | 1985-07-01 | 1989-05-09 | Toppan Moore Company, Inc. | IC card having state marker for record access |
US4843224A (en) * | 1987-06-12 | 1989-06-27 | Oki Electric Industry Co., Ltd. | IC card |
US4896262A (en) * | 1984-02-24 | 1990-01-23 | Kabushiki Kaisha Meidensha | Emulation device for converting magnetic disc memory mode signal from computer into semiconductor memory access mode signal for semiconductor memory |
US4914529A (en) * | 1988-07-18 | 1990-04-03 | Western Digital Corp. | Data disk defect handling using relocation ID fields |
US4920518A (en) * | 1985-04-23 | 1990-04-24 | Hitachi, Ltd. | Semiconductor integrated circuit with nonvolatile memory |
US4924331A (en) * | 1985-11-20 | 1990-05-08 | Seagate Technology, Inc. | Method for mapping around defective sectors in a disc drive |
US5093785A (en) * | 1985-11-30 | 1992-03-03 | Kabushiki Kaisha Toshiba | Portable electronic device with memory having data pointers and circuitry for determining whether a next unwritten memory location exist |
US5200959A (en) * | 1989-10-17 | 1993-04-06 | Sundisk Corporation | Device and method for defect handling in semi-conductor memory |
US5220518A (en) * | 1990-06-07 | 1993-06-15 | Vlsi Technology, Inc. | Integrated circuit memory with non-binary array configuration |
US5293560A (en) * | 1988-06-08 | 1994-03-08 | Eliyahou Harari | Multi-state flash EEPROM system using incremental programing and erasing methods |
US5297148A (en) * | 1989-04-13 | 1994-03-22 | Sundisk Corporation | Flash eeprom system |
US5303198A (en) * | 1990-09-28 | 1994-04-12 | Fuji Photo Film Co., Ltd. | Method of recording data in memory card having EEPROM and memory card system using the same |
US5315558A (en) * | 1991-10-25 | 1994-05-24 | Vlsi Technology, Inc. | Integrated circuit memory with non-binary array configuration |
US5315541A (en) * | 1992-07-24 | 1994-05-24 | Sundisk Corporation | Segmented column memory array |
US5382539A (en) * | 1991-10-31 | 1995-01-17 | Rohm Co., Ltd. | Method for manufacturing a semiconductor device including nonvolatile memories |
US5384743A (en) * | 1992-03-06 | 1995-01-24 | Sgs-Thomson Microelectronics, S.A. | Structure and method for flash eprom memory erasable by sectors |
US5388083A (en) * | 1993-03-26 | 1995-02-07 | Cirrus Logic, Inc. | Flash memory mass storage architecture |
US5396468A (en) * | 1991-03-15 | 1995-03-07 | Sundisk Corporation | Streamlined write operation for EEPROM system |
US5404485A (en) * | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
US5406527A (en) * | 1992-06-26 | 1995-04-11 | Kabushiki Kaisha Toshiba | Partial write transferable multiport memory |
US5422856A (en) * | 1993-03-04 | 1995-06-06 | Hitachi, Ltd. | Non-volatile memory programming at arbitrary timing based on current requirements |
US5428621A (en) * | 1992-09-21 | 1995-06-27 | Sundisk Corporation | Latent defect handling in EEPROM devices |
US5485595A (en) * | 1993-03-26 | 1996-01-16 | Cirrus Logic, Inc. | Flash memory mass storage architecture incorporating wear leveling technique without using cam cells |
US5490117A (en) * | 1993-03-23 | 1996-02-06 | Seiko Epson Corporation | IC card with dual level power supply interface and method for operating the IC card |
US5495442A (en) * | 1993-07-08 | 1996-02-27 | Sandisk Corporation | Method and circuit for simultaneously programming and verifying the programming of selected EEPROM cells |
US5504760A (en) * | 1991-03-15 | 1996-04-02 | Sandisk Corporation | Mixed data encoding EEPROM system |
US5508975A (en) * | 1992-08-25 | 1996-04-16 | Industrial Sound Technologies, Inc. | Apparatus for degassing liquids |
US5524230A (en) * | 1991-07-12 | 1996-06-04 | International Business Machines Incorporated | External information storage system with a semiconductor memory |
US5530828A (en) * | 1992-06-22 | 1996-06-25 | Hitachi, Ltd. | Semiconductor storage device including a controller for continuously writing data to and erasing data from a plurality of flash memories |
US5530673A (en) * | 1993-04-08 | 1996-06-25 | Hitachi, Ltd. | Flash memory control method and information processing system therewith |
US5530938A (en) * | 1992-02-05 | 1996-06-25 | Seiko Instruments Inc. | Non-volatile memory card device having flash EEPROM memory chips with designated spare memory chips and the method of rewriting data into the memory card device |
US5592415A (en) * | 1992-07-06 | 1997-01-07 | Hitachi, Ltd. | Non-volatile semiconductor memory |
US5596526A (en) * | 1995-08-15 | 1997-01-21 | Lexar Microsystems, Inc. | Non-volatile memory system of multi-level transistor cells and methods using same |
US5598370A (en) * | 1993-02-24 | 1997-01-28 | International Business Machines Corporation | Nonvolatile memory with cluster-erase flash capability and solid state file apparatus using the same |
US5603001A (en) * | 1994-05-09 | 1997-02-11 | Kabushiki Kaisha Toshiba | Semiconductor disk system having a plurality of flash memories |
US5606660A (en) * | 1994-10-21 | 1997-02-25 | Lexar Microsystems, Inc. | Method and apparatus for combining controller firmware storage and controller logic in a mass storage system |
US5611067A (en) * | 1992-03-31 | 1997-03-11 | Kabushiki Kaisha Toshiba | Nonvolatile semiconductor memory device having means for selective transfer of memory block contents and for chaining together unused memory blocks |
US5640528A (en) * | 1991-10-24 | 1997-06-17 | Intel Corporation | Method and apparatus for translating addresses using mask and replacement value registers |
US5642312A (en) * | 1988-06-08 | 1997-06-24 | Harari; Eliyahou | Flash EEPROM system cell array with more than two storage states per memory cell |
US5723990A (en) * | 1995-06-21 | 1998-03-03 | Micron Quantum Devices, Inc. | Integrated circuit having high voltage detection circuit |
US5734567A (en) * | 1992-11-06 | 1998-03-31 | Siemens Aktiengesellschaft | Diagnosis system for a plant |
US5754567A (en) * | 1996-10-15 | 1998-05-19 | Micron Quantum Devices, Inc. | Write reduction in flash memory systems through ECC usage |
US5757712A (en) * | 1996-07-12 | 1998-05-26 | International Business Machines Corporation | Memory modules with voltage regulation and level translation |
US5758100A (en) * | 1996-07-01 | 1998-05-26 | Sun Microsystems, Inc. | Dual voltage module interconnect |
US5761117A (en) * | 1995-08-31 | 1998-06-02 | Sanyo Electric Co., Ltd. | Non-volatile multi-state memory device with memory cell capable of storing multi-state data |
US5768195A (en) * | 1993-09-24 | 1998-06-16 | Kabushiki Kaisha Toshiba | Semiconductor memory device |
US5768190A (en) * | 1991-09-24 | 1998-06-16 | Kabushiki Kaisha Toshiba | Electrically erasable and programmable non-volatile semiconductor memory with automatic write-verify controller |
US5773901A (en) * | 1995-07-21 | 1998-06-30 | Kantner; Edward A. | Universal PC card host |
US5860083A (en) * | 1996-11-26 | 1999-01-12 | Kabushiki Kaisha Toshiba | Data storage system having flash memory and disk drive |
US5860124A (en) * | 1996-09-30 | 1999-01-12 | Intel Corporation | Method for performing a continuous over-write of a file in nonvolatile memory |
US5890192A (en) * | 1996-11-05 | 1999-03-30 | Sandisk Corporation | Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM |
US5907856A (en) * | 1995-07-31 | 1999-05-25 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
US5909586A (en) * | 1996-11-06 | 1999-06-01 | The Foxboro Company | Methods and systems for interfacing with an interface powered I/O device |
US6011322A (en) * | 1997-07-28 | 2000-01-04 | Sony Corporation | Apparatus and method for providing power to circuitry implementing two different power sources |
US6011323A (en) * | 1997-09-30 | 2000-01-04 | International Business Machines Corporation | Apparatus, method and article of manufacture providing for auxiliary battery conservation in adapters |
US6018265A (en) * | 1997-12-10 | 2000-01-25 | Lexar Media, Inc. | Internal CMOS reference generator and voltage regulator |
US6021408A (en) * | 1996-09-12 | 2000-02-01 | Veritas Software Corp. | Methods for operating a log device |
US6034897A (en) * | 1999-04-01 | 2000-03-07 | Lexar Media, Inc. | Space management for managing high capacity nonvolatile memory |
US6035357A (en) * | 1996-06-07 | 2000-03-07 | Kabushiki Kaisha Toshiba | IC card compatible with different supply voltages, IC card system comprising the same, and IC for the IC card |
US6040997A (en) * | 1998-03-25 | 2000-03-21 | Lexar Media, Inc. | Flash memory leveling architecture having no external latch |
US6041001A (en) * | 1999-02-25 | 2000-03-21 | Lexar Media, Inc. | Method of increasing data reliability of a flash memory device without compromising compatibility |
US6047352A (en) * | 1996-10-29 | 2000-04-04 | Micron Technology, Inc. | Memory system, method and predecoding circuit operable in different modes for selectively accessing multiple blocks of memory cells for simultaneous writing or erasure |
US6055188A (en) * | 1997-04-30 | 2000-04-25 | Kabushiki Kaishi Toshiba | Nonvolatile semiconductor memory device having a data circuit for erasing and writing operations |
US6055184A (en) * | 1998-09-02 | 2000-04-25 | Texas Instruments Incorporated | Semiconductor memory device having programmable parallel erase operation |
US6069827A (en) * | 1995-09-27 | 2000-05-30 | Memory Corporation Plc | Memory system |
US6076137A (en) * | 1997-12-11 | 2000-06-13 | Lexar Media, Inc. | Method and apparatus for storing location identification information within non-volatile memory devices |
US6181118B1 (en) * | 1999-06-24 | 2001-01-30 | Analog Devices, Inc. | Control circuit for controlling a semi-conductor switch for selectively outputting an output voltage at two voltage levels |
US6182162B1 (en) * | 1998-03-02 | 2001-01-30 | Lexar Media, Inc. | Externally coupled compact flash memory card that configures itself one of a plurality of appropriate operating protocol modes of a host computer |
US6202138B1 (en) * | 1995-07-31 | 2001-03-13 | Lexar Media, Inc | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6223308B1 (en) * | 1995-07-31 | 2001-04-24 | Lexar Media, Inc. | Identification and verification of a sector within a block of mass STO rage flash memory |
US6226708B1 (en) * | 1997-08-18 | 2001-05-01 | Texas Instruments Incorporated | Method and system for efficiently programming non-volatile memory |
US6230234B1 (en) * | 1995-07-31 | 2001-05-08 | Lexar Media, Inc. | Direct logical block addressing flash memory mass storage architecture |
US6345367B1 (en) * | 1996-07-11 | 2002-02-05 | Memory Corporation Plc | Defective memory block handling system by addressing a group of memory blocks for erasure and changing the content therewith |
US6411546B1 (en) * | 1997-03-31 | 2002-06-25 | Lexar Media, Inc. | Nonvolatile memory using flexible erasing methods and method and system for using same |
US20030033471A1 (en) * | 2001-08-07 | 2003-02-13 | Chun-Hung Lin | Window-based flash memory storage system and management and access methods thereof |
US6567307B1 (en) * | 2000-07-21 | 2003-05-20 | Lexar Media, Inc. | Block management for mass storage |
US6578127B1 (en) * | 1996-04-02 | 2003-06-10 | Lexar Media, Inc. | Memory devices |
US6711059B2 (en) * | 2001-09-28 | 2004-03-23 | Lexar Media, Inc. | Memory controller |
US6721819B2 (en) * | 1998-03-02 | 2004-04-13 | Lexar Media, Inc. | Flash memory card with enhanced operating mode detection and user-friendly interfacing system |
US6721843B1 (en) * | 2000-07-07 | 2004-04-13 | Lexar Media, Inc. | Flash memory architecture implementing simultaneously programmable multiple flash memory banks that are host compatible |
US6725321B1 (en) * | 1999-02-17 | 2004-04-20 | Lexar Media, Inc. | Memory system |
US6728851B1 (en) * | 1995-07-31 | 2004-04-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6751155B2 (en) * | 2001-09-28 | 2004-06-15 | Lexar Media, Inc. | Non-volatile memory control |
US6898662B2 (en) * | 2001-09-28 | 2005-05-24 | Lexar Media, Inc. | Memory system sectors |
US7000064B2 (en) * | 2001-09-28 | 2006-02-14 | Lexar Media, Inc. | Data handling system |
Family Cites Families (169)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS52130536A (en) | 1976-04-26 | 1977-11-01 | Toshiba Corp | Semiconductor memory unit |
US4099069A (en) | 1976-10-08 | 1978-07-04 | Westinghouse Electric Corp. | Circuit producing a common clear signal for erasing selected arrays in a mnos memory system |
US4398248A (en) | 1980-10-20 | 1983-08-09 | Mcdonnell Douglas Corporation | Adaptive WSI/MNOS solid state memory system |
US4210959A (en) | 1978-05-10 | 1980-07-01 | Apple Computer, Inc. | Controller for magnetic disc, recorder, or the like |
FR2426938A1 (en) * | 1978-05-26 | 1979-12-21 | Cii Honeywell Bull | DEVICE FOR DETECTION OF DEFECTIVE SECTORS AND ALLOCATION OF REPLACEMENT SECTORS IN A DISK MEMORY |
JPS559260A (en) | 1978-07-03 | 1980-01-23 | Nec Corp | Information processing system |
US4532590A (en) | 1980-04-25 | 1985-07-30 | Data General Corporation | Data processing system having a unique address translation unit |
US4355376A (en) | 1980-09-30 | 1982-10-19 | Burroughs Corporation | Apparatus and method for utilizing partially defective memory devices |
JPS5764383A (en) * | 1980-10-03 | 1982-04-19 | Toshiba Corp | Address converting method and its device |
US4473878A (en) | 1981-11-23 | 1984-09-25 | Motorola, Inc. | Memory management unit |
US4468730A (en) | 1981-11-27 | 1984-08-28 | Storage Technology Corporation | Detection of sequential data stream for improvements in cache data storage |
US4476526A (en) | 1981-11-27 | 1984-10-09 | Storage Technology Corporation | Cache buffered memory subsystem |
JPS58215795A (en) * | 1982-06-08 | 1983-12-15 | Toshiba Corp | Non-volatile memory device |
JPS58215794A (en) * | 1982-06-08 | 1983-12-15 | Toshiba Corp | Non-volatile memory device |
JPS5945695A (en) * | 1982-09-07 | 1984-03-14 | Fujitsu Ltd | Ic memory |
US4710871A (en) * | 1982-11-01 | 1987-12-01 | Ncr Corporation | Data transmitting and receiving apparatus |
AU557723B2 (en) * | 1982-12-17 | 1987-01-08 | Blue Circle Southern Cement Ltd. | Electronic memory system |
JPS59162695A (en) * | 1983-03-07 | 1984-09-13 | Nec Corp | Storage device |
US4609833A (en) | 1983-08-12 | 1986-09-02 | Thomson Components-Mostek Corporation | Simple NMOS voltage reference circuit |
JPS60212900A (en) * | 1984-04-09 | 1985-10-25 | Nec Corp | Semiconductor fixed memory |
JPS618798A (en) | 1984-06-21 | 1986-01-16 | Nec Corp | Nonvolatile storage device |
JPS6180597A (en) | 1984-09-26 | 1986-04-24 | Hitachi Ltd | Semiconductor memory device |
JPS6196598A (en) * | 1984-10-17 | 1986-05-15 | Fuji Electric Co Ltd | Count data memory method of electric erasable p-rom |
JPS61208673A (en) * | 1985-03-12 | 1986-09-17 | Matsushita Electric Ind Co Ltd | Information recording and reproducing device |
JPS62102482A (en) * | 1985-10-28 | 1987-05-12 | Matsushita Electric Ind Co Ltd | Information recording and reproducing device |
US4757474A (en) * | 1986-01-28 | 1988-07-12 | Fujitsu Limited | Semiconductor memory device having redundancy circuit portion |
JP2685173B2 (en) * | 1986-05-31 | 1997-12-03 | キヤノン株式会社 | Memory write control method |
JPH07109717B2 (en) * | 1986-05-31 | 1995-11-22 | キヤノン株式会社 | Memory write control method |
SU1388877A1 (en) | 1986-09-16 | 1988-04-15 | Таганрогский радиотехнический институт им.В.Д.Калмыкова | Device for addressing storage units |
SU1408439A1 (en) | 1986-10-20 | 1988-07-07 | Предприятие П/Я В-2129 | Addressing device for automatic configuration of computer memory |
US4953122A (en) * | 1986-10-31 | 1990-08-28 | Laserdrive Ltd. | Pseudo-erasable and rewritable write-once optical disk memory system |
JPS63183700A (en) * | 1987-01-26 | 1988-07-29 | Mitsubishi Electric Corp | Eeprom access method |
JPS6473430A (en) | 1987-09-14 | 1989-03-17 | Hudson Soft Co Ltd | Memory access control device |
JPH081760B2 (en) | 1987-11-17 | 1996-01-10 | 三菱電機株式会社 | Semiconductor memory device |
JPH01137817A (en) | 1987-11-25 | 1989-05-30 | Toshiba Corp | Delay circuit |
SU1515164A1 (en) | 1988-01-12 | 1989-10-15 | Предприятие П/Я Г-4493 | Device for addressing a memory |
SU1541619A1 (en) | 1988-05-30 | 1990-02-07 | Предприятие П/Я Г-4173 | Device for shaping address |
US5268319A (en) | 1988-06-08 | 1993-12-07 | Eliyahou Harari | Highly compact EPROM and flash EEPROM devices |
US5198380A (en) | 1988-06-08 | 1993-03-30 | Sundisk Corporation | Method of highly compact EPROM and flash EEPROM devices |
US5268318A (en) | 1988-06-08 | 1993-12-07 | Eliyahou Harari | Highly compact EPROM and flash EEPROM devices |
US5168465A (en) | 1988-06-08 | 1992-12-01 | Eliyahou Harari | Highly compact EPROM and flash EEPROM devices |
US5070474A (en) * | 1988-07-26 | 1991-12-03 | Disk Emulation Systems, Inc. | Disk emulation system |
US5253351A (en) | 1988-08-11 | 1993-10-12 | Hitachi, Ltd. | Memory controller with a cache memory and control method of cache memory including steps of determining memory access threshold values |
SU1573458A2 (en) | 1988-09-26 | 1990-06-23 | Войсковая Часть 32103 | Addressing device |
US5535328A (en) | 1989-04-13 | 1996-07-09 | Sandisk Corporation | Non-volatile memory system card with flash erasable sectors of EEprom cells including a mechanism for substituting defective cells |
US5226168A (en) * | 1989-04-25 | 1993-07-06 | Seiko Epson Corporation | Semiconductor memory configured to emulate floppy and hard disk magnetic storage based upon a determined storage capacity of the semiconductor memory |
SU1686449A2 (en) | 1989-10-23 | 1991-10-23 | Войсковая Часть 32103 | Addressing device |
US5247658A (en) | 1989-10-31 | 1993-09-21 | Microsoft Corporation | Method and system for traversing linked list record based upon write-once predetermined bit value of secondary pointers |
US5218695A (en) | 1990-02-05 | 1993-06-08 | Epoch Systems, Inc. | File server system having high-speed write execution |
DE69021732T2 (en) * | 1990-12-04 | 1996-01-18 | Hewlett Packard Ltd | Reprogrammable data storage system. |
JPH04216392A (en) | 1990-12-18 | 1992-08-06 | Mitsubishi Electric Corp | Semiconductor storage device provided with block write function |
GB2251324B (en) * | 1990-12-31 | 1995-05-10 | Intel Corp | File structure for a non-volatile semiconductor memory |
GB2251323B (en) | 1990-12-31 | 1994-10-12 | Intel Corp | Disk emulation for a non-volatile semiconductor memory |
US5270979A (en) | 1991-03-15 | 1993-12-14 | Sundisk Corporation | Method for optimum erasing of EEPROM |
US5663901A (en) | 1991-04-11 | 1997-09-02 | Sandisk Corporation | Computer memory cards using flash EEPROM integrated circuit chips and memory-controller systems |
JPH04332999A (en) * | 1991-05-07 | 1992-11-19 | Hitachi Koki Co Ltd | Method of using memory |
US5428758A (en) * | 1991-05-10 | 1995-06-27 | Unisys Corporation | Method and system for remapping memory from one physical configuration to another physical configuration |
US5430859A (en) * | 1991-07-26 | 1995-07-04 | Sundisk Corporation | Solid state memory system including plural memory chips and a serialized bus |
EP0528280B1 (en) | 1991-08-09 | 1997-11-12 | Kabushiki Kaisha Toshiba | Memory card apparatus |
JP3229345B2 (en) | 1991-09-11 | 2001-11-19 | ローム株式会社 | Non-volatile IC memory |
US6230233B1 (en) | 1991-09-13 | 2001-05-08 | Sandisk Corporation | Wear leveling techniques for flash EEPROM systems |
US5438573A (en) | 1991-09-13 | 1995-08-01 | Sundisk Corporation | Flash EEPROM array data and header file structure |
US5778418A (en) | 1991-09-27 | 1998-07-07 | Sandisk Corporation | Mass computer storage system having both solid state and rotating disk types of memory |
US5227714A (en) | 1991-10-07 | 1993-07-13 | Brooktree Corporation | Voltage regulator |
US5359569A (en) | 1991-10-29 | 1994-10-25 | Hitachi Ltd. | Semiconductor memory |
JPH05151097A (en) * | 1991-11-28 | 1993-06-18 | Fujitsu Ltd | Data control system for rewriting frequency limited type memory |
JPH05233426A (en) | 1992-02-20 | 1993-09-10 | Fujitsu Ltd | Flash memory using method |
EP0559213B1 (en) | 1992-03-05 | 1999-09-15 | Kabushiki Kaisha Toshiba | Nonvolatile semiconductor memory device |
TW231343B (en) | 1992-03-17 | 1994-10-01 | Hitachi Seisakusyo Kk | |
JP2830594B2 (en) | 1992-03-26 | 1998-12-02 | 日本電気株式会社 | Semiconductor memory device |
US5267218A (en) | 1992-03-31 | 1993-11-30 | Intel Corporation | Nonvolatile memory card with a single power supply input |
US5532962A (en) | 1992-05-20 | 1996-07-02 | Sandisk Corporation | Soft errors handling in EEPROM devices |
US5381539A (en) | 1992-06-04 | 1995-01-10 | Emc Corporation | System and method for dynamically controlling cache management |
DE4219145C1 (en) | 1992-06-11 | 1994-03-17 | Emitec Emissionstechnologie | Method and device for soldering a metallic honeycomb body |
JPH06103748A (en) | 1992-09-16 | 1994-04-15 | Mitsubishi Electric Corp | Power control circuit for ic memory card |
JP3105092B2 (en) | 1992-10-06 | 2000-10-30 | 株式会社東芝 | Semiconductor memory device |
US5341330A (en) * | 1992-10-30 | 1994-08-23 | Intel Corporation | Method for writing to a flash memory array during erase suspend intervals |
US5357475A (en) * | 1992-10-30 | 1994-10-18 | Intel Corporation | Method for detaching sectors in a flash EEPROM memory array |
US5341339A (en) * | 1992-10-30 | 1994-08-23 | Intel Corporation | Method for wear leveling in a flash EEPROM memory |
US5822781A (en) | 1992-10-30 | 1998-10-13 | Intel Corporation | Sector-based storage device emulator having variable-sized sector |
US5337275A (en) * | 1992-10-30 | 1994-08-09 | Intel Corporation | Method for releasing space in flash EEPROM memory array to allow the storage of compressed data |
JPH06236686A (en) | 1993-01-22 | 1994-08-23 | Nec Corp | Semiconductor device |
US5581723A (en) * | 1993-02-19 | 1996-12-03 | Intel Corporation | Method and apparatus for retaining flash block structure data during erase operations in a flash EEPROM memory array |
EP0613151A3 (en) | 1993-02-26 | 1995-03-22 | Tokyo Shibaura Electric Co | Semiconductor memory system including a flash EEPROM. |
JPH06266596A (en) | 1993-03-11 | 1994-09-22 | Hitachi Ltd | Flash memory file storage device and information processor |
US5479638A (en) * | 1993-03-26 | 1995-12-26 | Cirrus Logic, Inc. | Flash memory mass storage architecture incorporation wear leveling technique |
JP3330187B2 (en) | 1993-05-13 | 2002-09-30 | 株式会社リコー | Memory card |
US5353256A (en) * | 1993-06-30 | 1994-10-04 | Intel Corporation | Block specific status information in a memory device |
US5329491A (en) | 1993-06-30 | 1994-07-12 | Intel Corporation | Nonvolatile memory card with automatic power supply configuration |
US5519847A (en) | 1993-06-30 | 1996-05-21 | Intel Corporation | Method of pipelining sequential writes in a flash memory |
JP3228377B2 (en) | 1993-07-19 | 2001-11-12 | 東京電力株式会社 | Molten carbonate fuel cell cathode and method for suppressing its dissolution |
US5465338A (en) | 1993-08-24 | 1995-11-07 | Conner Peripherals, Inc. | Disk drive system interface architecture employing state machines |
US5566314A (en) * | 1993-08-30 | 1996-10-15 | Lucent Technologies Inc. | Flash memory device employing unused cell arrays to update files |
JP2922116B2 (en) | 1993-09-02 | 1999-07-19 | 株式会社東芝 | Semiconductor storage device |
JP3215237B2 (en) | 1993-10-01 | 2001-10-02 | 富士通株式会社 | Storage device and method for writing / erasing storage device |
US5365127A (en) | 1993-10-18 | 1994-11-15 | Hewlett-Packard Company | Circuit for conversion from CMOS voltage levels to shifted ECL voltage levels with process compensation |
JPH07235193A (en) | 1993-12-28 | 1995-09-05 | Toshiba Corp | Semiconductor memory |
DE69428881T2 (en) | 1994-01-12 | 2002-07-18 | Sun Microsystems, Inc. | Logically addressable physical memory for a computer system with virtual memory that supports multiple page sizes |
US5473765A (en) | 1994-01-24 | 1995-12-05 | 3Com Corporation | Apparatus for using flash memory as a floppy disk emulator in a computer system |
US6026027A (en) | 1994-01-31 | 2000-02-15 | Norand Corporation | Flash memory system having memory cache |
US5661053A (en) | 1994-05-25 | 1997-08-26 | Sandisk Corporation | Method of making dense flash EEPROM cell array and peripheral supporting circuits formed in deposited field oxide with the use of spacers |
US5809558A (en) | 1994-09-29 | 1998-09-15 | Intel Corporation | Method and data storage system for storing data in blocks without file reallocation before erasure |
US5508971A (en) | 1994-10-17 | 1996-04-16 | Sandisk Corporation | Programmable power generation circuit for flash EEPROM memory systems |
JP2669365B2 (en) | 1994-11-24 | 1997-10-27 | 日本電気株式会社 | Rewritable ROM file device |
US5541551A (en) | 1994-12-23 | 1996-07-30 | Advinced Micro Devices, Inc. | Analog voltage reference generator system |
US5847552A (en) | 1995-01-24 | 1998-12-08 | Dell Usa, L.P. | Integrated circuit with determinate power source control |
JPH08212019A (en) | 1995-01-31 | 1996-08-20 | Mitsubishi Electric Corp | Semiconductor disk device |
JPH08263361A (en) | 1995-03-23 | 1996-10-11 | Mitsubishi Electric Corp | Flash memory card |
US5818350A (en) | 1995-04-11 | 1998-10-06 | Lexar Microsystems Inc. | High performance method of and system for selecting one of a plurality of IC chip while requiring minimal select lines |
JP4254994B2 (en) | 1995-05-29 | 2009-04-15 | 株式会社日立製作所 | Analytical equipment using a disposable reaction vessel |
US6072796A (en) | 1995-06-14 | 2000-06-06 | Avid Technology, Inc. | Apparatus and method for accessing memory in a TDM network |
US5552698A (en) | 1995-06-29 | 1996-09-03 | United Microelectronics Corp. | Voltage supply system for IC chips |
US6757800B1 (en) | 1995-07-31 | 2004-06-29 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US5930815A (en) | 1995-07-31 | 1999-07-27 | Lexar Media, Inc. | Moving sequential sectors within a block of information in a flash memory mass storage architecture |
US6978342B1 (en) | 1995-07-31 | 2005-12-20 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
JPH0954726A (en) | 1995-08-18 | 1997-02-25 | Mitsubishi Electric Corp | Memory device |
US6125435A (en) | 1995-09-13 | 2000-09-26 | Lexar Media, Inc. | Alignment of cluster address to block addresses within a semiconductor non-volatile mass storage memory |
US5835935A (en) | 1995-09-13 | 1998-11-10 | Lexar Media, Inc. | Method of and architecture for controlling system data with automatic wear leveling in a semiconductor non-volatile mass storage memory |
GB2291990A (en) | 1995-09-27 | 1996-02-07 | Memory Corp Plc | Flash-memory management system |
US5809560A (en) | 1995-10-13 | 1998-09-15 | Compaq Computer Corporation | Adaptive read-ahead disk cache |
CN1202255A (en) | 1995-11-13 | 1998-12-16 | 勒克萨微型系统股份有限公司 | Automatic voltage detection in multiple voltage applications |
KR100253868B1 (en) | 1995-11-13 | 2000-05-01 | 니시무로 타이죠 | Non-volatile semiconductor memory device |
US5799168A (en) | 1996-01-05 | 1998-08-25 | M-Systems Flash Disk Pioneers Ltd. | Standardized flash controller |
JPH09212411A (en) | 1996-02-06 | 1997-08-15 | Tokyo Electron Ltd | Memory system |
US5724303A (en) | 1996-02-15 | 1998-03-03 | Nexcom Technology, Inc. | Non-volatile programmable memory having an SRAM capability |
US5787445A (en) | 1996-03-07 | 1998-07-28 | Norris Communications Corporation | Operating system including improved file management for use in devices utilizing flash memory as main memory |
US5822252A (en) | 1996-03-29 | 1998-10-13 | Aplus Integrated Circuits, Inc. | Flash memory wordline decoder with overerase repair |
GB9606927D0 (en) | 1996-04-02 | 1996-06-05 | Memory Corp Plc | Data storage devices |
US5991849A (en) | 1996-04-10 | 1999-11-23 | Sanyo Electric Co., Ltd | Rewriting protection of a size varying first region of a reprogrammable non-volatile memory |
GB9609301D0 (en) | 1996-05-03 | 1996-07-10 | Wallace & Tiernan Ltd | Measuring chlorine concentration |
GB9609833D0 (en) | 1996-05-10 | 1996-07-17 | Memory Corp Plc | Memory device |
US5959926A (en) | 1996-06-07 | 1999-09-28 | Dallas Semiconductor Corp. | Programmable power supply systems and methods providing a write protected memory having multiple interface capability |
GB9613088D0 (en) | 1996-06-21 | 1996-08-28 | Memory Corp Plc | Memory device |
JP3761635B2 (en) | 1996-07-12 | 2006-03-29 | 株式会社ダックス | Memory board, memory access method, and memory access device |
US5787484A (en) | 1996-08-08 | 1998-07-28 | Micron Technology, Inc. | System and method which compares data preread from memory cells to data to be written to the cells |
US5920884A (en) | 1996-09-24 | 1999-07-06 | Hyundai Electronics America, Inc. | Nonvolatile memory interface protocol which selects a memory device, transmits an address, deselects the device, subsequently reselects the device and accesses data |
US5956473A (en) | 1996-11-25 | 1999-09-21 | Macronix International Co., Ltd. | Method and system for managing a flash memory mass storage system |
US5745418A (en) | 1996-11-25 | 1998-04-28 | Macronix International Co., Ltd. | Flash memory mass storage system |
JPH10177797A (en) | 1996-12-17 | 1998-06-30 | Toshiba Corp | Semiconductor memory |
JPH10187505A (en) | 1996-12-24 | 1998-07-21 | Toshiba Corp | Information storage system and data arranging method applied to the system |
US6279069B1 (en) | 1996-12-26 | 2001-08-21 | Intel Corporation | Interface for flash EEPROM memory arrays |
US5901086A (en) | 1996-12-26 | 1999-05-04 | Motorola, Inc. | Pipelined fast-access floating gate memory architecture and method of operation |
US5928370A (en) | 1997-02-05 | 1999-07-27 | Lexar Media, Inc. | Method and apparatus for verifying erasure of memory blocks within a non-volatile memory structure |
US5822245A (en) | 1997-03-26 | 1998-10-13 | Atmel Corporation | Dual buffer flash memory architecture with multiple operating modes |
US6122195A (en) | 1997-03-31 | 2000-09-19 | Lexar Media, Inc. | Method and apparatus for decreasing block write operation times performed on nonvolatile memory |
US5953737A (en) | 1997-03-31 | 1999-09-14 | Lexar Media, Inc. | Method and apparatus for performing erase operations transparent to a solid state storage system |
US5831929A (en) | 1997-04-04 | 1998-11-03 | Micron Technology, Inc. | Memory device with staggered data paths |
EP1046078B1 (en) | 1997-10-08 | 2004-05-12 | Hewlett-Packard Company, A Delaware Corporation | Liquid crystal device alignment and method of making such a device |
US5937425A (en) | 1997-10-16 | 1999-08-10 | M-Systems Flash Disk Pioneers Ltd. | Flash file system optimized for page-mode flash technologies |
JPH11224492A (en) | 1997-11-06 | 1999-08-17 | Toshiba Corp | Semiconductor memory, non-volatile semiconductor memory, and flash memory |
GB9801373D0 (en) | 1998-01-22 | 1998-03-18 | Memory Corp Plc | Memory system |
US5969986A (en) | 1998-06-23 | 1999-10-19 | Invox Technology | High-bandwidth read and write architectures for non-volatile memories |
GB9806687D0 (en) | 1998-03-27 | 1998-05-27 | Memory Corp Plc | Memory system |
US6279114B1 (en) | 1998-11-04 | 2001-08-21 | Sandisk Corporation | Voltage negotiation in a single host multiple cards system |
US6490649B2 (en) | 1998-11-10 | 2002-12-03 | Lexar Media, Inc. | Memory device |
WO2000030116A1 (en) | 1998-11-17 | 2000-05-25 | Lexar Media, Inc. | Method and apparatus for memory control circuit |
US6084483A (en) | 1999-03-10 | 2000-07-04 | Lexar Media, Inc. | Internal oscillator circuit including a ring oscillator controlled by a voltage regulator circuit |
WO2000060605A1 (en) | 1999-04-01 | 2000-10-12 | Lexar Media, Inc. | Space management for managing high capacity nonvolatile memory |
US6141249A (en) | 1999-04-01 | 2000-10-31 | Lexar Media, Inc. | Organization of blocks within a nonvolatile memory unit to effectively decrease sector write operation time |
JP4268284B2 (en) | 1999-09-20 | 2009-05-27 | 積水化学工業株式会社 | Photocurable resin composition, liquid crystal inlet sealing agent and liquid crystal display cell |
AU780771B2 (en) | 1999-12-21 | 2005-04-14 | Teva Pharmaceutical Industries Ltd. | Novel sertraline hydrochloride polymorphs, processes for preparing them, compositions containing them and methods of using them |
JP4332999B2 (en) | 2000-06-08 | 2009-09-16 | 株式会社デンソー | Quiz game device and navigation device with quiz game function |
US6772274B1 (en) | 2000-09-13 | 2004-08-03 | Lexar Media, Inc. | Flash memory system and method implementing LBA to PBA correlation within flash memory array |
GB2411499B (en) | 2001-09-28 | 2006-02-08 | Lexar Media Inc | Method of writing data to non-volatile memory |
GB0123415D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Method of writing data to non-volatile memory |
GB0123410D0 (en) | 2001-09-28 | 2001-11-21 | Memquest Ltd | Memory system for data storage and retrieval |
US6957295B1 (en) | 2002-01-18 | 2005-10-18 | Lexar Media, Inc. | File management of one-time-programmable nonvolatile memory devices |
US6950918B1 (en) | 2002-01-18 | 2005-09-27 | Lexar Media, Inc. | File management of one-time-programmable nonvolatile memory devices |
US6973519B1 (en) | 2003-06-03 | 2005-12-06 | Lexar Media, Inc. | Card identification compatibility |
-
1995
- 1995-07-31 US US08/509,706 patent/US5845313A/en not_active Expired - Lifetime
-
1998
- 1998-05-29 US US09/087,720 patent/US5924113A/en not_active Expired - Lifetime
-
1999
- 1999-05-13 US US09/311,045 patent/US6115785A/en not_active Expired - Lifetime
-
2000
- 2000-03-08 US US09/521,420 patent/US6230234B1/en not_active Expired - Lifetime
-
2001
- 2001-05-07 US US09/850,790 patent/US6912618B2/en not_active Expired - Fee Related
-
2005
- 2005-06-24 US US11/165,864 patent/US7523249B1/en not_active Expired - Fee Related
-
2009
- 2009-04-20 US US12/426,662 patent/US7774576B2/en not_active Expired - Fee Related
-
2010
- 2010-07-27 US US12/844,354 patent/US8032694B2/en not_active Expired - Fee Related
Patent Citations (99)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US34881A (en) * | 1862-04-08 | Improved arrastra | ||
US4309627A (en) * | 1978-04-14 | 1982-01-05 | Kabushiki Kaisha Daini Seikosha | Detecting circuit for a power source voltage |
US4456971A (en) * | 1981-02-09 | 1984-06-26 | Sony Corporation | Semiconductor RAM that is accessible in magnetic disc storage format |
US4525839A (en) * | 1981-10-30 | 1985-06-25 | Hitachi, Ltd. | Method of controlling storage device |
US4450559A (en) * | 1981-12-24 | 1984-05-22 | International Business Machines Corporation | Memory system with selective assignment of spare locations |
US4498146A (en) * | 1982-07-30 | 1985-02-05 | At&T Bell Laboratories | Management of defects in storage media |
US4896262A (en) * | 1984-02-24 | 1990-01-23 | Kabushiki Kaisha Meidensha | Emulation device for converting magnetic disc memory mode signal from computer into semiconductor memory access mode signal for semiconductor memory |
US4654847A (en) * | 1984-12-28 | 1987-03-31 | International Business Machines | Apparatus for automatically correcting erroneous data and for storing the corrected data in a common pool alternate memory array |
US4920518A (en) * | 1985-04-23 | 1990-04-24 | Hitachi, Ltd. | Semiconductor integrated circuit with nonvolatile memory |
US4829169A (en) * | 1985-07-01 | 1989-05-09 | Toppan Moore Company, Inc. | IC card having state marker for record access |
US4797543A (en) * | 1985-07-31 | 1989-01-10 | 501 Toppan Moore Company, Ltd. | Selectable data readout IC card |
US4800520A (en) * | 1985-10-29 | 1989-01-24 | Kabushiki Kaisha Toshiba | Portable electronic device with garbage collection function |
US4748320A (en) * | 1985-10-29 | 1988-05-31 | Toppan Printing Co., Ltd. | IC card |
US4924331A (en) * | 1985-11-20 | 1990-05-08 | Seagate Technology, Inc. | Method for mapping around defective sectors in a disc drive |
US4746998A (en) * | 1985-11-20 | 1988-05-24 | Seagate Technology, Inc. | Method for mapping around defective sectors in a disc drive |
US5093785A (en) * | 1985-11-30 | 1992-03-03 | Kabushiki Kaisha Toshiba | Portable electronic device with memory having data pointers and circuitry for determining whether a next unwritten memory location exist |
US4843224A (en) * | 1987-06-12 | 1989-06-27 | Oki Electric Industry Co., Ltd. | IC card |
US5293560A (en) * | 1988-06-08 | 1994-03-08 | Eliyahou Harari | Multi-state flash EEPROM system using incremental programing and erasing methods |
US5642312A (en) * | 1988-06-08 | 1997-06-24 | Harari; Eliyahou | Flash EEPROM system cell array with more than two storage states per memory cell |
US4914529A (en) * | 1988-07-18 | 1990-04-03 | Western Digital Corp. | Data disk defect handling using relocation ID fields |
US5719808A (en) * | 1989-04-13 | 1998-02-17 | Sandisk Corporation | Flash EEPROM system |
US5418752A (en) * | 1989-04-13 | 1995-05-23 | Sundisk Corporation | Flash EEPROM system with erase sector select |
US5297148A (en) * | 1989-04-13 | 1994-03-22 | Sundisk Corporation | Flash eeprom system |
US5602987A (en) * | 1989-04-13 | 1997-02-11 | Sandisk Corporation | Flash EEprom system |
US5200959A (en) * | 1989-10-17 | 1993-04-06 | Sundisk Corporation | Device and method for defect handling in semi-conductor memory |
US5220518A (en) * | 1990-06-07 | 1993-06-15 | Vlsi Technology, Inc. | Integrated circuit memory with non-binary array configuration |
US5303198A (en) * | 1990-09-28 | 1994-04-12 | Fuji Photo Film Co., Ltd. | Method of recording data in memory card having EEPROM and memory card system using the same |
US5504760A (en) * | 1991-03-15 | 1996-04-02 | Sandisk Corporation | Mixed data encoding EEPROM system |
US5396468A (en) * | 1991-03-15 | 1995-03-07 | Sundisk Corporation | Streamlined write operation for EEPROM system |
US5524230A (en) * | 1991-07-12 | 1996-06-04 | International Business Machines Incorporated | External information storage system with a semiconductor memory |
US5768190A (en) * | 1991-09-24 | 1998-06-16 | Kabushiki Kaisha Toshiba | Electrically erasable and programmable non-volatile semiconductor memory with automatic write-verify controller |
US5640528A (en) * | 1991-10-24 | 1997-06-17 | Intel Corporation | Method and apparatus for translating addresses using mask and replacement value registers |
US5315558A (en) * | 1991-10-25 | 1994-05-24 | Vlsi Technology, Inc. | Integrated circuit memory with non-binary array configuration |
US5382539A (en) * | 1991-10-31 | 1995-01-17 | Rohm Co., Ltd. | Method for manufacturing a semiconductor device including nonvolatile memories |
US5530938A (en) * | 1992-02-05 | 1996-06-25 | Seiko Instruments Inc. | Non-volatile memory card device having flash EEPROM memory chips with designated spare memory chips and the method of rewriting data into the memory card device |
US5384743A (en) * | 1992-03-06 | 1995-01-24 | Sgs-Thomson Microelectronics, S.A. | Structure and method for flash eprom memory erasable by sectors |
US5611067A (en) * | 1992-03-31 | 1997-03-11 | Kabushiki Kaisha Toshiba | Nonvolatile semiconductor memory device having means for selective transfer of memory block contents and for chaining together unused memory blocks |
US5530828A (en) * | 1992-06-22 | 1996-06-25 | Hitachi, Ltd. | Semiconductor storage device including a controller for continuously writing data to and erasing data from a plurality of flash memories |
US5406527A (en) * | 1992-06-26 | 1995-04-11 | Kabushiki Kaisha Toshiba | Partial write transferable multiport memory |
US5592415A (en) * | 1992-07-06 | 1997-01-07 | Hitachi, Ltd. | Non-volatile semiconductor memory |
US5315541A (en) * | 1992-07-24 | 1994-05-24 | Sundisk Corporation | Segmented column memory array |
US5508975A (en) * | 1992-08-25 | 1996-04-16 | Industrial Sound Technologies, Inc. | Apparatus for degassing liquids |
US5428621A (en) * | 1992-09-21 | 1995-06-27 | Sundisk Corporation | Latent defect handling in EEPROM devices |
US5734567A (en) * | 1992-11-06 | 1998-03-31 | Siemens Aktiengesellschaft | Diagnosis system for a plant |
US5598370A (en) * | 1993-02-24 | 1997-01-28 | International Business Machines Corporation | Nonvolatile memory with cluster-erase flash capability and solid state file apparatus using the same |
US5422856A (en) * | 1993-03-04 | 1995-06-06 | Hitachi, Ltd. | Non-volatile memory programming at arbitrary timing based on current requirements |
US5404485A (en) * | 1993-03-08 | 1995-04-04 | M-Systems Flash Disk Pioneers Ltd. | Flash file system |
US5490117A (en) * | 1993-03-23 | 1996-02-06 | Seiko Epson Corporation | IC card with dual level power supply interface and method for operating the IC card |
US5485595A (en) * | 1993-03-26 | 1996-01-16 | Cirrus Logic, Inc. | Flash memory mass storage architecture incorporating wear leveling technique without using cam cells |
US5388083A (en) * | 1993-03-26 | 1995-02-07 | Cirrus Logic, Inc. | Flash memory mass storage architecture |
US5530673A (en) * | 1993-04-08 | 1996-06-25 | Hitachi, Ltd. | Flash memory control method and information processing system therewith |
US5495442A (en) * | 1993-07-08 | 1996-02-27 | Sandisk Corporation | Method and circuit for simultaneously programming and verifying the programming of selected EEPROM cells |
US5768195A (en) * | 1993-09-24 | 1998-06-16 | Kabushiki Kaisha Toshiba | Semiconductor memory device |
US5603001A (en) * | 1994-05-09 | 1997-02-11 | Kabushiki Kaisha Toshiba | Semiconductor disk system having a plurality of flash memories |
US5606660A (en) * | 1994-10-21 | 1997-02-25 | Lexar Microsystems, Inc. | Method and apparatus for combining controller firmware storage and controller logic in a mass storage system |
US5723990A (en) * | 1995-06-21 | 1998-03-03 | Micron Quantum Devices, Inc. | Integrated circuit having high voltage detection circuit |
US5773901A (en) * | 1995-07-21 | 1998-06-30 | Kantner; Edward A. | Universal PC card host |
US6223308B1 (en) * | 1995-07-31 | 2001-04-24 | Lexar Media, Inc. | Identification and verification of a sector within a block of mass STO rage flash memory |
US6202138B1 (en) * | 1995-07-31 | 2001-03-13 | Lexar Media, Inc | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US6728851B1 (en) * | 1995-07-31 | 2004-04-27 | Lexar Media, Inc. | Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices |
US5907856A (en) * | 1995-07-31 | 1999-05-25 | Lexar Media, Inc. | Moving sectors within a block of information in a flash memory mass storage architecture |
US6230234B1 (en) * | 1995-07-31 | 2001-05-08 | Lexar Media, Inc. | Direct logical block addressing flash memory mass storage architecture |
US5596526A (en) * | 1995-08-15 | 1997-01-21 | Lexar Microsystems, Inc. | Non-volatile memory system of multi-level transistor cells and methods using same |
US5761117A (en) * | 1995-08-31 | 1998-06-02 | Sanyo Electric Co., Ltd. | Non-volatile multi-state memory device with memory cell capable of storing multi-state data |
US6069827A (en) * | 1995-09-27 | 2000-05-30 | Memory Corporation Plc | Memory system |
US6578127B1 (en) * | 1996-04-02 | 2003-06-10 | Lexar Media, Inc. | Memory devices |
US6035357A (en) * | 1996-06-07 | 2000-03-07 | Kabushiki Kaisha Toshiba | IC card compatible with different supply voltages, IC card system comprising the same, and IC for the IC card |
US5758100A (en) * | 1996-07-01 | 1998-05-26 | Sun Microsystems, Inc. | Dual voltage module interconnect |
US6345367B1 (en) * | 1996-07-11 | 2002-02-05 | Memory Corporation Plc | Defective memory block handling system by addressing a group of memory blocks for erasure and changing the content therewith |
US5757712A (en) * | 1996-07-12 | 1998-05-26 | International Business Machines Corporation | Memory modules with voltage regulation and level translation |
US6021408A (en) * | 1996-09-12 | 2000-02-01 | Veritas Software Corp. | Methods for operating a log device |
US5860124A (en) * | 1996-09-30 | 1999-01-12 | Intel Corporation | Method for performing a continuous over-write of a file in nonvolatile memory |
US5754567A (en) * | 1996-10-15 | 1998-05-19 | Micron Quantum Devices, Inc. | Write reduction in flash memory systems through ECC usage |
US6047352A (en) * | 1996-10-29 | 2000-04-04 | Micron Technology, Inc. | Memory system, method and predecoding circuit operable in different modes for selectively accessing multiple blocks of memory cells for simultaneous writing or erasure |
US5890192A (en) * | 1996-11-05 | 1999-03-30 | Sandisk Corporation | Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM |
US5909586A (en) * | 1996-11-06 | 1999-06-01 | The Foxboro Company | Methods and systems for interfacing with an interface powered I/O device |
US5860083A (en) * | 1996-11-26 | 1999-01-12 | Kabushiki Kaisha Toshiba | Data storage system having flash memory and disk drive |
US6411546B1 (en) * | 1997-03-31 | 2002-06-25 | Lexar Media, Inc. | Nonvolatile memory using flexible erasing methods and method and system for using same |
US6055188A (en) * | 1997-04-30 | 2000-04-25 | Kabushiki Kaishi Toshiba | Nonvolatile semiconductor memory device having a data circuit for erasing and writing operations |
US6011322A (en) * | 1997-07-28 | 2000-01-04 | Sony Corporation | Apparatus and method for providing power to circuitry implementing two different power sources |
US6226708B1 (en) * | 1997-08-18 | 2001-05-01 | Texas Instruments Incorporated | Method and system for efficiently programming non-volatile memory |
US6011323A (en) * | 1997-09-30 | 2000-01-04 | International Business Machines Corporation | Apparatus, method and article of manufacture providing for auxiliary battery conservation in adapters |
US6018265A (en) * | 1997-12-10 | 2000-01-25 | Lexar Media, Inc. | Internal CMOS reference generator and voltage regulator |
US6076137A (en) * | 1997-12-11 | 2000-06-13 | Lexar Media, Inc. | Method and apparatus for storing location identification information within non-volatile memory devices |
US6721819B2 (en) * | 1998-03-02 | 2004-04-13 | Lexar Media, Inc. | Flash memory card with enhanced operating mode detection and user-friendly interfacing system |
US6182162B1 (en) * | 1998-03-02 | 2001-01-30 | Lexar Media, Inc. | Externally coupled compact flash memory card that configures itself one of a plurality of appropriate operating protocol modes of a host computer |
US6040997A (en) * | 1998-03-25 | 2000-03-21 | Lexar Media, Inc. | Flash memory leveling architecture having no external latch |
US6055184A (en) * | 1998-09-02 | 2000-04-25 | Texas Instruments Incorporated | Semiconductor memory device having programmable parallel erase operation |
US6725321B1 (en) * | 1999-02-17 | 2004-04-20 | Lexar Media, Inc. | Memory system |
US6041001A (en) * | 1999-02-25 | 2000-03-21 | Lexar Media, Inc. | Method of increasing data reliability of a flash memory device without compromising compatibility |
US6034897A (en) * | 1999-04-01 | 2000-03-07 | Lexar Media, Inc. | Space management for managing high capacity nonvolatile memory |
US6181118B1 (en) * | 1999-06-24 | 2001-01-30 | Analog Devices, Inc. | Control circuit for controlling a semi-conductor switch for selectively outputting an output voltage at two voltage levels |
US6721843B1 (en) * | 2000-07-07 | 2004-04-13 | Lexar Media, Inc. | Flash memory architecture implementing simultaneously programmable multiple flash memory banks that are host compatible |
US6567307B1 (en) * | 2000-07-21 | 2003-05-20 | Lexar Media, Inc. | Block management for mass storage |
US20030033471A1 (en) * | 2001-08-07 | 2003-02-13 | Chun-Hung Lin | Window-based flash memory storage system and management and access methods thereof |
US6711059B2 (en) * | 2001-09-28 | 2004-03-23 | Lexar Media, Inc. | Memory controller |
US6751155B2 (en) * | 2001-09-28 | 2004-06-15 | Lexar Media, Inc. | Non-volatile memory control |
US6898662B2 (en) * | 2001-09-28 | 2005-05-24 | Lexar Media, Inc. | Memory system sectors |
US7000064B2 (en) * | 2001-09-28 | 2006-02-14 | Lexar Media, Inc. | Data handling system |
Cited By (60)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US11640359B2 (en) | 2006-12-06 | 2023-05-02 | Unification Technologies Llc | Systems and methods for identifying storage resources that are not in use |
US8756375B2 (en) | 2006-12-06 | 2014-06-17 | Fusion-Io, Inc. | Non-volatile cache |
US11573909B2 (en) | 2006-12-06 | 2023-02-07 | Unification Technologies Llc | Apparatus, system, and method for managing commands of solid-state storage using bank interleave |
US9454492B2 (en) | 2006-12-06 | 2016-09-27 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for storage parallelism |
US8266496B2 (en) | 2006-12-06 | 2012-09-11 | Fusion-10, Inc. | Apparatus, system, and method for managing data using a data pipeline |
US8285927B2 (en) | 2006-12-06 | 2012-10-09 | Fusion-Io, Inc. | Apparatus, system, and method for solid-state storage as cache for high-capacity, non-volatile storage |
US9495241B2 (en) | 2006-12-06 | 2016-11-15 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for adaptive data storage |
US11960412B2 (en) | 2006-12-06 | 2024-04-16 | Unification Technologies Llc | Systems and methods for identifying storage resources that are not in use |
US8443134B2 (en) | 2006-12-06 | 2013-05-14 | Fusion-Io, Inc. | Apparatus, system, and method for graceful cache device degradation |
US9519594B2 (en) | 2006-12-06 | 2016-12-13 | Sandisk Technologies Llc | Apparatus, system, and method for solid-state storage as cache for high-capacity, non-volatile storage |
US8482993B2 (en) | 2006-12-06 | 2013-07-09 | Fusion-Io, Inc. | Apparatus, system, and method for managing data in a solid-state storage device |
US9575902B2 (en) | 2006-12-06 | 2017-02-21 | Longitude Enterprise Flash S.A.R.L. | Apparatus, system, and method for managing commands of solid-state storage using bank interleave |
US8533569B2 (en) | 2006-12-06 | 2013-09-10 | Fusion-Io, Inc. | Apparatus, system, and method for managing data using a data pipeline |
US11847066B2 (en) | 2006-12-06 | 2023-12-19 | Unification Technologies Llc | Apparatus, system, and method for managing commands of solid-state storage using bank interleave |
US9116823B2 (en) | 2006-12-06 | 2015-08-25 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for adaptive error-correction coding |
US8189407B2 (en) | 2006-12-06 | 2012-05-29 | Fusion-Io, Inc. | Apparatus, system, and method for biasing data in a solid-state storage device |
US9734086B2 (en) | 2006-12-06 | 2017-08-15 | Sandisk Technologies Llc | Apparatus, system, and method for a device shared between multiple independent hosts |
US9824027B2 (en) | 2006-12-06 | 2017-11-21 | Sandisk Technologies Llc | Apparatus, system, and method for a storage area network |
US8706968B2 (en) | 2007-12-06 | 2014-04-22 | Fusion-Io, Inc. | Apparatus, system, and method for redundant write caching |
US9600184B2 (en) | 2007-12-06 | 2017-03-21 | Sandisk Technologies Llc | Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment |
US8489817B2 (en) | 2007-12-06 | 2013-07-16 | Fusion-Io, Inc. | Apparatus, system, and method for caching data |
US9519540B2 (en) | 2007-12-06 | 2016-12-13 | Sandisk Technologies Llc | Apparatus, system, and method for destaging cached data |
US8316277B2 (en) | 2007-12-06 | 2012-11-20 | Fusion-Io, Inc. | Apparatus, system, and method for ensuring data validity in a data storage process |
US9170754B2 (en) | 2007-12-06 | 2015-10-27 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for coordinating storage requests in a multi-processor/multi-thread environment |
US9104599B2 (en) | 2007-12-06 | 2015-08-11 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for destaging cached data |
US8719501B2 (en) | 2009-09-08 | 2014-05-06 | Fusion-Io | Apparatus, system, and method for caching data on a solid-state storage device |
US20110099339A1 (en) * | 2009-10-28 | 2011-04-28 | Canon Kabushiki Kaisha | Information processing apparatus, method for controlling information processing apparatus and storage medium |
US8443167B1 (en) | 2009-12-16 | 2013-05-14 | Western Digital Technologies, Inc. | Data storage device employing a run-length mapping table and a single address mapping table |
US8194340B1 (en) | 2010-03-18 | 2012-06-05 | Western Digital Technologies, Inc. | Disk drive framing write data with in-line mapping data during write operations |
US8194341B1 (en) | 2010-03-18 | 2012-06-05 | Western Digital Technologies, Inc. | Disk drive seeding data path protection with system data seed |
US8693133B1 (en) | 2010-03-22 | 2014-04-08 | Western Digital Technologies, Inc. | Systems and methods for improving sequential data rate performance using sorted data zones for butterfly format |
US8687306B1 (en) | 2010-03-22 | 2014-04-01 | Western Digital Technologies, Inc. | Systems and methods for improving sequential data rate performance using sorted data zones |
US9330715B1 (en) | 2010-03-22 | 2016-05-03 | Western Digital Technologies, Inc. | Mapping of shingled magnetic recording media |
US8902527B1 (en) | 2010-03-22 | 2014-12-02 | Western Digital Technologies, Inc. | Systems and methods for improving sequential data rate performance using sorted data zones |
US8667248B1 (en) | 2010-08-31 | 2014-03-04 | Western Digital Technologies, Inc. | Data storage device using metadata and mapping table to identify valid user data on non-volatile media |
US8954664B1 (en) | 2010-10-01 | 2015-02-10 | Western Digital Technologies, Inc. | Writing metadata files on a disk |
US8756361B1 (en) | 2010-10-01 | 2014-06-17 | Western Digital Technologies, Inc. | Disk drive modifying metadata cached in a circular buffer when a write operation is aborted |
US9092337B2 (en) | 2011-01-31 | 2015-07-28 | Intelligent Intellectual Property Holdings 2 Llc | Apparatus, system, and method for managing eviction of data |
US8966184B2 (en) | 2011-01-31 | 2015-02-24 | Intelligent Intellectual Property Holdings 2, LLC. | Apparatus, system, and method for managing eviction of data |
US9141527B2 (en) | 2011-02-25 | 2015-09-22 | Intelligent Intellectual Property Holdings 2 Llc | Managing cache pools |
US8825937B2 (en) | 2011-02-25 | 2014-09-02 | Fusion-Io, Inc. | Writing cached data forward on read |
US8793429B1 (en) | 2011-06-03 | 2014-07-29 | Western Digital Technologies, Inc. | Solid-state drive with reduced power up time |
US20120320517A1 (en) * | 2011-06-17 | 2012-12-20 | Bae Systems Controls Inc. | Obsolescence tolerant flash memory architecture and physical building block (pbb) implementation |
US8954948B2 (en) * | 2011-06-17 | 2015-02-10 | Bae Systems Controls Inc. | Obsolescence tolerant flash memory architecture and physical building block (PBB) implementation |
US8756382B1 (en) | 2011-06-30 | 2014-06-17 | Western Digital Technologies, Inc. | Method for file based shingled data storage utilizing multiple media types |
US8856438B1 (en) | 2011-12-09 | 2014-10-07 | Western Digital Technologies, Inc. | Disk drive with reduced-size translation table |
US9213493B1 (en) | 2011-12-16 | 2015-12-15 | Western Digital Technologies, Inc. | Sorted serpentine mapping for storage drives |
US8819367B1 (en) | 2011-12-19 | 2014-08-26 | Western Digital Technologies, Inc. | Accelerated translation power recovery |
US8612706B1 (en) | 2011-12-21 | 2013-12-17 | Western Digital Technologies, Inc. | Metadata recovery in a disk drive |
US10102117B2 (en) | 2012-01-12 | 2018-10-16 | Sandisk Technologies Llc | Systems and methods for cache and storage device coordination |
US9767032B2 (en) | 2012-01-12 | 2017-09-19 | Sandisk Technologies Llc | Systems and methods for cache endurance |
US9251052B2 (en) | 2012-01-12 | 2016-02-02 | Intelligent Intellectual Property Holdings 2 Llc | Systems and methods for profiling a non-volatile cache having a logical-to-physical translation layer |
US8782344B2 (en) | 2012-01-12 | 2014-07-15 | Fusion-Io, Inc. | Systems and methods for managing cache admission |
US9251086B2 (en) | 2012-01-24 | 2016-02-02 | SanDisk Technologies, Inc. | Apparatus, system, and method for managing a cache |
US10019353B2 (en) | 2012-03-02 | 2018-07-10 | Longitude Enterprise Flash S.A.R.L. | Systems and methods for referencing data on a storage medium |
US8699185B1 (en) | 2012-12-10 | 2014-04-15 | Western Digital Technologies, Inc. | Disk drive defining guard bands to support zone sequentiality when butterfly writing shingled data tracks |
US8953269B1 (en) | 2014-07-18 | 2015-02-10 | Western Digital Technologies, Inc. | Management of data objects in a data object zone |
US9875055B1 (en) | 2014-08-04 | 2018-01-23 | Western Digital Technologies, Inc. | Check-pointing of metadata |
US10078567B2 (en) | 2016-03-18 | 2018-09-18 | Alibaba Group Holding Limited | Implementing fault tolerance in computer system memory |
WO2017161083A1 (en) * | 2016-03-18 | 2017-09-21 | Alibaba Group Holding Limited | Implementing fault tolerance in computer system memory |
Also Published As
Publication number | Publication date |
---|---|
US7523249B1 (en) | 2009-04-21 |
US5845313A (en) | 1998-12-01 |
US6115785A (en) | 2000-09-05 |
US20040117586A1 (en) | 2004-06-17 |
US8032694B2 (en) | 2011-10-04 |
US6230234B1 (en) | 2001-05-08 |
US7774576B2 (en) | 2010-08-10 |
US20100293324A1 (en) | 2010-11-18 |
US5924113A (en) | 1999-07-13 |
US6912618B2 (en) | 2005-06-28 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7774576B2 (en) | Direct logical block addressing flash memory mass storage architecture | |
US8793430B2 (en) | Electronic system having memory with a physical block having a sector storing data and indicating a move status of another sector of the physical block | |
US6145051A (en) | Moving sectors within a block of information in a flash memory mass storage architecture | |
EP0980551B1 (en) | Moving sectors within a block in a flash memory | |
US5930815A (en) | Moving sequential sectors within a block of information in a flash memory mass storage architecture | |
EP0691008B1 (en) | Flash memory mass storage architecture | |
US5388083A (en) | Flash memory mass storage architecture |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
FEPP | Fee payment procedure |
Free format text: PAYOR NUMBER ASSIGNED (ORIGINAL EVENT CODE: ASPN); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
AS | Assignment |
Owner name: MICRON TECHNOLOGY, INC., IDAHO Free format text: MERGER;ASSIGNOR:LEXAR MEDIA, INC.;REEL/FRAME:026024/0131 Effective date: 20060621 |
|
AS | Assignment |
Owner name: MICRON TECHNOLOGY, INC., IDAHO Free format text: MERGER;ASSIGNOR:LEXAR MEDIA, INC.;REEL/FRAME:030588/0368 Effective date: 20070530 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: U.S. BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT, CALIFORNIA Free format text: SECURITY INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:038669/0001 Effective date: 20160426 Owner name: U.S. BANK NATIONAL ASSOCIATION, AS COLLATERAL AGEN Free format text: SECURITY INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:038669/0001 Effective date: 20160426 |
|
AS | Assignment |
Owner name: MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL AGENT, MARYLAND Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:038954/0001 Effective date: 20160426 Owner name: MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL Free format text: PATENT SECURITY AGREEMENT;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:038954/0001 Effective date: 20160426 |
|
AS | Assignment |
Owner name: U.S. BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT, CALIFORNIA Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REPLACE ERRONEOUSLY FILED PATENT #7358718 WITH THE CORRECT PATENT #7358178 PREVIOUSLY RECORDED ON REEL 038669 FRAME 0001. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:043079/0001 Effective date: 20160426 Owner name: U.S. BANK NATIONAL ASSOCIATION, AS COLLATERAL AGEN Free format text: CORRECTIVE ASSIGNMENT TO CORRECT THE REPLACE ERRONEOUSLY FILED PATENT #7358718 WITH THE CORRECT PATENT #7358178 PREVIOUSLY RECORDED ON REEL 038669 FRAME 0001. ASSIGNOR(S) HEREBY CONFIRMS THE SECURITY INTEREST;ASSIGNOR:MICRON TECHNOLOGY, INC.;REEL/FRAME:043079/0001 Effective date: 20160426 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.) |
|
AS | Assignment |
Owner name: MICRON TECHNOLOGY, INC., IDAHO Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:U.S. BANK NATIONAL ASSOCIATION, AS COLLATERAL AGENT;REEL/FRAME:047243/0001 Effective date: 20180629 |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20180810 |
|
AS | Assignment |
Owner name: MICRON TECHNOLOGY, INC., IDAHO Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:MORGAN STANLEY SENIOR FUNDING, INC., AS COLLATERAL AGENT;REEL/FRAME:050937/0001 Effective date: 20190731 |