A data storage subsystem is disclosed that implements a process for storing and/or reconstructing system data, such as a system mapping table. In certain embodiments, table pages are systematically copied, or flushed, to non-volatile memory in a progressive manner, according to a fixed ratio of flushed table pages per table update trigger, thereby facilitating write and/or load efficiency. Full or partial reconstruction of a table may be performed within a bounded number of operations based on the size of the table, the ratio implemented, and/or other characteristics.
|
1. A method of storing and recovering a segmented system table having y table pages in a data storage system, the method comprising:
in response to updating a first table page of the segmented system table in a volatile memory:
flushing the updated first table page from the volatile memory to a non-volatile memory; and
flushing, from the volatile memory to the non-volatile memory, one or more additional table pages of the segmented system table in the volatile memory based at least on a predetermined ratio of a number of flushed table pages to a number of segmented system table update triggers to keep table pages in the non-volatile memory updated, wherein the one or more additional table pages are different from the first table page;
loading a set of z table pages divided into a plurality of segments from the non-volatile memory to the volatile memory according to individual segments;
determining whether a host data access request accessing an address within a yet-to-be loaded segment of the plurality of segments is pending;
processing a segment containing the address of the host data access request when it is determined that the host data access request is pending and is within the yet-to-be loaded segment of the plurality of segments;
locating and copying into the volatile memory, by individual segment, a most up-to date version of each table page contained in the individual segment; and
recovering the segmented system table using a number of load operations less than or equal to twice a size of the segmented system table measured in segments.
4. A non-volatile storage system comprising:
a non-volatile memory configured to store data;
a volatile memory; and
a controller configured to store and recover a segmented system table having y table pages by:
in response to updating a first table page of the segmented system table in the volatile memory:
flushing the updated first table page from the volatile memory to the non-volatile memory; and
flushing, from the volatile memory to the non-volatile memory, one or more additional table pages of the segmented system table in the volatile memory based at least on a predetermined ratio of a number of flushed table pages to a number of segmented system table update triggers to keep table pages in the non-volatile memory updated, wherein the one or more additional table pages are different from the first table page;
loading a set of z table pages divided into a plurality of segments from a non-volatile memory to a volatile memory according to individual segments;
determining whether a host data access request accessing an address within a yet-to-be loaded segment of the plurality of segments is pending;
processing a segment containing the address of the host data access request when it is determined that a host data access request is pending and is within the yet-to-be loaded segment of the plurality of segments;
locating and copying into the volatile memory, by individual segment, a most up-to date version of each table page contained in the individual segment; and
recovering the segmented system table using a number of operations less than or equal to twice a size of the segmented system table measured in segments.
2. The method of
3. The method of
5. The non-volatile storage system of
6. The non-volatile storage system of
|
This application is a continuation of U.S. patent application Ser. No. 13/478,036 filed May 22, 2012, entitled “System Data Storage Mechanism Providing Coherency and Segmented Data Loading,” the contents of which are expressly incorporated by reference herein in its entirety and for all purposes.
This disclosure relates to non-volatile storage subsystems. More particularly, the disclosure relates to systems and methods for storing and loading system table data.
Non-volatile storage systems can include system tables, such as tables containing logical-to-physical address mapping data. Such data may associate logical addresses used by a host system with corresponding physical storage locations in the non-volatile storage system. In certain circumstances, it may be desirable for system table data to be loaded from non-volatile memory into volatile memory, along with log data that indicates changes to a system table. However, loading and updating system table data can incur delays for memory accesses.
Systems and methods that embody the various features of the invention will now be described with reference to the following drawings, in which:
While certain embodiments are described, these embodiments are presented by way of example only, and are not intended to limit the scope of protection. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms. Furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made without departing from the scope of protection.
Overview
Data storage systems may include system tables having various sizes and/or characteristics. With respect to system tables of certain sizes, it may be desirable to periodically store table data and/or table change logs, in non-volatile memory in order to avoid unwanted data loss. However, storage of table data may make present various data storage and/or loading efficiency or reliability concerns. Furthermore, loading partial segments of system table data may be difficult in systems with inadequate, or complicated, data coherency characteristics. As used in this application, a “segment” refers broadly to any partition, division, or portion of a whole. Segments may or may not be of equal size and the size of a segment may vary over time.
Certain data storage systems implement progressive copying, or “flushing” of system table data from volatile memory to non-volatile storage. Data coherency may be relatively easier to attain in such systems, though write and/or load time considerations may need to be taken into account. In addition, the ability to load partial segments of table data efficiently may be a concern.
In some embodiments of the present invention, system data is stored in a progressive manner, without the use of log data. In certain embodiments, such a system may allow for satisfactory loading of partial segments of table data, while maintaining satisfactory levels of data coherency.
System Overview
In non-volatile storage devices, such as solid-state storage devices, commands can be received from a host designating a logical memory address. The logical memory address can then be converted into a physical address corresponding to a storage location on the non-volatile media. This logical-to-physical address mapping may be maintained in a mapping table in volatile memory of a controller of the storage device. As changes are made to the mapping table in volatile memory, the controller may periodically save a copy of the mapping table, or pages of the mapping table, to the non-volatile storage array to ensure that the mapping table can be reconstructed in the volatile memory when power is lost. Because the mapping table can comprise a significant amount of data (e.g. 256 Mb for a 256 Gb drive), changes to the mapping table made between saves to the non-volatile storage array can be recorded in a log of mapping table changes and the log can also be saved to non-volatile memory. Alternatively, in certain embodiments disclosed herein, table pages are updated and flushed progressively, such that log pages are unnecessary. Progressive flushing of table pages may allow for recording of changes without the need for log pages. On system power up, table data in the non-volatile memory may be loaded to the volatile memory prior to servicing any media access requests to ensure the logical addresses resolve to the proper locations on the storage array.
The term “non-volatile memory” is used herein according to its broad and ordinary meaning, and may refer to solid-state memory such as NAND flash. However, the systems and methods of this disclosure may also be useful in more conventional hard drives and hybrid drives including both solid-state and hard drive components. Solid-state memory may comprise a wide variety of technologies, such as flash integrated circuits, Chalcogenide RAM (C-RAM), Phase Change Memory (PC-RAM or PRAM), Programmable Metallization Cell RAM (PMC-RAM or PMCm), Ovonic Unified Memory (OUM), Resistance RAM (RRAM), NAND memory, NOR memory, EEPROM, Ferroelectric Memory (FeRAM), or other discrete NVM (non-volatile memory) chips. The solid-state storage devices may be physically divided into planes, blocks, pages, and sectors, as is known in the art. Other forms of storage (e.g., battery backed-up volatile DRAM or SRAM devices, magnetic disk drives, etc.) may additionally or alternatively be used.
The controller 130 can be configured to receive data and/or storage access commands from a storage interface module 112 (e.g., a device driver) in a host system 110. Storage access commands communicated by the storage interface 112 can include read and/or write commands issued by the host system 110. Read and write commands can specify a logical block address in the storage system 120. The controller 130 can execute the received commands in the non-volatile memory module 150, for example. In certain embodiments, the controller can include memory (e.g., DRAM) for storing data, such as system table data. In certain embodiments, one or more of the depicted devices or modules may be omitted, such as, for example, magnetic storage 160.
The solid-state memory module 150 may be implemented using NAND flash memory devices. Other types of solid-state memory devices can alternatively be used. In one embodiment, the memory devices are MLC devices, SLC memory devices, or a combination of SLC and MLC devices.
The data storage system 120 can store data communicated by the host system 110. That is, the storage system 120 can act as memory storage for the host system 110. To facilitate this function, the controller 130 can implement a logical interface that can present to the host system 110 storage system's 120 memory as a set of logical addresses (e.g., contiguous address) where data can be stored. Internally, the controller 130 can map logical addresses to various physical memory addresses in the non-volatile memory module 150 and/or the magnetic media 164.
In one embodiment, at least a portion of the solid state memory module 150 can be used as cache. The controller 130 can store data communicated by the host system 110 in the solid-state memory 150. To improve performance of the storage system 120 and/or host system 110, in some embodiments, various types of data can be stored in non-volatile memory cache, including frequently accessed data, data accessed at start-up (e.g., following a reset or power down), system data, sequentially accessed data, etc.
With continued reference to
The controller 130 depicted in
Table Storage Structure
In the example shown, superblocks 0 and 1 contain pages of the system table. In certain embodiments, table data storage in accordance with one or more embodiments of the present disclosure may be desirable for storage of large system tables. For example, superblocks 0 and 1 may contain a large system table, wherein the pages of the table are disposed in sequential order within the superblocks. As shown, superblock 0 includes table pages T0 through T1023, while superblock 1 includes table pages T1024 through T2047. Assuming this is the state at power-up, a copy of the table is loaded into volatile memory.
Superblock 2 contains one or more table pages stored in response to one or more system update triggers. In certain embodiments, superblock 2 may contain table pages according to a pre-defined ratio of table pages flushed for each table update trigger event. For example, in a storage system utilizing a ratio of 2 to 1, whenever a table page is updated in the volatile memory in response to a host request, an additional page of table data is flushed to the non-volatile storage. In such an embodiment, two pages are written per update trigger. The ratio of two pages written per update trigger may require that two times the number of bare minimum superblocks number of operations, plus 1, is required to perform active writes. As shown in
Progressive flushing of table data, as described herein, may allow for large system data to be stored without single block restrictions. Furthermore, such methods may provide bounded segmented system data loading.
Table Reconstruction
When the command involves a system table update, the process 400 includes copying the updated table page to non-volatile memory at block 408. In addition, one or more additional pages of table data are copied to nonvolatile memory in response to the host command. A first additional table page Tn is copied to the non-volatile memory at block 410. At decision block 412, it is determined whether variable n is equal to Ttotal−1, wherein Ttotal is a variable representing the total number of pages of the system table. If not, the variable n is incremented at block 414, and the process 400 is directed to decision block 418, where it is determined whether additional table pages are to be copied to meet a predefined ratio of copied pages to system table update triggers. The process 400 may be implemented according to any suitable ratio of copied pages to system table update triggers. For example, the ratio of copied pages to system table update triggers may be 2 to 1, 3 to 1, 4 to 1, or any other ratio.
When it is determined at block 412 that variable n is equal to Ttotal−1, the process 400 proceeds to block 416, where variable n is reset to zero. When additional table pages are to be copied in order to meet the predefined ratio, the process 400 loops back to block 410, and continues in a loop until the ratio of copied table pages to system table update triggers has been met. Once the ratio has been met, the process 400 proceeds to decision block 420, where it is determined whether the host system command requires additional table pages to be updated. If so, the process 400 is directed back to block 408, and the process 400 proceeds from that point. When additional table pages are to be updated in response to the command received from the host system, the process 400 proceeds back to block 404 where another command is received from the host system. From that point, the process 400 may proceed as described above.
The process 500A proceeds to decision block 510 where it is determined whether the most recently read table page has been previously read in the reconstruction process 500A. If not, at block 512, the system table in volatile storage is updated with respect to the most recently read table page. The process 500A proceeds to decision block 514 where it is determined whether the variable PagesRead is less than the product of Ttotal times ((R+1)/R), wherein R represents a predefined ratio of table pages flushed or copied to nonvolatile memory per system table update trigger, as described above. If not, the process 500A is terminated at block 518, and the system table has been fully reconstructed.
If the variable PagesRead is determined to be less than Ttotal×((R+1)/R), then the process 500A proceeds to block 516 where the next most recently copied table page is read. The process 500A proceeds in the loop until the number of pages read is equal to the bounded value of Ttotal×((R+1)/R). In certain embodiments, the process 500A provides the benefit of bounded system data loading.
In certain embodiments, the process 500B proceeds to decision block 507, though in other embodiments, the process 500B may bypass decision block 507, as well as block 515, and proceed to decision block 509. At decision block 507, it is determined whether a host data access request accessing an address within a yet-to-be-loaded segment is pending. If such a host segment request is pending, the variable n is set to the requested host segment, the process 500B thereafter proceeding to process the requested host segment. At decision block 517 it is determined whether segment Segn has been previously loaded to volatile memory. If it has not, the process 500B progresses to block 505, where Segn is loaded. If it is determined at block 517 that Segn has been previously loaded, the process 500B proceeds to decision block 507 where, as described above, it is determined whether a host segment request is pending.
If at decision block 507 it is determined that no host segment request is currently pending, or if decision block 507 is bypassed, the process 500B proceeds to decision block 509, wherein it is determined whether the variable i is less than two times the value of a variable Ts, wherein Ts represents the this size of the system table in segments. For example, in an embodiment comprising a system table having four segments of table data, it would be determined at decision block 509 whether the variable i is less than eight. If the variable i does meet the condition of decision block 509, process 500B progresses to block 511 where the variable i is incremented. The process further progresses to block 513 where the variable n is set to equal the current value of the variable i. The process 500B further proceeds to decision block 517, where, as discussed above, it is determined whether segment Segn has been previously loaded to volatile memory. If, at decision block 509, it is determined that i is not less than two times the variable Ts, the process 500B terminates at block 518, and the system table is fully reconstructed.
Data storage systems in accordance with one or more embodiments disclosed herein may provide one or more of the following benefits. For example, one embodiment is a progressive flushing approach may keep each executed command at a small bounded execution time. Another embodiment includes a system table storage mechanism that is optimal for large sequential host writes. Another embodiment includes a storage mechanism that can support large system tables; while another embodiment is a method to load segmented data. Some of the embodiments avoid the complexity of logs—the large sequential use case may make this mechanism particularly useful. Furthermore one or more of the following goals may be achieved through implementation of a data storage system in accordance with one or more embodiments disclosed herein: Improved power-up time, by reconstructing in real-rime as commands are accepted; necessary segments of system data can be loaded on demand; large system data can use this approach and still maintain a good command response time during reconstruction; large sequential host writes may be optimized, particularly when the table pages updated are also sequential; command response time may be uniform based on the progressive table flushes; and avoidance of large burst writes.
Conclusion
Data storage systems may include system tables having various sizes and/or characteristics. With respect to system tables of certain sizes, it may be desirable to periodically store table data and/or table change logs, in non-volatile memory in order to avoid unwanted data loss. However, storage of table data may make present various data storage and/or loading efficiency concerns. Furthermore, loading partial segments of system table data may be difficult in systems with inadequate, or complicated, data coherency characteristics.
As described herein, certain data storage systems may implement progressive copying, or “flushing,” of system table data to non-volatile storage, wherein one or more additional table pages or segments are flushed to the nonvolatile storage for every table update trigger. Such systems may benefit from improved data storage and/or loading efficiency.
Other Variations
As used in this application, “non-volatile memory” typically refers to solid-state memory such as, but not limited to, NAND flash. However, the systems and methods of this disclosure may also be useful in more conventional hard drives and hybrid hard drives including both solid-state and hard drive components. The solid-state storage devices (e.g., dies) may be physically divided into planes, blocks, pages, and sectors, as is known in the art. Other forms of storage (e.g., battery backed-up volatile DRAM or SRAM devices, magnetic disk drives, etc.) may additionally or alternatively be used.
Those skilled in the art will appreciate that in some embodiments, other types of system table storage and/or reconstruction can be implemented. In addition, the actual steps taken in the processes shown in
While certain embodiments have been described, these embodiments have been presented by way of example only, and are not intended to limit the scope of protection. Indeed, the novel methods and systems described herein may be embodied in a variety of other forms. Furthermore, various omissions, substitutions and changes in the form of the methods and systems described herein may be made. The accompanying claims and their equivalents are intended to cover such forms or modifications as would fall within the scope and spirit of the protection. For example, the various components illustrated in the figures may be implemented as software and/or firmware on a processor, ASIC/FPGA, or dedicated hardware. Also, the features and attributes of the specific embodiments disclosed above may be combined in different ways to form additional embodiments, all of which fall within the scope of the present disclosure. Although the present disclosure provides certain preferred embodiments and applications, other embodiments that are apparent to those of ordinary skill in the art, including embodiments which do not provide all of the features and advantages set forth herein, are also within the scope of this disclosure. Accordingly, the scope of the present disclosure is intended to be defined only by reference to the appended claims.
Lo, Jerry, Suryabudi, Dominic S., Phan, Lan D.
Patent | Priority | Assignee | Title |
11256619, | May 05 2019 | Microsoft Technology Licensing, LLC | Memory management for serverless databases |
Patent | Priority | Assignee | Title |
5835955, | Jun 23 1995 | PDACO LTD | Disk array controller with enhanced synchronous write |
6615223, | Feb 29 2000 | ORACLE INTERNATIONAL CORPORATION OIC | Method and system for data replication |
6651073, | May 23 2000 | International Business Machines Corporation | Method and apparatus for insuring database data integrity without data recovery logging |
6728826, | Jun 22 1992 | EMERGENCE MEMORY SOLUTIONS LLC | Semiconductor storage device in which commands are sequentially fed to a plurality of flash memories to continuously write data |
6856556, | Apr 03 2003 | INNOVATIVE MEMORY SYSTEMS, INC | Storage subsystem with embedded circuit for protecting against anomalies in power signal from host |
7126857, | Apr 03 2003 | INNOVATIVE MEMORY SYSTEMS, INC | Storage subsystem with embedded circuit for protecting against anomalies in power signal from host |
7212440, | Dec 30 2004 | SanDisk Technologies, Inc | On-chip data grouping and alignment |
7430136, | Nov 30 2004 | Western Digital Technologies, INC | Purge operations for solid-state storage devices |
7447807, | Jun 30 2006 | Western Digital Technologies, INC | Systems and methods for storing data in segments of a storage subsystem |
7502256, | Nov 30 2004 | Western Digital Technologies, INC | Systems and methods for reducing unauthorized data recovery from solid-state storage devices |
7502259, | Dec 30 2004 | SanDisk Technologies, Inc | On-chip data grouping and alignment |
7509441, | Jun 30 2006 | Western Digital Technologies, INC | Systems and methods for segmenting and protecting a storage subsystem |
7596643, | Feb 07 2007 | Western Digital Technologies, INC | Storage subsystem with configurable buffer |
7653778, | May 08 2006 | Western Digital Technologies, INC | Systems and methods for measuring the useful life of solid-state storage devices |
7685337, | May 24 2007 | Western Digital Technologies, INC | Solid state storage subsystem for embedded applications |
7685338, | May 24 2007 | Western Digital Technologies, INC | Solid state storage subsystem for embedded applications |
7685374, | Jul 26 2007 | Western Digital Technologies, INC | Multi-interface and multi-bus structured solid-state storage subsystem |
7702868, | Jul 13 2005 | ACQUIOM AGENCY SERVICES LLC, AS ASSIGNEE | Restoring data with reduced suspension-of-access periods |
7711923, | Jun 23 2006 | Microsoft Technology Licensing, LLC | Persistent flash memory mapping table |
7733712, | May 20 2008 | Western Digital Technologies, INC | Storage subsystem with embedded circuit for protecting against anomalies in power signal from host |
7765373, | Jun 27 2006 | Western Digital Technologies, INC | System for controlling use of a solid-state storage subsystem |
7898855, | Nov 30 2004 | Western Digital Technologies, INC | Systems and methods for reducing unauthorized data recovery from solid-state storage devices |
7912991, | Jun 30 2006 | Western Digital Technologies, INC | Systems and methods for segmenting and protecting a storage subsystem |
7913061, | Dec 30 2003 | SanDisk Technologies LLC | Non-volatile memory and method with memory planes alignment |
7936603, | Nov 30 2004 | Western Digital Technologies, INC | Purge operations for solid-state storage devices |
7962792, | Feb 11 2008 | Western Digital Technologies, INC | Interface for enabling a host computer to retrieve device monitor data from a solid state storage subsystem |
8078918, | Feb 07 2008 | Western Digital Technologies, INC | Solid state storage subsystem that maintains and provides access to data reflective of a failure risk |
8090899, | Mar 04 2009 | Western Digital Technologies, Inc.; Western Digital Technologies, INC | Solid state drive power safe wear-leveling |
8095851, | Sep 06 2007 | Western Digital Technologies, INC | Storage subsystem capable of adjusting ECC settings based on monitored conditions |
8108692, | Jun 27 2006 | Western Digital Technologies, INC | Solid-state storage subsystem security solution |
8122185, | May 08 2006 | Western Digital Technologies, INC | Systems and methods for measuring the useful life of solid-state storage devices |
8127048, | Jun 30 2006 | Western Digital Technologies, INC | Systems and methods for segmenting and protecting a storage subsystem |
8135903, | Oct 30 2009 | Western Digital Technologies, INC | Non-volatile semiconductor memory compressing data to improve performance |
8151020, | Feb 07 2007 | Western Digital Technologies, INC | Storage subsystem with configurable buffer |
8161227, | Oct 30 2006 | Western Digital Technologies, INC | Storage subsystem capable of programming field-programmable devices of a target computer system |
8166245, | Jul 26 2007 | Western Digital Technologies, INC | Multi-interface and multi-bus structured solid-state storage subsystem |
8194340, | Mar 18 2010 | Western Digital Technologies, Inc.; Western Digital Technologies, INC | Disk drive framing write data with in-line mapping data during write operations |
8194341, | Mar 18 2010 | Western Digital Technologies, Inc.; Western Digital Technologies, INC | Disk drive seeding data path protection with system data seed |
8243525, | Sep 30 2009 | Western Digital Technologies, INC | Refreshing non-volatile semiconductor memory by reading without rewriting |
8254172, | Sep 30 2009 | Western Digital Technologies, INC | Wear leveling non-volatile semiconductor memory based on erase times and program times |
8261012, | Oct 30 2009 | PALISADE TECHNOLOGIES, LLP | Non-volatile semiconductor memory comprising power fail circuitry for flushing write data in response to a power fail signal |
8296625, | Sep 06 2007 | Western Digital Technologies, INC | Storage subsystem capable of adjusting ECC settings based on monitored conditions |
8312207, | May 08 2006 | Western Digital Technologies, INC | Systems and methods for measuring the useful life of solid-state storage devices |
8316176, | Feb 17 2010 | Western Digital Technologies, INC | Non-volatile semiconductor memory segregating sequential data during garbage collection to reduce write amplification |
8341339, | Jun 14 2010 | Western Digital Technologies, INC | Hybrid drive garbage collecting a non-volatile semiconductor memory by migrating valid data to a disk |
8375151, | Feb 12 2009 | SanDisk Technologies, Inc | Command portal for securely communicating and executing non-standard storage subsystem commands |
8392635, | Dec 22 2010 | SanDisk Technologies, Inc | Selectively enabling a host transfer interrupt |
8397107, | Dec 11 2009 | SanDisk Technologies, Inc | Data storage device employing data path protection using both LBA and PBA |
8407449, | Feb 26 2010 | SanDisk Technologies, Inc | Non-volatile semiconductor memory storing an inverse map for rebuilding a translation table |
8423722, | Aug 26 2011 | SanDisk Technologies, Inc | System and method for high performance command processing in solid state drives |
8433858, | Jul 26 2007 | SanDisk Technologies, Inc | Multi-interface and multi-bus structured solid-state storage subsystem |
8443167, | Dec 16 2009 | Western Digital Technologies, Inc.; Western Digital Technologies, INC | Data storage device employing a run-length mapping table and a single address mapping table |
8447920, | Jun 29 2010 | SanDisk Technologies, Inc | System and method for managing data access in non-volatile memory |
8458435, | Dec 20 2010 | SanDisk Technologies, Inc | Sequential write thread detection |
8478930, | Mar 04 2009 | Western Digital Technologies, INC | Solid state drive power safe wear-leveling |
8489854, | Feb 26 2010 | Western Digital Technologies, INC | Non-volatile semiconductor memory storing an inverse map for rebuilding a translation table |
8503237, | May 18 2011 | Western Digital Technologies, INC | System and method for data recovery in a solid state storage device |
8521972, | Jun 30 2010 | Western Digital Technologies, INC | System and method for optimizing garbage collection in data storage |
8549236, | Dec 15 2006 | Western Digital Technologies, INC | Storage subsystem with multiple non-volatile memory arrays to protect against data losses |
8582223, | Jan 31 2012 | Western Digital Technologies, INC | Methods and devices for two-dimensional iterative multi-track based map detection |
8583835, | Aug 06 2008 | Western Digital Technologies, INC | Command portal for executing non-standard storage subsystem commands |
8601311, | Dec 14 2010 | Western Digital Technologies, INC | System and method for using over-provisioned data capacity to maintain a data redundancy scheme in a solid state memory |
8601313, | Dec 13 2010 | Western Digital Technologies, INC | System and method for a data reliability scheme in a solid state memory |
8612669, | Jun 28 2010 | Western Digital Technologies, INC | System and method for performing data retention in solid-state memory using copy commands and validity and usage data |
8612804, | Sep 30 2010 | Western Digital Technologies, INC | System and method for improving wear-leveling performance in solid-state memory |
8615681, | Dec 14 2010 | Western Digital Technologies, INC | System and method for maintaining a data redundancy scheme in a solid state memory in the event of a power loss |
8638602, | Sep 10 2010 | Western Digital Technologies, INC | Background selection of voltage reference values for performing memory read operations |
8639872, | Aug 13 2010 | Western Digital Technologies, Inc. | Hybrid drive comprising write cache spanning non-volatile semiconductor memory and disk |
8683113, | Feb 04 2011 | Western Digital Technologies, INC | Concurrently searching multiple devices of a non-volatile semiconductor memory |
8700834, | Sep 06 2011 | Western Digital Technologies, INC | Systems and methods for an enhanced controller architecture in data storage systems |
8700950, | Feb 11 2011 | Western Digital Technologies, INC | System and method for data error recovery in a solid state subsystem |
8700951, | Mar 09 2011 | Western Digital Technologies, INC | System and method for improving a data redundancy scheme in a solid state subsystem with additional metadata |
8706985, | Jun 30 2010 | Western Digital Technologies, INC | System and method for optimizing garbage collection in data storage |
8707104, | Sep 06 2011 | Western Digital Technologies, Inc. | Systems and methods for error injection in data storage systems |
8713066, | Mar 29 2010 | Western Digital Technologies, INC | Managing wear leveling and garbage collection operations in a solid-state memory using linked lists |
8713357, | Sep 06 2011 | Western Digital Technologies, INC | Systems and methods for detailed error reporting in data storage systems |
8719531, | Jun 14 2011 | Western Digital Technologies, INC | System and method for performing data retention that incorporates environmental conditions |
8724422, | Feb 29 2012 | Western Digital Technologies, Inc. | System and method for charging back-up charge storage element for data storage device using spindle phase switching elements |
8725931, | Mar 26 2010 | Western Digital Technologies, INC | System and method for managing the execution of memory commands in a solid-state memory |
8745277, | Aug 06 2008 | Western Digital Technologies, INC | Command portal for securely communicating and executing non-standard storage subsystem commands |
8751728, | Apr 29 2011 | Western Digital Technologies, INC | Storage system bus transfer optimization |
8769190, | Sep 15 2010 | Western Digital Technologies, INC | System and method for reducing contentions in solid-state memory access |
8769232, | Apr 06 2011 | Western Digital Technologies, INC | Non-volatile semiconductor memory module enabling out of order host command chunk media access |
8775720, | Aug 31 2010 | Western Digital Technologies, Inc. | Hybrid drive balancing execution times for non-volatile semiconductor memory and disk |
8782327, | May 11 2010 | Western Digital Technologies, INC | System and method for managing execution of internal commands and host commands in a solid-state memory |
8788778, | Jun 04 2012 | SanDisk Technologies, Inc | Garbage collection based on the inactivity level of stored data |
8788779, | Sep 17 2010 | Western Digital Technologies, INC | Non-volatile storage subsystem with energy-based performance throttling |
8788880, | Aug 22 2012 | Western Digital Technologies, INC | Efficient retry mechanism for solid-state memory failures |
8793429, | Jun 03 2011 | Western Digital Technologies, INC | Solid-state drive with reduced power up time |
8966205, | May 10 2012 | Western Digital Technologies, INC | System data management using garbage collection and hybrid self mapping |
8984247, | May 10 2012 | Western Digital Technologies, INC | Storing and reconstructing mapping table data in a data storage system |
9170932, | May 22 2012 | Western Digital Technologies, INC | System data storage mechanism providing coherency and segmented data loading |
20020184436, | |||
20030065899, | |||
20040210706, | |||
20050166028, | |||
20080082775, | |||
20080098195, | |||
20090150599, | |||
20100106897, | |||
20100174849, | |||
20100180068, | |||
20100250793, | |||
20100262799, | |||
20110029720, | |||
20110099323, | |||
20110161621, | |||
20110173395, | |||
20110283049, | |||
20110296231, | |||
20110307651, | |||
20120110258, | |||
20120239860, | |||
20120260020, | |||
20120265924, | |||
20120278531, | |||
20120284460, | |||
20120324191, | |||
20130132638, | |||
20130145106, | |||
20130166819, | |||
20130185508, | |||
20130290793, | |||
20140059405, | |||
20140101369, | |||
20140115427, | |||
20140133220, | |||
20140136753, | |||
20140149826, | |||
20140157078, | |||
20140181432, | |||
20140223255, |
Executed on | Assignor | Assignee | Conveyance | Frame | Reel | Doc |
May 17 2012 | LO, JERRY | Western Digital Technologies, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037948 | /0251 | |
May 17 2012 | SURYABUDI, DOMINIC S | Western Digital Technologies, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037948 | /0251 | |
Jul 24 2012 | PHAN, LAN D | Western Digital Technologies, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 037948 | /0251 | |
Oct 26 2015 | Western Digital Technologies, Inc. | (assignment on the face of the patent) | / | |||
Jul 12 2016 | Western Digital Technologies, INC | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT | 039389 | /0699 | |
Jul 19 2016 | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | Western Digital Technologies, INC | RELEASE BY SECURED PARTY SEE DOCUMENT FOR DETAILS | 039444 | /0802 | |
Feb 03 2022 | JPMORGAN CHASE BANK, N A | Western Digital Technologies, INC | RELEASE OF SECURITY INTEREST AT REEL 039389 FRAME 0699 | 058965 | /0553 | |
Aug 18 2023 | Western Digital Technologies, INC | JPMORGAN CHASE BANK, N A | PATENT COLLATERAL AGREEMENT - DDTL LOAN AGREEMENT | 067045 | /0156 | |
Aug 18 2023 | Western Digital Technologies, INC | JPMORGAN CHASE BANK, N A | PATENT COLLATERAL AGREEMENT - A&R LOAN AGREEMENT | 064715 | /0001 | |
May 03 2024 | Western Digital Technologies, INC | SanDisk Technologies, Inc | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 067567 | /0682 | |
Jun 21 2024 | SanDisk Technologies, Inc | SanDisk Technologies, Inc | CHANGE OF NAME SEE DOCUMENT FOR DETAILS | 067982 | /0032 | |
Aug 20 2024 | SanDisk Technologies, Inc | JPMORGAN CHASE BANK, N A , AS THE AGENT | PATENT COLLATERAL AGREEMENT | 068762 | /0494 | |
Oct 08 2024 | SanDisk Technologies, Inc | Western Digital Technologies, INC | ASSIGNMENT OF ASSIGNORS INTEREST SEE DOCUMENT FOR DETAILS | 069168 | /0273 | |
Oct 30 2024 | Western Digital Technologies, INC | JPMORGAN CHASE BANK, N A , AS COLLATERAL AGENT | SECURITY AGREEMENT SUPPLEMENTAL | 069411 | /0208 |
Date | Maintenance Fee Events |
Feb 01 2023 | M1551: Payment of Maintenance Fee, 4th Year, Large Entity. |
Date | Maintenance Schedule |
Aug 13 2022 | 4 years fee payment window open |
Feb 13 2023 | 6 months grace period start (w surcharge) |
Aug 13 2023 | patent expiry (for year 4) |
Aug 13 2025 | 2 years to revive unintentionally abandoned end. (for year 4) |
Aug 13 2026 | 8 years fee payment window open |
Feb 13 2027 | 6 months grace period start (w surcharge) |
Aug 13 2027 | patent expiry (for year 8) |
Aug 13 2029 | 2 years to revive unintentionally abandoned end. (for year 8) |
Aug 13 2030 | 12 years fee payment window open |
Feb 13 2031 | 6 months grace period start (w surcharge) |
Aug 13 2031 | patent expiry (for year 12) |
Aug 13 2033 | 2 years to revive unintentionally abandoned end. (for year 12) |