|Publication number||US8209516 B2|
|Application number||US 12/714,237|
|Publication date||Jun 26, 2012|
|Filing date||Feb 26, 2010|
|Priority date||Dec 21, 2005|
|Also published as||US7747837, US20070143532, US20100223308|
|Publication number||12714237, 714237, US 8209516 B2, US 8209516B2, US-B2-8209516, US8209516 B2, US8209516B2|
|Inventors||Alan W. Sinclair|
|Original Assignee||Sandisk Technologies Inc.|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (256), Non-Patent Citations (116), Referenced by (1), Classifications (12), Legal Events (2)|
|External Links: USPTO, USPTO Assignment, Espacenet|
This application is a divisional patent application of U.S. patent application Ser. No. 11/313,567, filed Dec. 21, 2005 now U.S. Pat. No. 7,747,837, the disclosure of which is incorporated herein by reference in its entirety.
This patent application is related to the following co-pending patent applications, incorporated herein by reference in their entireties:
Ser. No. 11/060,249; Filed on Feb. 16, 2005;
Ser. No. 11/060,174; Filed on Feb. 16, 2005;
Ser. No. 11/060,248; Filed on Feb. 16, 2005;
Ser. No. 11/196,168; Filed on Aug. 3, 2005, (now U.S. Pat. No. 7,627,733); and
Provisional patent application Ser. No. 60/705,388; filed Aug. 3, 2004.
1. Field of the Invention
The present invention relates generally to the operation of re-programmable non-volatile memory systems such as semiconductor flash memory, and more particularly, to the management of the interface between a host device and the memory.
Conventional computer systems typically include several functional components. These components may include a central processing unit (CPU), main memory, input/output (“I/O”) devices, and mass storage devices. In conventional systems, the main memory is coupled to the CPU via a system bus or a local memory bus. The main memory is used to provide the CPU access to data and/or program information that is stored in main memory at execution time. Typically, the main memory is composed of random access memory (RAM) circuits. A computer system with the CPU and main memory is often referred to as a host system.
A host system interfaces with mass storage devices for example, non-volatile memory systems (may also be referred to as “flash device”, “flash” or “flash card” interchangeably throughout this specification) via an interface.
In an early generation of commercial flash memory systems, a rectangular array of memory cells were divided into a large number of groups of cells that each stored the amount of data of a standard disk drive sector, namely 512 bytes. An additional amount of data, such as 16 bytes, are also usually included in each group to store an error correction code (ECC) and possibly other overhead data relating to the user data and/or to the memory cell group in which it is stored. The memory cells in each such group are the minimum number of memory cells that are erasable together. That is, the erase unit is effectively the number of memory cells that store one data sector and any overhead data that is included. Examples of this type of memory system are described in U.S. Pat. Nos. 5,602,987 and 6,426,893. It is a characteristic of flash memory that the memory cells need to be erased prior to re-programming them with data.
Flash memory systems are most commonly provided in the form of a memory card or flash drive that is removably connected with a variety of hosts such as a personal computer, a camera or the like, but may also be embedded within such host systems.
Typically, a host system maintains a file directory and allocates file data to logical clusters. A host system that uses a logical interface for accessing data may be referred to as a legacy host system. The term host system in this context includes legacy flash memory card readers and digital cameras and the like.
In conventional systems, a host maintains a file system and allocates file data to logical clusters, where the cluster size is typically fixed. A flash device is divided into plural logical sectors and the host allocates space within the clusters comprising of a plurality of logical sectors. A cluster is a sub-division of logical addresses and a cluster map is designated as a file allocation table (“FAT”). The FAT is normally stored on a storage device itself.
In conventional systems, when writing data to the memory, the host typically assigns unique logical addresses to sectors, clusters or other units of data within a continuous virtual address space of the memory system. Like a disk operating system (DOS), the host writes data to, and reads data from, addresses within the logical address space of the memory system. A controller within the memory system translates logical addresses received from the host into physical addresses within the memory array, where the data are actually stored, and then keeps track of these address translations. The data storage capacity of the memory system is at least as large as the amount of data that is addressable over the entire logical address space defined for the memory system.
Other file storage systems (or formats) are being developed so that a host does not have to perform the file to logical address mapping. However, these new file systems may still have to be used with legacy host systems to read data.
Therefore, there is a need for a method and system that allows a host system to efficiently access files in a flash device that uses a non-traditional file storage format.
In one aspect of the present invention, a system for reading data from a non-volatile mass storage device is provided. The system includes a file storage segment that reads and writes data on a file-by-file basis, allowing a host system to access data from the non-volatile mass storage device using a file based protocol; and a logical interface segment that allows the host system to access data using logical addressing, wherein the host system is unaware of a storage format under which data is stored on a file-by-file basis.
In another aspect, a method for reading data from a non-volatile mass storage device that stores data on a file-by-file basis is provided. The method includes, performing logical configuration for the non-volatile mass storage device, wherein file data is allocated addresses in a virtual logical address space; and data identified by virtual logical addresses is read by a host system.
In yet another aspect of the present invention, a method for reading data from a non-volatile mass storage device is provided. The method includes, performing logical configuration for the non-volatile mass storage device that stores file data on a file-by-file basis, wherein during the logical configuration a logical index is created where the logical index includes an entry for each file that is identified in a file directory and each entry specifies an address for a file within a virtual logical address space for the non-volatile mass storage device and a corresponding entry location in the file directory; and operating the non-volatile mass storage device wherein data identified by the virtual logical address is read by the host system.
In yet another aspect of the present invention, a system for reading data in a non-volatile mass storage device is provided. The system includes, a direct data file storage segment that operates in a direct data file access mode allowing a host system to access data from the non-volatile mass storage device on a file-by-file basis; and a logical interface segment that allows the host system to access data using logical addressing, wherein the host system is unaware of a storage format under which data is stored on a file-by-file basis.
This brief summary has been provided so that the nature of the invention may be understood quickly. A more complete understanding of the invention can be obtained by reference to the following detailed description of the preferred embodiments thereof in connection with the attached drawings.
The foregoing features and other features of the present invention will now be described with reference to the drawings of a preferred embodiment. In the drawings, the same components have the same reference numerals. The illustrated embodiment is intended to illustrate, but not to limit the invention. The drawings include the following Figures:
To facilitate an understanding of the preferred embodiment, the general architecture and operation of a host system/non-volatile mass storage system will be described. The specific architecture and operation of the preferred embodiment will then be described with reference to the general architecture.
Host System/Memory System:
Read only memory (ROM″) 102 is provided to store invariant instruction sequences such as start-up instruction sequences or basic Input/output operating system (BIOS) sequences.
Input/Output (“I/O”) devices 102A, for example, a keyboard, a pointing device (“mouse”), a monitor, a modem and the like are also provided.
Mass storage device (Flash device) 105 also provides non-volatile memory for CPU 101. Flash device 105 includes a controller module 106 (may also be referred to as “memory system controller”) and solid state memory modules 107-108 (shown as Memory Module #1 and Memory Module #N). Controller module 106 interfaces with host system 100 via a bus interface 104 or directly via system bus 101A or another peripheral bus (not shown).
There are currently many different flash memory cards that are commercially available, examples being the CompactFlash (CF), the MultiMediaCard (MMC), Secure Digital (SD), miniSD, Memory Stick, SmartMedia and TransFlash cards. Although each of these cards has a unique mechanical and/or electrical interface according to its standardized specifications, the flash memory included in each is very similar. These cards are all available from SanDisk Corporation, assignee of the present application. SanDisk also provides a line of flash drives under its Cruzer trademark, which are hand held memory systems in small packages that have a Universal Serial Bus (USB) plug for connecting with a host by plugging into the host's USB receptacle. Each of these memory cards and flash drives includes controllers that interface with the host and control operation of the flash memory within them.
Host systems that use such memory cards and flash drives are many and varied. They include personal computers (PCs), laptop and other portable computers, cellular telephones, personal digital assistants (PDAs), digital still cameras, digital movie cameras and portable audio players. The host typically includes a built-in receptacle for one or more types of memory cards or flash drives but some require adapters into which a memory card is plugged.
A NAND architecture of the memory cell arrays 107-108 is currently preferred, although other architectures, such as NOR, can also be used instead. Examples of NAND flash memories and their operation as part of a memory system may be had by reference to U.S. Pat. Nos. 5,570,315, 5,774,397, 6,046,935, 6,373,746, 6,456,528, 6,522,580, 6,771,536 and 6,781,877 and United States patent application publication no. 2003/0147278.
It is noteworthy that the adaptive aspects of the present invention are not limited to a flash device 105, and can be used for any non-volatile mass storage system.
A host interface 113 interfaces with host system 100, while a flash interface 112 interfaces with memory modules 107-108.
A block of memory cells is the unit of erase, the smallest number of memory cells that are physically erasable together. For increased parallelism, however, the blocks are operated in larger metablock units. One block from each plane is logically linked together to form a metablock. The four blocks 137-140 are shown to form one metablock 141. All of the cells within a metablock are typically erased together. The blocks used to form a metablock need not be restricted to the same relative locations within their respective planes, as is shown in a second metablock 143 made up of blocks 145-148.
Although it is usually preferable to extend the metablocks across all of the planes, for high system performance, the memory system can be operated with the ability to dynamically form metablocks of any or all of one, two or three blocks in different planes. This allows the size of the metablock to be more closely matched with the amount of data available for storage in one programming operation.
The individual blocks are in turn divided for operational purposes into pages of memory cells, as illustrated in
Although it is preferable to program and read the maximum amount of data in parallel across all four planes, for high system performance, the memory system can also be operated to form metapages of any or all of one, two or three pages in separate blocks in different planes. This allows the programming and reading operations to adaptively match the amount of data that may be conveniently handled in parallel and reduces the occasions when part of a metapage remains unprogrammed with data.
A metapage formed of physical pages of multiple planes, as illustrated in
As the parallelism of memories increases, data storage capacity of the metablock increases and the size of the data page and metapage also increase as a result. The data page may then contain more than two sectors of data. With two sectors in a data page, and two data pages per metapage, there are four sectors in a metapage. Each metapage thus stores 2048 bytes of data. This is a high degree of parallelism, and can be increased even further as the number of memory cells in the rows is increased. For this reason, the width of flash memories is being extended in order to increase the amount of data in a page and a metapage.
The physically small re-programmable non-volatile memory cards and flash drives identified above are commercially available with data storage capacity of 512 megabytes (MB), 1 gigabyte (GB), 2 GB and 4 GB, and may go higher.
A common logical interface between the host and the memory system is illustrated in
Three Files 1, 2 and 3 are shown in the example of
When a File 2 is later created by the host, the host similarly assigns two different ranges of contiguous addresses within the logical address space 161, as shown in
The host keeps track of the memory logical address space by maintaining a file allocation table (FAT), where the logical addresses the host assigns to the various host files are maintained. The FAT table is typically stored in the non-volatile memory, as well as in a host memory, and is frequently updated by the host as new files are stored, other files deleted, files modified and the like. When a host file is deleted, for example, the host then de-allocates the logical addresses previously allocated to the deleted file by updating the FAT table to show that they are now available for use with other data files.
The host is not concerned about the physical locations where the memory system controller chooses to store the files. The typical host only knows its logical address space and the logical addresses that it has allocated to its various files. The memory system, on the other hand, through a typical host/card interface, only knows the portions of the logical address space to which data have been written but does not know the logical addresses allocated to specific host files, or even the number of host files. The memory system controller 106 converts the logical addresses provided by the host for the storage or retrieval of data into unique physical addresses within the flash memory cell array where host data are stored. A block 163 represents a working table of these logical-to-physical address conversions, which is maintained by the memory system controller 106.
The memory system controller 106 is programmed to store data files within the blocks and metablocks of a memory array 165 in a manner to maintain the performance of the system at a high level. Four planes or sub-arrays are used in this illustration. Data are preferably programmed and read with the maximum degree of parallelism that the system allows, across an entire metablock formed of a block from each of the planes. At least one metablock 167 is usually allocated as a reserved block for storing operating firmware and data used by the memory controller. Another metablock 169, or multiple metablocks, may be allocated for storage of host operating software, the host FAT table and the like. Most of the physical storage space remains for the storage of data files.
The memory system controller 106 does not know, however, how the data received has been allocated by the host among its various file objects. All the memory controller 106 typically knows from interacting with the host is that data written by the host to specific logical addresses are stored in corresponding physical addresses as maintained by the controller's logical-to-physical address table 163.
In a typical memory system, a few extra blocks of storage capacity are provided than are necessary to store the amount of data within the address space 161. One or more of these extra blocks may be provided as redundant blocks for substitution for other blocks that may become defective during the lifetime of the memory. The logical grouping of blocks contained within individual metablocks may usually be changed for various reasons, including the substitution of a redundant block for a defective block originally assigned to the metablock. One or more additional blocks, such as metablock 171, are typically maintained in an erased block pool.
When the host writes data to the memory system, the controller 106 converts the logical addresses assigned by the host to physical addresses within a metablock in the erased block pool. Other metablocks not being used to store data within the logical address space 161 are then erased and designated as erased pool blocks for use during a subsequent data write operation.
Data stored at specific host logical addresses are frequently overwritten by new data as the original stored data become obsolete. The memory system controller 106, in response, writes the new data in an erased block and then changes the logical-to-physical address table for those logical addresses to identify the new physical block to which the data at those logical addresses are stored. The blocks containing the original data at those logical addresses are then erased and made available for the storage of new data. Such erasure often must take place before a current data write operation may be completed if there is not enough storage capacity in the pre-erased blocks from the erase block pool at the start of writing. This can adversely impact the system data programming speed. The memory controller 106 typically learns that data at a given logical address has been rendered obsolete by the host only when the host writes new data to their same logical address. Many blocks of the memory can therefore be storing such invalid data for a time.
The sizes of blocks and metablocks are increasing in order to efficiently use the area of the integrated circuit memory chip. This results in a large proportion of individual data writes storing an amount of data that is less than the storage capacity of a metablock, and in many cases even less than that of a block. Since the memory system controller 106 normally directs new data to an erased pool metablock, this can result in portions of metablocks going unfilled. If the new data are updates of some data stored in another metablock, remaining valid metapages of data from that other metablock having logical addresses contiguous with those of the new data metapages are also desirably copied in logical address order into the new metablock. The old metablock may retain other valid data metapages. This results over time in data of certain metapages of an individual metablock being rendered obsolete and invalid, and replaced by new data with the same logical address being written to a different metablock.
In order to maintain enough physical memory space to store data over the entire logical address space 161, such data are periodically compacted or consolidated (garbage collection). It is also desirable to maintain sectors of data within the metablocks in the same order as their logical addresses as much as practical, since this makes reading data in contiguous logical addresses more efficient. So data compaction and garbage collection are typically performed with this additional goal. Some aspects of managing a memory when receiving partial block data updates and the use of metablocks are described in U.S. Pat. No. 6,763,424.
Direct Data File Storage:
In a DFS device, data is accessed by host system 100 on a file-by-file basis (a file based protocol) as described in the aforementioned patent application, that is, data is identified by a file identifier and an offset address within the file. No logical address space is defined for the device. Host system 100 does not allocate file data to logical clusters, and directory/index table information for files is generated by flash device 105.
The host addresses each file by a unique file ID (or other unique reference) and offset addresses of units of data (such as bytes) within the file. This file address is given directly to the memory system controller 106, which then keeps its own table of where the data of each host file are physically stored.
This file-based interface is illustrated in
The file-based interface is also illustrated by
With reference to
Although DFS devices will be used advantageously by host systems, there are still and will be legacy host systems that need to use a logical interface to read data files. In one aspect of the present invention, a DFS device can be accessed in a read-only mode by legacy host systems. When flash device 105 detects that it has been inserted in a conventional host system, it emulates directory and FAT data structures according to the DOS standards, and represents file data address as contiguous regions of a virtual logical address space. The legacy host system interfaces with DFS enabled flash device 105 as if was a conventional flash device with a logical interface.
In another embodiment of the present invention, a host system may wish to access the flash device 105 using both a file-based interface and a logical interface. For example, legacy application software on a host may use a logical interface for compatibility with legacy memory devices operating only with the logical interface, whilst other applications may use a file based interface to a DFS device.
Referring back to
Segments 200A and 200B are described below with respect to the various modes of operation for flash device 105.
Direct Data File Access Mode (or “DFS Mode”): During the DFS mode, flash device 105 operates in a direct data file access mode that is described in detail in the aforementioned co-pending patent application. During this mode, a host system sends a file identifier and an offset address to direct data file interface 201. No logical address space is required during this mode. File directory 203 and a file index table (may also be referred to as “FIT”) 204 are generated by flash device 105.
File directory 203 records file attribute information with a pointer to a first data group entry in the file index table 204. File index table 204 contains an entry for each valid data group within a file with contiguous file offset addresses. Entries for a data group include a file offset address and a physical address.
Every file in a directory points to an entry in FIT 204 (for example, 203B points to 204D). FIT 204 includes an entry for every data group and each entry (for example, 204D) includes an offset value 204A, block value 204B and byte value 204C. The offset value 204A shows offset address within the file corresponding to the start of a data group (for example, 205A in flash block 205B). The block value 204B provides the actual physical address of the data block and the byte value 204C points to a byte where the data group begins.
Logical Configuration Mode:
When flash device 105 detects that it is inserted in a legacy host system (or communicates with a legacy host system/operationally coupled with a legacy host system) that needs a logical interface to read data, a logical configuration operation is performed, according to one aspect of the present invention.
A logical configuration may also be performed at other times, such as may be determined by controller 106 or in response to a command received at the host interface 113.
As shown in
Directory Index 206: Directory index 206 includes a virtual logical address that is assigned for each file directory 203 entry. A file directory 203 entry defines a sub-directory or a file and contains a pointer to the file directory 203 or FIT 204. It is noteworthy that pointers in a DOS directory relate to logical addresses in the address space of the device. Directory index 206 contains virtual logical addresses that are used to substitute for the pointers in file directory 203, to create a directory conforming to DOS standards
FAT Index 207: FAT index 207 contains information that allows a FAT to be emulated for the virtual address space for the flash device 105 (see
It is noteworthy that the present invention is not limited to explicitly storing such FAT entries as they can be generated algorithmically when a FAT sector is read by a host. A record that identifies FAT entries with an <End of File> code is stored. For each sector of FAT entries (207A). FAT index 207 contains a list of entries that contain an <End of File> code (see
Logical Index 208: During logical read-only mode, file data from flash device 105 is accessed by using a logical address. Logical index 208 is used to convert a logical address to a File Directory 203 entry address and a file address offset so that file data 205C (
A host provides a target logical address Y′ (not shown), and the logical index 208 is searched to find logical address Y for the beginning of the file within which logical address Y′ is located. (Y′-Y) defines the offset address of the target logical address within the file. Logical index 208 provides location X corresponding to logical address Y. This allows file data 205 to be provided to a legacy host using a logical interface.
Flash device 105 represents sub-directories as being at successive cluster addresses at the beginning of a data space. Files are represented as occupying sequential clusters in data space without fragmentation of address and without unallocated clusters between the files (shown as contiguous files 211A).
Logical Read Only Mode:
When flash device 105 is configured for logical read-only operation, it may be read using logical interface 210 as shown in
Entries relating to a directory sector are read from file directory 203 and are modified by using a corresponding entry from directory index 206, before being returned to a host system.
Entries relating to a FAT sector are created as a set of incrementing cluster addresses, and are updated to <End of File> codes according to entries for the sector in the FAT index 207. Thereafter, the entries are returned to a host system.
A logical sector address from a host system is converted to an entry address in the file directory 203 with a file offset address by searching entries in the logical index 208. Sector data is read using direct data file storage manager 202.
It is noteworthy that memory 110 may be used for storage and access of directory index 206. FAT index 207 and logical index 208. DFS manager 202 may use a pool of buffers in memory 110 and a pool of erased blocks for file and control data storage. These buffers (not shown) are not used during the logical read-only operation and hence may be used to store the foregoing indices. However, the indices may also be stored in flash memory modules 107-108, with or without copies in memory 110.
If logical configuration is required, then in step S304, controller 106 reads the next file directory entry and creates a corresponding entry for directory index 206 in step S306A. Controller 106 then determines in step S306, if the file directory entry is for a file. If the file directory entry is not for a file, then the process moves to step S312 (described below).
If the file directory entry in step S306 is for a file, then in step S308, a FAT index entry 207B is created, and in step S308A, a logical index entry (for example, as shown in
In step S312, controller 106 determines if the last entry in the file directory has been reached. If the last entry in the file directory has not been reached, then the process reverts back to step S304. If the last entry in the file directory has been reached, then in step S314, the controller 106 determines if a read command has been received at logical interface 210.
If a read command has not been received, then the process reverts back to step S302.
If the read command has been received, then in step S316, the process determines if the logical address is for a directory sector. If the logical address is for a directory sector, then in step S318 directory index 206 is read and in step S320, the file directory 203 is read. In step S322, a directory sector is created and the information returned to host 100 in step S324.
If in step S316, the logical address is not for a directory sector, then in step S330, the process determines if the logical address is for a FAT sector. If it is for a FAT sector, then in step S332, the FAT index 207 is read. A FAT sector is created in step S334 and returned to host 100 in step S324.
If in step S330, the logical address is not for a FAT sector but for file data, then in step S336, the process determines if the logical address is for file data. If not, then the process reverts back to step S302.
If the logical address is for file data, then in step S338, the logical index 208 is read. The file directory entry is identified in step S340 and data is read from the direct data file storage segment in step S342. Thereafter, file data is returned to host in step S324.
In step S326, the process determines if there are any other logical addresses that are to be read as a result of the read command received in step S314. If not, then the process reverts back to step S302. If there are other logical addresses, then the process reverts back to step S316.
In one aspect of the present invention, a legacy host system does not have to make any upgrades to read data from direct data file storage device.
Although the present invention has been described with reference to specific embodiments, these embodiments are illustrative only and not limiting. Many other applications and embodiments of the present invention will be apparent in light of this disclosure and the following claims.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US4761737||Jan 16, 1986||Aug 2, 1988||International Business Machines Corporation||Method to automatically increase the segment size of unix files in a page segmented virtual memory data processing system|
|US4800520||Oct 23, 1986||Jan 24, 1989||Kabushiki Kaisha Toshiba||Portable electronic device with garbage collection function|
|US4802117||Dec 16, 1985||Jan 31, 1989||Pitney Bowes Inc.||Method of preserving data storage in a postal meter|
|US4896262||Feb 22, 1985||Jan 23, 1990||Kabushiki Kaisha Meidensha||Emulation device for converting magnetic disc memory mode signal from computer into semiconductor memory access mode signal for semiconductor memory|
|US5226155||Aug 24, 1989||Jul 6, 1993||Kabushiki Kaisha Toshiba||Method and system for allocating file space in memory of ic card|
|US5369754||Mar 30, 1994||Nov 29, 1994||Intel Corporation||Block specific status information in a memory device|
|US5388083||Mar 26, 1993||Feb 7, 1995||Cirrus Logic, Inc.||Flash memory mass storage architecture|
|US5404485||Mar 8, 1993||Apr 4, 1995||M-Systems Flash Disk Pioneers Ltd.||Flash file system|
|US5530673||Apr 8, 1994||Jun 25, 1996||Hitachi, Ltd.||Flash memory control method and information processing system therewith|
|US5542066||Dec 23, 1993||Jul 30, 1996||International Business Machines Corporation||Destaging modified data blocks from cache memory|
|US5544356||Mar 3, 1995||Aug 6, 1996||Intel Corporation||Block-erasable non-volatile semiconductor memory which tracks and stores the total number of write/erase cycles for each block|
|US5570315||Sep 21, 1994||Oct 29, 1996||Kabushiki Kaisha Toshiba||Multi-state EEPROM having write-verify control circuit|
|US5586291||Dec 23, 1994||Dec 17, 1996||Emc Corporation||Disk controller with volatile and non-volatile cache memories|
|US5592662||Sep 29, 1993||Jan 7, 1997||Kabushiki Kaisha Tishiba||File management system and method for managing access and storage of data within multiple external memory devices|
|US5592669||Dec 1, 1995||Jan 7, 1997||Intel Corporation||File structure for a non-volatile block-erasable semiconductor flash memory|
|US5602987||Dec 29, 1993||Feb 11, 1997||Sandisk Corporation||Flash EEprom system|
|US5619690||Jun 21, 1994||Apr 8, 1997||Hitachi, Ltd.||Computer system including a computer which requests an access to a logical address in a secondary storage system with specification of a local address in the secondary storage system|
|US5628014||Feb 3, 1995||May 6, 1997||Paranode, Inc.||Methods and apparatus for node caching at the file level|
|US5634050||Jun 7, 1995||May 27, 1997||Microsoft Corporation||Method and system for file system management using a flash-erasable programmable, read-only memory|
|US5636355||Jun 30, 1993||Jun 3, 1997||Digital Equipment Corporation||Disk cache management techniques using non-volatile storage|
|US5708846||Feb 24, 1995||Jan 13, 1998||Intel Corporation||System for retrieving initial data sequence corresponding to next data sequence while locating next data sequence when branch point is reached during current data sequence|
|US5754888||Jan 18, 1996||May 19, 1998||The Board Of Governors For Higher Education, State Of Rhode Island And Providence Plantations||System for destaging data during idle time by transferring to destage buffer, marking segment blank , reodering data in buffer, and transferring to beginning of segment|
|US5774397||Sep 10, 1996||Jun 30, 1998||Kabushiki Kaisha Toshiba||Non-volatile semiconductor memory device and method of programming a non-volatile memory cell to a predetermined state|
|US5778418||Aug 8, 1994||Jul 7, 1998||Sandisk Corporation||Mass computer storage system having both solid state and rotating disk types of memory|
|US5798968||Sep 24, 1996||Aug 25, 1998||Sandisk Corporation||Plane decode/virtual sector architecture|
|US5799168||Jan 5, 1996||Aug 25, 1998||M-Systems Flash Disk Pioneers Ltd.||Standardized flash controller|
|US5809558||Mar 17, 1997||Sep 15, 1998||Intel Corporation||Method and data storage system for storing data in blocks without file reallocation before erasure|
|US5832493||Apr 24, 1997||Nov 3, 1998||Trimble Navigation Limited||Flash file management system|
|US5848420||Jun 14, 1996||Dec 8, 1998||Eastman Kodak Company||System and method for accessing data of a digital camera from a personal computer|
|US5867641||Oct 27, 1995||Feb 2, 1999||Scm Microsystems (U.S.) Inc.||Flash translation layer cleanup system and method|
|US5890192||Nov 5, 1996||Mar 30, 1999||Sandisk Corporation||Concurrent write of multiple chunks of data into multiple subarrays of flash EEPROM|
|US5896393||May 23, 1996||Apr 20, 1999||Advanced Micro Devices, Inc.||Simplified file management scheme for flash memory|
|US5907854||Sep 27, 1996||May 25, 1999||Alcatel Usa Sourcing, L.P.||Flash memory file system for writing data files without rewriting an entire volume|
|US5928347||Nov 18, 1997||Jul 27, 1999||Shuttle Technology Group Ltd.||Universal memory card interface apparatus|
|US5933846||Nov 2, 1995||Aug 3, 1999||Nec Corporation||Rewritable ROM file device having read/write buffer access control via copy of rewritable area|
|US5937425||Oct 16, 1997||Aug 10, 1999||M-Systems Flash Disk Pioneers Ltd.||Flash file system optimized for page-mode flash technologies|
|US5953538||Nov 12, 1996||Sep 14, 1999||Digital Equipment Corporation||Method and apparatus providing DMA transfers between devices coupled to different host bus bridges|
|US5966720||Dec 24, 1997||Oct 12, 1999||Fujitsu Limited||Flash memory accessed using only the logical address|
|US5973964||Oct 30, 1998||Oct 26, 1999||Hitachi, Ltd.||Flash memory control method and information processing system therewith|
|US5978893||Jun 19, 1996||Nov 2, 1999||Apple Computer, Inc.||Method and system for memory management|
|US5987478||Oct 31, 1995||Nov 16, 1999||Intel Corporation||Virtual small block file manager for flash memory array|
|US5996047||Jul 1, 1996||Nov 30, 1999||Sun Microsystems, Inc.||Method and apparatus for caching file control information corresponding to a second file block in a first file block|
|US6014724||Sep 17, 1996||Jan 11, 2000||Scm Microsystems (U.S.) Inc.||Flash translation layer block indication map revision system and method|
|US6016530||Apr 21, 1998||Jan 18, 2000||Sandisk Corporation||Mass computer storage system having both solid state and rotating disk types of memory|
|US6021415||Oct 29, 1997||Feb 1, 2000||International Business Machines Corporation||Storage management system with file aggregation and space reclamation within aggregated files|
|US6038636||Apr 27, 1998||Mar 14, 2000||Lexmark International, Inc.||Method and apparatus for reclaiming and defragmenting a flash memory device|
|US6046935||Jan 27, 1999||Apr 4, 2000||Kabushiki Kaisha Toshiba||Semiconductor device and memory system|
|US6069827||Mar 24, 1998||May 30, 2000||Memory Corporation Plc||Memory system|
|US6078520||Jul 21, 1999||Jun 20, 2000||Hitachi, Ltd.||Flash memory control method and information processing system therewith|
|US6094693||Aug 18, 1997||Jul 25, 2000||Sony Corporation||Information recording apparatus using erasure units|
|US6145069||Apr 26, 1999||Nov 7, 2000||Interactive Silicon, Inc.||Parallel decompression and compression system and method for improving storage density and access speed for non-volatile memory and embedded memory devices|
|US6148354||Apr 5, 1999||Nov 14, 2000||M-Systems Flash Disk Pioneers Ltd.||Architecture for a universal serial bus-based PC flash disk|
|US6216204||Jul 31, 1997||Apr 10, 2001||Schlumberger Systemes||Integrated circuit card comprising files classified in a tree structure|
|US6223271||Jul 15, 1998||Apr 24, 2001||Compaq Computer Corp.||System and method for detecting system memory size using ROM based paging tables|
|US6226728||Apr 21, 1998||May 1, 2001||Intel Corporation||Dynamic allocation for efficient management of variable sized data within a nonvolatile memory|
|US6256690||Nov 29, 1999||Jul 3, 2001||Todd Carper||System and method for facilitating multiple applications on a smart card|
|US6275436||May 23, 2000||Aug 14, 2001||Hitachi, Ltd||Flash memory control method and apparatus processing system therewith|
|US6275804||Aug 19, 1997||Aug 14, 2001||Grundig Ag||Process and circuit arrangement for storing dictations in a digital dictating machine|
|US6279069||Dec 26, 1996||Aug 21, 2001||Intel Corporation||Interface for flash EEPROM memory arrays|
|US6286056||Dec 23, 1998||Sep 4, 2001||Seagate Technology Llc||Data storage device with small computer system interface providing persistent reservations|
|US6286256||Aug 3, 2000||Sep 11, 2001||Southpac Trust International, Inc.||Floral sleeve having expandable sidewalls|
|US6370614||Jan 26, 1999||Apr 9, 2002||Motive Power, Inc.||I/O cache with user configurable preload|
|US6373746||Sep 22, 2000||Apr 16, 2002||Kabushiki Kaisha Toshiba||Nonvolatile semiconductor memory having plural data storage portions for a bit line connected to memory cells|
|US6380597||Aug 28, 1998||Apr 30, 2002||Hans Gude Gudesen||Read-only memory and read-only memory device|
|US6385690||Feb 25, 2000||May 7, 2002||Sony Corporation||Recording method, managing method, and recording apparatus|
|US6389433||Jul 16, 1999||May 14, 2002||Microsoft Corporation||Method and system for automatically merging files into a single instance store|
|US6408357||Jan 15, 1999||Jun 18, 2002||Western Digital Technologies, Inc.||Disk drive having a cache portion for storing write data segments of a predetermined length|
|US6412040||Jan 20, 2000||Jun 25, 2002||Intel Corporation||Method of performing reliable updates in a symmetrically blocked nonvolatile memory having a bifurcated storage architecture|
|US6421279||Aug 13, 2001||Jul 16, 2002||Hitachi, Ltd.||Flash memory control method and apparatus processing system therewith|
|US6424486||Dec 17, 1997||Jul 23, 2002||Texas Instruments Incorporated||Method and apparatus for positioning a read/write head of a hard disk drive|
|US6426893||Feb 17, 2000||Jul 30, 2002||Sandisk Corporation||Flash eeprom system with simultaneous multiple data sector programming and storage of physical block characteristics in other designated blocks|
|US6427186||Mar 30, 1999||Jul 30, 2002||Frank (Fong-Long) Lin||Memory, interface system and method for mapping logical block numbers to physical sector numbers in a flash memory, using a master index table and a table of physical sector numbers|
|US6446140||Nov 8, 1999||Sep 3, 2002||Nec Corporation||Data input/output device, data input/output method and storage medium|
|US6456528||Sep 17, 2001||Sep 24, 2002||Sandisk Corporation||Selective operation of a multi-state non-volatile memory system in a binary mode|
|US6466973||Mar 6, 1998||Oct 15, 2002||Adaptec, Inc.||Method and system for managing storage devices over a network|
|US6467015||Apr 11, 2002||Oct 15, 2002||Dell Products, L.P.||High speed bus interface for non-volatile integrated circuit memory supporting continuous transfer|
|US6467021||Oct 1, 1998||Oct 15, 2002||Memquest, Inc.||Data storage system storing data of varying block size|
|US6467022||Nov 3, 2000||Oct 15, 2002||International Business Machines Corporation||Extending adapter memory with solid state disks in JBOD and RAID environments|
|US6477616||Apr 18, 2000||Nov 5, 2002||Tokyo Electron Device Limited||Storage device, storage system, memory management method, recording medium, and computer data signal|
|US6480935||Aug 31, 1999||Nov 12, 2002||Todd Carper||Smart card memory management system and method|
|US6484937||Feb 13, 1998||Nov 26, 2002||Oberthur Card Systems Sa||Method for storing data in a chip card rewritable memory|
|US6490649||Feb 28, 2002||Dec 3, 2002||Lexar Media, Inc.||Memory device|
|US6493811||Jan 20, 1999||Dec 10, 2002||Computer Associated Think, Inc.||Intelligent controller accessed through addressable virtual space|
|US6504846||May 21, 1999||Jan 7, 2003||Advanced Micro Devices, Inc.||Method and apparatus for reclaiming buffers using a single buffer bit|
|US6522580||Jun 27, 2001||Feb 18, 2003||Sandisk Corporation||Operating techniques for reducing effects of coupling between storage elements of a non-volatile memory operated in multiple data states|
|US6535949||Apr 19, 1999||Mar 18, 2003||Research In Motion Limited||Portable electronic device having a log-structured file system in flash memory|
|US6542407||Jan 18, 2002||Apr 1, 2003||Sandisk Corporation||Techniques of recovering data from memory cells affected by field coupling with adjacent memory cells|
|US6547150||Apr 19, 2000||Apr 15, 2003||Microsoft Corporation||Smart card application development system and method|
|US6567307||Feb 28, 2002||May 20, 2003||Lexar Media, Inc.||Block management for mass storage|
|US6598114||Aug 13, 2001||Jul 22, 2003||Nissan Motor Co., Ltd.||Electronic control unit including flash memory and method and apparatus for storing control data group into flash memory|
|US6604168||Jul 9, 1999||Aug 5, 2003||Canon Kabushiki Kaisha||Flash eeprom management using ratio of used to unused sectors|
|US6631453||Nov 27, 2001||Oct 7, 2003||Zecurity||Secure data storage device|
|US6631456||Mar 6, 2001||Oct 7, 2003||Lance Leighnor||Hypercache RAM based disk emulation and method|
|US6643188||Jan 22, 2002||Nov 4, 2003||Kabushiki Kaisha Toshiba||Non-volatile semiconductor memory device adapted to store a multi-valued data in a single memory cell|
|US6646948||Aug 29, 2002||Nov 11, 2003||Motorola, Inc.||Data storage system utilizing a non-volatile IC based memory for reduction of data retrieval time|
|US6667932||Feb 19, 2003||Dec 23, 2003||Micron Technology, Inc.||Synchronous flash memory with virtual segment architecture|
|US6668336||Mar 29, 2002||Dec 23, 2003||M-Systems Flash Disk Pioneers Ltd.||Ruggedized block device driver|
|US6681239||Dec 23, 1996||Jan 20, 2004||International Business Machines Corporation||Computer system having shared address space among multiple virtual address spaces|
|US6728851||May 20, 2002||Apr 27, 2004||Lexar Media, Inc.||Increasing the memory performance of flash memory devices by writing sectors simultaneously to multiple flash memory devices|
|US6748457||Feb 2, 2001||Jun 8, 2004||Realtime Data, Llc||Data storewidth accelerator|
|US6763424||Jan 19, 2001||Jul 13, 2004||Sandisk Corporation||Partial block data programming and reading operations in a non-volatile memory|
|US6766432||May 24, 2002||Jul 20, 2004||Sun Microsystems, Inc.||Memory management system supporting object deletion in non-volatile memory|
|US6771536||Feb 27, 2002||Aug 3, 2004||Sandisk Corporation||Operating techniques for reducing program and read disturbs of a non-volatile memory|
|US6772955||Jul 12, 2002||Aug 10, 2004||Matsushita Electric Industrial Co., Ltd.||Memory card|
|US6779063||Apr 9, 2001||Aug 17, 2004||Hitachi, Ltd.||Direct access storage system having plural interfaces which permit receipt of block and file I/O requests|
|US6781877||Sep 6, 2002||Aug 24, 2004||Sandisk Corporation||Techniques for reducing effects of coupling between storage elements of adjacent rows of memory cells|
|US6798710||Feb 19, 2003||Sep 28, 2004||Micron Technology, Inc.||Synchronous flash memory with virtual segment architecture|
|US6804730||Nov 17, 1999||Oct 12, 2004||Tokyo Electron Device Limited||Access control device, access control method, recording medium, and computer data signal for controlling allowance of access to storage area using certification data|
|US6810462||Aug 19, 2002||Oct 26, 2004||Hitachi, Ltd.||Storage system and method using interface control devices of different types|
|US6823417||Oct 1, 2001||Nov 23, 2004||Hewlett-Packard Development Company, L.P.||Memory controller for memory card manages file allocation table|
|US6834331||Oct 24, 2000||Dec 21, 2004||Starfish Software, Inc.||System and method for improving flash memory data integrity|
|US6839823||Sep 29, 2000||Jan 4, 2005||Intel Corporation||Increased reliability of data stored on flash memory in applications sensitive to power-loss|
|US6842843||Jun 29, 2001||Jan 11, 2005||Emc Corporation||Digital data storage subsystem including arrangement for increasing cache memory addressability|
|US6845385||Dec 14, 2001||Jan 18, 2005||Object Technology Licensing Corp.||Real-time computer “garbage collector”|
|US6865659||Jun 7, 2002||Mar 8, 2005||Sun Microsystems, Inc.||Using short references to access program elements in a large address space|
|US6877074||Dec 13, 2001||Apr 5, 2005||International Business Machines Corporation||Apparatus having durable storage|
|US6883114||Nov 8, 2001||Apr 19, 2005||M-Systems Flash Disk Pioneers Ltd.||Block device driver enabling a ruggedized file system|
|US6886083||Sep 4, 2002||Apr 26, 2005||Kabushiki Kaisha Toshiba||Apparatus and method for controlling a card device|
|US6895464||Jun 3, 2002||May 17, 2005||Honeywell International Inc.||Flash memory management system and method utilizing multiple block list windows|
|US6898662||Sep 27, 2002||May 24, 2005||Lexar Media, Inc.||Memory system sectors|
|US6925007||Oct 25, 2002||Aug 2, 2005||Sandisk Corporation||Multi-state non-volatile integrated circuit memory systems that employ dielectric storage elements|
|US6938116||Dec 31, 2001||Aug 30, 2005||Samsung Electronics Co., Ltd.||Flash memory management method|
|US6965963||Jul 28, 2000||Nov 15, 2005||Sony Corporation||Continuous arrangement of data clusters across multiple storages|
|US7003553||Jun 2, 2004||Feb 21, 2006||Hitachi, Ltd.||Storage control system with channel control device having data storage memory and transfer destination circuit which transfers data for accessing target cache area without passing through data storage memory|
|US7032065||Dec 3, 2003||Apr 18, 2006||Sandisk Corporation||Techniques for operating non-volatile memory systems with data sectors having different sizes than the sizes of the pages and/or blocks of the memory|
|US7035949||Jul 29, 2002||Apr 25, 2006||M-System Flash Dist Pioneers Ltd.||Multipurpose processor, system and method|
|US7092911||Mar 24, 2000||Aug 15, 2006||Sony Corporation||Reproducing apparatus and reproducing method|
|US7127549||Feb 4, 2004||Oct 24, 2006||Sandisk Corporation||Disk acceleration using first and second storage devices|
|US7136973||Feb 4, 2004||Nov 14, 2006||Sandisk Corporation||Dual media storage device|
|US7193899||Dec 3, 2004||Mar 20, 2007||Micron Technology, Inc.||Erase block data splitting|
|US7251747||Sep 19, 2002||Jul 31, 2007||Ncr Corp.||Method and system for transferring data using a volatile data transfer mechanism such as a pipe|
|US7627733||Aug 3, 2005||Dec 1, 2009||Sandisk Corporation||Method and system for dual mode access for storage devices|
|US7747837||Jun 29, 2010||Sandisk Corporation||Method and system for accessing non-volatile storage devices|
|US7769978||Dec 21, 2005||Aug 3, 2010||Sandisk Corporation||Method and system for accessing non-volatile storage devices|
|US7793068||Sep 7, 2010||Sandisk Corporation||Dual mode access for non-volatile storage devices|
|US7877539||Jan 25, 2011||Sandisk Corporation||Direct data file storage in flash memories|
|US20010034809||Jul 9, 1999||Oct 25, 2001||Takeshi Ogawa||Selecting erase method based on type of power supply for flash eeprom|
|US20010052038||Feb 2, 2001||Dec 13, 2001||Realtime Data, Llc||Data storewidth accelerator|
|US20020069354||Feb 2, 2001||Jun 6, 2002||Fallon James J.||Systems and methods for accelerated loading of operating systems and application programs|
|US20020078002||Dec 14, 2000||Jun 20, 2002||Bottomley Thomas Mark Walter||Memory garbage collection method and apparatus|
|US20020083280||Dec 13, 2001||Jun 27, 2002||International Business Machines Corporation||Data server system, computer apparatus, and recording medium|
|US20020099904||Jan 19, 2001||Jul 25, 2002||Conley Kevin M.||Partial block data programming and reading operations in a non-volatile memory|
|US20020166023||Apr 11, 2002||Nov 7, 2002||Dell Products, L.P.||High speed bus interface for non-volatile integrated circuit memory supporting continuous transfer|
|US20020178143||Dec 18, 2001||Nov 28, 2002||Kazuhisa Fujimoto||Storage system, a method of file data backup and method of copying of file data|
|US20020184436||Dec 31, 2001||Dec 5, 2002||Samsung Electronics Co., Ltd.||Flash memory management method|
|US20020188592||Jun 11, 2001||Dec 12, 2002||Storage Technology Corporation||Outboard data storage management system and method|
|US20030002432||Jun 17, 2002||Jan 2, 2003||Koninklijke Philips Electronics N.V.||Receiver apparatus and method|
|US20030026186||Aug 2, 2002||Feb 6, 2003||Hideo Ando||Information storage medium and information recording method|
|US20030065866||Oct 1, 2001||Apr 3, 2003||Spencer Andrew M.||Memory controller for memory card manages file allocation table|
|US20030065876||Sep 28, 2001||Apr 3, 2003||Menahem Lasser||Flash management system using only sequential Write|
|US20030065899||Sep 27, 2002||Apr 3, 2003||Gorobets Sergey Anatolievich||Memory system sectors|
|US20030088812||Nov 8, 2001||May 8, 2003||M-Systems Flash Disk Pioneers Ltd.||Ruggedized block device driver|
|US20030109093||Oct 25, 2002||Jun 12, 2003||Eliyahou Harari||Multi-state non-volatile integrated circuit memory systems that employ dielectric storage elements|
|US20030128619||Feb 19, 2003||Jul 10, 2003||Micron Technology, Inc.||Synchronous flash memory with virtual segment architecture|
|US20030135514||Oct 25, 2002||Jul 17, 2003||Patel Sujal M.||Systems and methods for providing a distributed file system incorporating a virtual hot spare|
|US20030147278||Jan 22, 2002||Aug 7, 2003||Kabushiki Kaisha Toshiba||Non-volatile semiconductor memory device adapted to store a multi-valued data in a single memory cell|
|US20030208501||Apr 1, 2003||Nov 6, 2003||Trg Products, Inc.||FAT file system in Palm OS computer|
|US20030229753||Sep 26, 2002||Dec 11, 2003||Samsung Electronics Co., Ltd.||Flash memory file system|
|US20030229769||Jun 7, 2002||Dec 11, 2003||Montemayor Oscar A.||Using short references to access program elements in a large address space|
|US20040019716||Jul 29, 2002||Jan 29, 2004||M-Systems Flash Disk Pioneers, Ltd.||Multipurpose processor, system and method|
|US20040019761||Feb 27, 2003||Jan 29, 2004||Mitsubishi Denki Kabushiki Kaisha||Flash storage medium having a NAND-type flash memory|
|US20040024921||Feb 21, 2003||Feb 5, 2004||William Peake||System and method for analyzing input/output activity on local attached storage|
|US20040028068||Aug 6, 2002||Feb 12, 2004||Govind Kizhepat||Dual-mode network storage systems and methods|
|US20040030693||May 23, 2003||Feb 12, 2004||Takahisa Toda||Data management apparatus that controls a data storage apparatus by transmitting command of structured document format|
|US20040040018||Aug 22, 2002||Feb 26, 2004||Internatinal Business Machines Corporation||Apparatus and method for removing elements from a linked list|
|US20040044873||Aug 29, 2002||Mar 4, 2004||Wanmo Wong||Linear object management for a range of flash memory|
|US20040073627||Mar 1, 2002||Apr 15, 2004||Toshihiko Amano||Patent or utility model information retrieval management system using the internet|
|US20040073727||Oct 11, 2002||Apr 15, 2004||M-Systems Flash Disk Pioneers, Ltd.||Portable storage media as file servers|
|US20040103241||Oct 2, 2003||May 27, 2004||Sandisk Corporation||Method and apparatus for effectively enabling an out of sequence write process within a non-volatile memory system|
|US20040123020||Dec 3, 2003||Jun 24, 2004||Carlos Gonzalez||Techniques for operating non-volatile memory systems with data sectors having different sizes than the sizes of the pages and/or blocks of the memory|
|US20040133718||Oct 17, 2003||Jul 8, 2004||Hitachi America, Ltd.||Direct access storage system with combined block interface and file interface access|
|US20040157638||Feb 6, 2003||Aug 12, 2004||Dov Moran||Multi-access solid state memory devices and a telephone utilizing such|
|US20040186946||Mar 19, 2003||Sep 23, 2004||Jinaeon Lee||Flash file system|
|US20040205289||Apr 11, 2003||Oct 14, 2004||Sujaya Srinivasan||Reclaiming blocks in a block-alterable memory|
|US20040205301||Mar 30, 2004||Oct 14, 2004||Renesas Technology Corp.||Memory device|
|US20040207512||Aug 18, 2003||Oct 21, 2004||Bastian William A.||Inventory system with image display|
|US20040248612||May 28, 2004||Dec 9, 2004||Lg Electronics Inc.||Garbage collection system and method for a mobile communication terminal|
|US20050018527||Jun 14, 2004||Jan 27, 2005||Gorobets Sergey Anatolievich||Non-volatile memory control|
|US20050021657||Apr 21, 2004||Jan 27, 2005||International Business Machines Corp.||Network system, server, data processing method and program|
|US20050055497||Dec 19, 2003||Mar 10, 2005||Petro Estakhri||Faster write operations to nonvolatile memory by manipulation of frequently-accessed sectors|
|US20050086241 *||Aug 24, 2004||Apr 21, 2005||Tamir Ram||Method, system, and program for personal data management using content-based replication|
|US20050086422||Oct 28, 2004||Apr 21, 2005||Wanmo Wong||Multiple segment data object management|
|US20050125600||Dec 4, 2003||Jun 9, 2005||Ehrlich Richard M.||Method for storing HDD critical data in flash|
|US20050125602||Dec 4, 2003||Jun 9, 2005||Ehrlich Richard M.||HDD with storage of critical data in FLASH|
|US20050125603||Dec 4, 2003||Jun 9, 2005||Ehrlich Richard M.||Method for rapid availability of critical data through re-allocation|
|US20050141312||Aug 13, 2004||Jun 30, 2005||Sinclair Alan W.||Non-volatile memory and method with non-sequential update block management|
|US20050141313||Aug 13, 2004||Jun 30, 2005||Gorobets Sergey A.||Non-volatile memory and method with memory planes alignment|
|US20050144357||Dec 30, 2003||Jun 30, 2005||Sinclair Alan W.||Adaptive metablocks|
|US20050144358||Dec 30, 2003||Jun 30, 2005||Conley Kevin M.||Management of non-volatile memory systems having large erase blocks|
|US20050144360||Dec 30, 2003||Jun 30, 2005||Bennett Alan D.||Non-volatile memory and method with block management system|
|US20050144363||May 7, 2004||Jun 30, 2005||Sinclair Alan W.||Data boundary management|
|US20050144365||Aug 13, 2004||Jun 30, 2005||Sergey Anatolievich Gorobets||Non-volatile memory and method with control data management|
|US20050144367||Dec 16, 2004||Jun 30, 2005||Sinclair Alan W.||Data run programming|
|US20050166087||Aug 13, 2004||Jul 28, 2005||Gorobets Sergey A.||Non-volatile memory and method with phased program failure handling|
|US20050172067||Feb 4, 2004||Aug 4, 2005||Sandisk Corporation||Mass storage accelerator|
|US20050172074||Feb 4, 2004||Aug 4, 2005||Sandisk Corporation||Dual media storage device|
|US20050223166||Jun 2, 2004||Oct 6, 2005||Hiroki Kanai||Storage control system, channel control device for storage control system, and data transfer device|
|US20060004951||Jun 30, 2004||Jan 5, 2006||Rudelic John C||Method and apparatus to alter code in a memory|
|US20060020744||Jul 21, 2004||Jan 26, 2006||Sandisk Corporation||Method and apparatus for maintaining data on non-volatile memory systems|
|US20060020745||Dec 23, 2004||Jan 26, 2006||Conley Kevin M||Fat analysis for optimized sequential cluster management|
|US20060031593||Aug 9, 2004||Feb 9, 2006||Sinclair Alan W||Ring bus structure and its use in flash memory systems|
|US20060087957||Apr 5, 2004||Apr 27, 2006||Koninklijke Philips Electronics N.V.||Format mapping scheme for universal drive device|
|US20060143365||Jun 17, 2003||Jun 29, 2006||Tokyo Electron Device Limited||Memory device, memory managing method and program|
|US20060155920||Jul 27, 2005||Jul 13, 2006||Smith Peter J||Non-volatile memory and method with multi-stream updating|
|US20060155921||Jul 27, 2005||Jul 13, 2006||Gorobets Sergey A||Non-volatile memory and method with multi-stream update tracking|
|US20060155922||Jul 27, 2005||Jul 13, 2006||Gorobets Sergey A||Non-volatile memory and method with improved indexing for scratch pad and update blocks|
|US20060161724||Jan 20, 2005||Jul 20, 2006||Bennett Alan D||Scheduling of housekeeping operations in flash memory systems|
|US20060161728||Dec 19, 2005||Jul 20, 2006||Bennett Alan D||Scheduling of housekeeping operations in flash memory systems|
|US20060168392||Mar 28, 2006||Jul 27, 2006||Samsung Electronics Co., Ltd.||Flash memory file system|
|US20060168395||Nov 18, 2003||Jul 27, 2006||Guoshun Deng||Method of sending command and data to movable storage device|
|US20060184718||Feb 16, 2005||Aug 17, 2006||Sinclair Alan W||Direct file data programming and deletion in flash memories|
|US20060184719||Feb 16, 2005||Aug 17, 2006||Sinclair Alan W||Direct data file storage implementation techniques in flash memories|
|US20060184720||Feb 16, 2005||Aug 17, 2006||Sinclair Alan W||Direct data file storage in flash memories|
|US20060184722||Jan 26, 2006||Aug 17, 2006||Sinclair Alan W||Direct data file storage implementation techniques in flash memories|
|US20060184723||Jan 26, 2006||Aug 17, 2006||Sinclair Alan W||Direct file data programming and deletion in flash memories|
|US20070014136||Jul 15, 2005||Jan 18, 2007||Ali Dhamim P||Apparatus, system, and method for accessing persistent files in non-execute-in-place flash memory|
|US20070030734||May 8, 2006||Feb 8, 2007||Sinclair Alan W||Reclaiming Data Storage Capacity in Flash Memories|
|US20070033323||Aug 3, 2005||Feb 8, 2007||Gorobets Sergey A||Interfacing systems operating through a logical address space and on a direct data file basis|
|US20070033324||Oct 25, 2005||Feb 8, 2007||Sinclair Alan W||Scheduling of reclaim operations in non-volatile memory|
|US20070033326||Dec 21, 2005||Feb 8, 2007||Sinclair Alan W||Enhanced host interfacing methods|
|US20070033328||May 8, 2006||Feb 8, 2007||Sinclair Alan W||Management of Memory Blocks That Directly Store Data Files|
|US20070033329||May 8, 2006||Feb 8, 2007||Sinclair Alan W||Memory System With Management of Memory Blocks That Directly Store Data Files|
|US20070033330||May 8, 2006||Feb 8, 2007||Sinclair Alan W||Reclaiming Data Storage Capacity in Flash Memory Systems|
|US20070033332||Jul 21, 2006||Feb 8, 2007||Sinclair Alan W||Methods of Managing Blocks in NonVolatile Memory|
|US20070033362||Aug 3, 2005||Feb 8, 2007||Sinclair Alan W||Mass data storage system|
|US20070033373||Aug 3, 2005||Feb 8, 2007||Sinclair Alan W||Method and system for dual mode access for storage devices|
|US20070033374||Jul 21, 2006||Feb 8, 2007||Sinclair Alan W||Reprogrammable Non-Volatile Memory Systems With Indexing of Directly Stored Data Files|
|US20070143532||Dec 21, 2005||Jun 21, 2007||Gorobets Sergey A||Method and system for accessing non-volatile storage devices|
|US20070143570||Dec 21, 2005||Jun 21, 2007||Gorobets Sergey A||Method and system for accessing non-volatile storage devices|
|US20070143571||Dec 21, 2005||Jun 21, 2007||Sinclair Alan W||Dual mode access for non-volatile storage devices|
|CN1466060A||Oct 15, 2002||Jan 7, 2004||三星电子株式会社||闪速存储器文件系统|
|DE10234971A1||Jul 31, 2002||Feb 19, 2004||Giesecke & Devrient Gmbh||Program code generation method for generating program code from source text uses a processor core in a micro-controller to run the program code and a compiler to generate corresponding commands|
|EP0564699A1||Oct 20, 1992||Oct 13, 1993||Fujitsu Limited||Disk drive with dual function buffer|
|EP0702305A1||Sep 12, 1995||Mar 20, 1996||Nec Corporation||Disk memory apparatus|
|EP0852765B1||Feb 6, 1996||Sep 19, 2001||Memory Corporation plc||Memory management|
|EP1054319A2||May 16, 2000||Nov 22, 2000||KOM Inc.||Method and apparatus for storage of data|
|EP1100001B1||Oct 18, 2000||Aug 13, 2003||Sun Microsystems, Inc.||Storage system supporting file-level and block-level accesses|
|EP1357463A2||Aug 19, 2002||Oct 29, 2003||Hitachi, Ltd.||Storage system|
|EP1571557A1||Nov 18, 2003||Sep 7, 2005||Netac Technology Co., Ltd.||A method of sending command and data to movable storage device|
|JP2005122439A||Title not available|
|TWI352901B||Title not available|
|WO2002019334A2||Aug 24, 2001||Mar 7, 2002||Lexar Media, Inc.||Flash memory architecture with separate storage of overhead and user data|
|WO2002023341A1||Aug 6, 2001||Mar 21, 2002||Matrix Semiconductor, Inc.||Memory devices and methods for use therewith|
|WO2002029575A2||Sep 20, 2001||Apr 11, 2002||Emc Corporation||System and method for hierarchical data storage in a log structure|
|WO2002058074A2||Jan 7, 2002||Jul 25, 2002||Sandisk Corporation||Partial block data programming and reading operations in a non-volatile memory|
|WO2004012027A2||Jul 24, 2003||Feb 5, 2004||M-Systems Flash Disk Pioneers Ltd.||Multipurpose processor, system and method|
|WO2004040453A2||Sep 10, 2003||May 13, 2004||Sandisk Corporation||Method and apparatus for grouping pages within a block|
|WO2004040455A2||Sep 10, 2003||May 13, 2004||Sandisk Corporation||Method and apparatus for splitting a logical block|
|WO2005066793A2||Dec 21, 2004||Jul 21, 2005||Sandisk Corporation||Non-volatile memory and method with non-sequential update block management|
|WO2005081097A2||Jan 5, 2005||Sep 1, 2005||Sandisk Corporation||Mass storage accelerator|
|WO2006088719A2||Feb 8, 2006||Aug 24, 2006||Sandisk Corporation||Direct data file storage implementation techniques in flash memories|
|WO2006088723A2||Feb 8, 2006||Aug 24, 2006||Sandisk Corporation||Direct file data programming and deletion in flash memories|
|WO2006088727A2||Feb 8, 2006||Aug 24, 2006||Sandisk Corporation||Direct data file storage in flash memories|
|WO2007019075A2||Jul 27, 2006||Feb 15, 2007||Sandisk Corporation||Method and system for dual mode access for storage devices|
|WO2007076378A2||Dec 19, 2006||Jul 5, 2007||Sandisk Corporation||Dual mode access for non-volatile storage devices|
|WO2007079358A2||Dec 19, 2006||Jul 12, 2007||Sandisk Corporation||Method and system for accessing non-volatile storage devices|
|1||"Intel AP-686 Application Note, Flash File System Selection Guide," 18 pgs. (Dec. 1998).|
|2||"ISO/IEC, International Standard, Information Technology-Identification Cards-Integrated Circuit(s) With Contracts," Part 4: Interindustry Commands for Interchange, ISO/IEC 7816-4, First Edition, 46 pgs. (Sep. 1, 1995).|
|3||"ISO/IEC, International Standard, Information Technology—Identification Cards—Integrated Circuit(s) With Contracts," Part 4: Interindustry Commands for Interchange, ISO/IEC 7816-4, First Edition, 46 pgs. (Sep. 1, 1995).|
|4||Advisory Action for U.S. Appl. No. 11/060,248 (Nov. 10, 2009).|
|5||Ban, Amir, "Inside Flash File Systems-Part I," IC Card Systems & Design, pp. 15-16, & 18, (Jul. Aug. 1993).|
|6||Ban, Amir, "Inside Flash File Systems—Part I," IC Card Systems & Design, pp. 15-16, & 18, (Jul. Aug. 1993).|
|7||Ban, Amir, "Inside Flash File Systems-Part II," IC Card Systems & Design, pp. 21-24, (Sep./Oct. 1993).|
|8||Ban, Amir, "Inside Flash File Systems—Part II," IC Card Systems & Design, pp. 21-24, (Sep./Oct. 1993).|
|9||Ban, Amir, "Local Flash Disks: Two Architectures Compared," M-Systems Flash Disks Pioneers, White Paper, Rev. 1.0, pp. 1-8, (Aug. 2001).|
|10||Chiang et al., "Cleaning Policies in Mobile Computers Using Flash Memory," Journal of Systems & Software, vol. 48, pp. 213-231, (1999).|
|11||Chiang et al., "Data Management in a Flash Memory Based Storage Server," National Chiao-Tung University, Hsinchu, Taiwan, Dept. of Computer and Information Science, 8 pages, (Publication Date Unknown).|
|12||China State Intellectual Property Office, "First Office Action," corresponding Chinese Patent Application No. 2006800089822.0, mailed on Aug. 5, 2009, 7 pages.|
|13||China State Intellectual Property Office, "First Office Action," corresponding Chinese Patent Application No. 200680009222.3, mailed on Jul. 22, 2009, 7 pages.|
|14||China State Intellectual Property Office, "Office Action," corresponding Chinese Patent Application No. 200680089894, mailed on Apr. 24, 2009, 25 pages (including translation).|
|15||Communication pursuant to Article 94(3) EPC corresponding to European Patent Application No. 06734659.3 (Jun. 23, 2008).|
|16||Communication pursuant to Article 94(3) EPC for European Application No. 06720547.6 (May 19, 2008).|
|17||Communication pursuant to Article 94(3) EPC for European Application No. 06734695.7 (May 19, 2008).|
|18||Communication pursuant to Article 94(3) EPC for European Application No. 06788725.7 (Mar. 10, 2009).|
|19||Co-pending U.S. Patent Application entitled "Dual Mode Access for Non-Volatile Storage Devices," U.S. Appl. No. 11/314,842, filed Dec. 21, 2005.|
|20||Co-pending U.S. Patent Application entitled "Method and System for Accessing Non-Volatile Storage Devices," U.S. Appl. No. 11/313,567, filed Dec. 21, 2005. (co-pending to U.S. Appl. No. 11/196,168=1694/43).|
|21||Co-pending U.S. Patent Application entitled "Method and System for Accessing Non-Volatile Storage Devices," U.S. Appl. No. 11/313,633, filed Dec. 22, 2005.|
|22||Co-pending U.S. Patent Application entitled Direct File Data Programming and Deletion in Flash Memories,) U.S. Appl. No. 11/060,174, filed Feb. 16, 2005. (co-pending to U.S. Appl. No. 11/342,170).|
|23||Co-pending U.S. Provisional Patent Application entitled "Direct Data File Storage in Flash Memories," U.S. Appl. No. 60/705,388, filed Aug. 3, 2004. (co-pending to U.S. Appl. No. 11/060,249).|
|24||Decision to Grant for Taiwanese Application No. 095128233 (Mar. 22, 2010).|
|25||Eshel et al., "Multiple Caching Schemes in a Lan-Attached Server," IP.Com Journal, IP.Com Inc., West Henrietta, NY, US. (Apr. 1, 1995).|
|26||Final Official Action for U.S. Appl. No. 11/060,174 (Apr. 28, 2009).|
|27||Final Official Action for U.S. Appl. No. 11/060,174 (Dec. 12, 2007).|
|28||Final Official Action for U.S. Appl. No. 11/060,248 (Apr. 28, 2009).|
|29||Final Official Action for U.S. Appl. No. 11/060,248 (Dec. 26, 2007).|
|30||Final Official Action for U.S. Appl. No. 11/060,249 (Apr. 8, 2009).|
|31||Final Official Action for U.S. Appl. No. 11/060,249 (Dec. 26, 2007).|
|32||Final Official Action for U.S. Appl. No. 11/196,168 (Jul. 24, 2008).|
|33||Final Official Action for U.S. Appl. No. 11/313,567 (May 28, 2008).|
|34||Final Official Action for U.S. Appl. No. 11/313,633 (Apr. 29, 2008).|
|35||Final Official Action for U.S. Appl. No. 11/314,842 (Apr. 1, 2008).|
|36||Final Official Action for U.S. Appl. No. 11/342,168 (Nov. 19, 2010).|
|37||Final Official Action for U.S. Appl. No. 11/342,170 (Mar. 4, 2010).|
|38||First Office Action for Japanese Patent Application No. 2008-525046 (Nov. 8, 2011).|
|39||First Office Action for Japanese Patent Application No. 2008-525047 (Nov. 8, 2011).|
|40||Gal et al. "Algorithms and Data Structures for Flash Memories," ACM Computing Surveys (CSUR) vol. 37, Issue 2, pp. 138-163, (Jun. 2005).|
|41||Hitz, D. et al., "File System Design for an NFS File Server Appliance," Network Appliance Technical Report 3002 Retrieved from http://citeseer.ist.psu.edu/hitz95file.html (Jan. 19, 1994).|
|42||Imamiya et al., "A 125-mm2 1-Gb NAND Flash Memory with 10-Mbyte/s Program Speed," IEEE Journal of Solid-State Circuits, vol. 37, No. 11, pp. 1493-1501, (Nov. 2002).|
|43||International Preliminary Report on Patentability for International Application No. PCT/US2006/004555 (Aug. 21, 2007).|
|44||International Preliminary Report on Patentability for International Application No. PCT/US2006/004585 (Aug. 21, 2007).|
|45||International Preliminary Report on Patentability for International Application No. PCT/US2006/004658 (Aug. 21, 2007).|
|46||International Search Report for International Application No. PCT/US2006/004658 (Aug. 23, 2006).|
|47||Interview Summary for U.S. Appl. No. 11/060,249 (May 8, 2009).|
|48||Interview Summary for U.S. Appl. No. 11/196,826 (Nov. 30, 2011).|
|49||Interview Summary for U.S. Appl. No. 11/313,567 (Feb. 2, 2009).|
|50||Interview Summary for U.S. Appl. No. 11/313,567 (Jan. 16, 2008).|
|51||Interview Summary for U.S. Appl. No. 11/313,567 (Nov. 5, 2009).|
|52||Interview Summary for U.S. Appl. No. 11/313,633 (Nov. 5, 2009).|
|53||Interview Summary for U.S. Appl. No. 11/314,842 (Feb. 23, 2010).|
|54||Interview Summary for U.S. Appl. No. 11/314,842 (Jan. 16, 2008).|
|55||Kim et al., "A Space-Efficient Flash Translation Layer for CompactFlash Systems," IEEE Transactions on Consumer Electronics, vol. 48, No. 2, pp. 366-375, (May 2002).|
|56||Kim, et al., "A New Flash Memory Management for Flash Storage System," Computer Software and Applications Conference, 1999. Compsac '99 Proceedings. IEEE Comput. Soc., pp. 284-289 (1999).|
|57||Kjelso et al., "Memory Management in Flash-Memory Disks with Data Compression," Springer-Verlag, pp. 399-413 (1995).|
|58||Kolowsky, "Introduction to MTP: Media Transfer Protocol," Cypress Semiconductor (Publication Date Unknown).|
|59||Lai/The Waite Group, "Writing MS-DOSŪ Device Drivers," Second Edition, pp. 240-253 (2002).|
|60||Lim et al., "An Efficient NAND Flash File System for Flash Memory Storage," IEEE Transactions on Computer, vol. 55, No. 7, pp. 906-912 (Jul. 1, 2006).|
|61||Microsoft Computer Dictionary, Microsoft Press, 2002, Fifth Edition, p. 151.|
|62||Notice of Abandonment for U.S. Appl. No. 11/060,174 (Jul. 2, 2010).|
|63||Notice of Allowance and Fee(s) due for U.S. Appl. No. 10/772,789 (Jun. 16, 2006).|
|64||Notice of Allowance and Fee(s) due for U.S. Appl. No. 10/772,855 (Feb. 21, 2006).|
|65||Notice of Allowance and Fee(s) due for U.S. Appl. No. 10/772,855 (Jun. 16, 2006).|
|66||Notice of Allowance and Fee(s) Due for U.S. Appl. No. 11/060,249 (Sep. 21, 2010).|
|67||Notice of Allowance and Fee(s) Due for U.S. Appl. No. 11/196,168 (Jul. 16, 2009).|
|68||Notice of Allowance and Fee(s) Due for U.S. Appl. No. 11/313,633 (Mar. 22, 2010).|
|69||Notice of Allowance and Fee(s) Due for U.S. Appl. No. 11/314,842 (Apr. 29, 2010).|
|70||Notice of Allowance for Taiwanese Patent Application No. 095148077 (Jun. 22, 2011).|
|71||Notice of Allowance for U.S. Appl. No. 11/313,567 (Feb. 12, 2010).|
|72||Notice of Non-Compliant Appeal Brief for U.S. Appl. No. 11/060,249 (Feb. 22, 2010).|
|73||Notification Concerning the Transmittal of International Preliminary Report on Patentability for International Application No. PCT/US2006/062340 (Jul. 3, 2008).|
|74||Notification Concerning Transmittal of International Preliminary Report on Patentability for International Application No. PCT/US2006/029306 (Feb. 14, 2008).|
|75||Notification Concerning Transmittal of International Preliminary Report on Patentability for International Application No. PCT/US2006/062341 (Jul. 3, 2008).|
|76||Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2006/004555 (Oct. 4, 2006).|
|77||Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2006/029306 (Mar. 9, 2007).|
|78||Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2006/062340 (Oct. 29, 2007).|
|79||Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority, or the Declaration for International Application No. PCT/US2006/062341 (Jun. 26, 2007).|
|80||Notification of Transmittal of the International Search Report and the Written Opinion of the InternationalSearching Authority, or the Declaration for International Application No. PCT/US2006/004585 (Aug. 17, 2006).|
|81||Noting of loss of rights pursuant to Rule 112(1) EPC for European Application No. 06734695.7 (Jan. 21, 2009).|
|82||Noting of loss of rights pursuant to Rule 112(1) EPC for European Application No. 067720547.6 (Jan. 20, 2009).|
|83||Official Action for Taiwanese Application No. 095148077 (Feb. 8, 2010).|
|84||Official Action for Taiwanese Patent Application No. 095128233 (Aug. 11, 2009).|
|85||Official Action for U.S. Appl. No. 10/772,789, (Mar. 24, 2006).|
|86||Official Action for U.S. Appl. No. 11/060,174 (Jul. 24, 2008).|
|87||Official Action for U.S. Appl. No. 11/060,174 (Mar. 27, 2007).|
|88||Official Action for U.S. Appl. No. 11/060,248 (Apr. 5, 2007).|
|89||Official Action for U.S. Appl. No. 11/060,248 (Aug. 14, 2008).|
|90||Official Action for U.S. Appl. No. 11/060,249 (Apr. 13, 2007).|
|91||Official Action for U.S. Appl. No. 11/060,249 (Aug. 4, 2008).|
|92||Official Action for U.S. Appl. No. 11/196,168 (Dec. 24, 2008).|
|93||Official Action for U.S. Appl. No. 11/196,168 (Nov. 28, 2007).|
|94||Official Action for U.S. Appl. No. 11/313,567 (Jan. 6, 2009).|
|95||Official Action for U.S. Appl. No. 11/313,567 (Jun. 15, 2009).|
|96||Official Action for U.S. Appl. No. 11/313,567 (Oct. 9, 2007).|
|97||Official Action for U.S. Appl. No. 11/313,633 (Jan. 6, 2009).|
|98||Official Action for U.S. Appl. No. 11/313,633 (Jul. 17, 2009).|
|99||Official Action for U.S. Appl. No. 11/313,633 (Oct. 9, 2007).|
|100||Official Action for U.S. Appl. No. 11/314,842 (May 8, 2009).|
|101||Official Action for U.S. Appl. No. 11/314,842 (Oct. 26, 2009).|
|102||Official Action for U.S. Appl. No. 11/314,842 (Oct. 9, 2007).|
|103||Official Action for U.S. Appl. No. 11/314,842 (Sep. 15, 2008).|
|104||Official Action for U.S. Appl. No. 11/342,168 (Aug. 19, 2008).|
|105||Official Action for U.S. Appl. No. 11/342,168 (Dec. 26, 2007).|
|106||Official Action for U.S. Appl. No. 11/342,168 (Mar. 4, 2009).|
|107||Official Action for U.S. Appl. No. 11/342,170 (Dec. 14, 2007).|
|108||Official Action for U.S. Appl. No. 11/342,170 (May 20, 2009).|
|109||Official Action for U.S. Appl. No. 11/342,170 (Oct. 17, 2009).|
|110||PNY Technologies Attache Flash Product, http://www.pny.com/products/flash/attache.asp (Copyright 2003).|
|111||Rankl, Wolfgang, "Smart Card Handbook," Third Edition, Translated by Kenneth Cox, John Wiley & Sons, Ltd., pp. 52-93, 233-369, & 435-490, (2004).|
|112||Taiwanese Allowance Decision for Taiwanese application No. 095148079 (Nov. 28, 2010).|
|113||Taiwanese Office Action for Taiwanese Patent Application No. 095148079 (Apr. 23, 2010).|
|114||Taiwanese Office Action for Taiwanese Patent Application No. 09514877 (Sep. 10, 2010).|
|115||Written Opinion of the International Searching Authority for International Application No. PCT/US2005/000275 (Aug. 7, 2006).|
|116||Wu et al., "Envy: A Non-Volatile, Main Memory Storage System," ACM Sigplan Notices, vol. 29, No. 11, pp. 86-97, (Nov. 1, 1994).|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US9104315||Aug 3, 2005||Aug 11, 2015||Sandisk Technologies Inc.||Systems and methods for a mass data storage system having a file-based interface to a host and a non-file-based interface to secondary storage|
|U.S. Classification||711/203, 707/E17.01, 707/831, 711/102, 711/E12.001|
|Cooperative Classification||G06F3/0638, G06F3/0679, G06F3/0607|
|European Classification||G06F3/06A4F, G06F3/06A6L2F, G06F3/06A2A4|
|Jun 1, 2011||AS||Assignment|
Owner name: SANDISK TECHNOLOGIES INC., TEXAS
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:SANDISK CORPORATION;REEL/FRAME:026368/0471
Effective date: 20110404
|Dec 9, 2015||FPAY||Fee payment|
Year of fee payment: 4