Compression and formatting of data for data storage systems

Abstract
Embodiments of compression and formatting of data for data storage systems are disclosed. In some embodiments, a data storage system can compress fixed sized data before storing it on a media and format obtained variable sized compressed data for storing on the media that typically has fixed size storage granularity. One or more modules compress the incoming host data and create an output stream of fixed sized storage units that contain compressed data. The storage units are stored on the media. Capacity, reliability, and performance are thereby increased.
Description
BACKGROUND

Technical Field


This disclosure relates to data storage systems for computer systems. More particularly, the disclosure relates to compression and formatting of data for storage systems.


Description of the Related Art


Modern computer systems continually require increases in data storage system capacity, reliability, and performance. In 1981, a typical hard disk drive used in a personal computer had capacity of about 10 megabytes (MB). Today, capacities of hard disk drives are measured in terabytes (TB). Shingled magnetic recording is utilized in order to increase capacity of magnetic storage. In addition, modern disk drives often include solid state memory to increase performance. It is desirable to provide mechanisms and architectures for increasing capacity, reliability, and performance of data storage systems.





BRIEF DESCRIPTION OF THE DRAWINGS

Systems and methods that embody the various features of the invention will now be described with reference to the following drawings, in which:



FIG. 1 illustrates a combination of a host system and a data storage system according to some embodiments of the invention.



FIG. 2 illustrates compression and formatting utilized by a data storage system according to some embodiments of the invention.



FIG. 3 illustrates compression and formatting data flow utilized by a data storage system according to some embodiments of the invention.



FIG. 4 is a flow diagram illustrating a process of storing data in a data storage system according to some embodiments of the invention.



FIG. 5 is a flow diagram illustrating a process of retrieving data stored in a data storage system according to some embodiments of the invention.





DETAILED DESCRIPTION

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 can utilize compression techniques in order to meet the demand for increased capacity, reliability, and performance. Compressing host system data before storing it in a data storage system typically causes compressed data to have smaller size than the original, non-compressed data provided by a host system. Accordingly, fixed sized host data units provided by the host system become variable sized data units after compression. Numerous challenges exist with storing and retrieving such variable sized data. For example, storing variable sized data in a data storage system media may necessitate making considerable changes to the way the data storage system stores data and keeps track of the stored data. As another example, because the host system usually expects fixed size data to be returned during data retrieval, considerable changes to data retrieval mechanisms may also be necessitated.


In some embodiments, mechanisms for compression and formatting of host data (or user data) for storing in data storage systems are provided. A data storage system can compress fixed sized data before storing it on a media and format obtained variable sized compressed data for storing on the media that typically has fixed size storage granularity, such as sectors for magnetic media and pages for non-volatile solid-state memory. One or more modules can compress incoming host data and create an output stream of fixed size “virtual” storage units (or storage units) containing one or more compressed host data units, error correction and detection code (EDC) information, and metadata for decoding the logical contents of the storage units. Virtual storage units serve as fixed sized containers for compressed host data.


In some embodiments, during writing of data to a data storage system, uncompressed, fixed sized host data units are grouped by adjacent logical addresses, stripped of EDC data, and compressed into one or more variable sized compressed data units. In order to maintain data protection and error detection and recovery, uncompressed data of a compressed data unit is used to determine new EDC that is appended to the compressed data unit. The compression logic also creates compressed data unit metadata that may include host logical addresses and length of compressed data. Compressed payload can include the metadata, determined EDC, and compressed host data. One or more compressed payloads, which can include one or more full or partial payloads, can be appended to create a fixed size virtual storage unit. The virtual storage unit can also include metadata for decoding the logical contents of the virtual storage unit. For example, the virtual storage unit metadata can include an offset of the first compressed mapping unit, a virtual data unit block address field, and a sequence number. Additional EDC data can be appended to the virtual storage unit. The virtual storage unit can be moved from a volatile memory buffer to the non-volatile media.


In some embodiments, reading stored data from the data storage system involves performing the inverse of writing data. Appropriate one or more virtual storage units are retrieved from the media and the data is decompressed. During decompression, the data storage system uses various elements of a virtual storage unit metadata and compressed payload metadata to unpack compressed data unit(s) that contain the required host data, decompress the compressed data unit(s), and generate uncompressed data in a fixed sized format expected by the host system. The data storage system can also use the metadata to verify that proper data units are being returned to the host system.


System Overview



FIG. 1 illustrates a combination 100 of a host system and a data storage system according to some embodiments of the invention. As is shown, the data storage system 120 (e.g., a solid-state drive) includes a controller 130 and storage media 140. Media 140 includes a non-volatile solid-state memory array 150. The solid-state memory array 150 may comprise 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 (e.g., single-level cell (SLC) memory, multi-level cell (MLC) memory, or any combination thereof), NOR memory, EEPROM, Ferroelectric Memory (FeRAM), Magnetoresistive RAM (MRAM), other discrete NVM (non-volatile memory) chips, or any combination thereof. Media 140 also includes magnetic storage 160, which comprises magnetic recording media 164. In one embodiment, magnetic storage 160 utilizes shingled magnetic recording. Storage media 140 can further comprise other types of storage. In some embodiments, the storage media 140 can comprise only one of solid-state memory array 140 or the magnetic storage 160.


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) of a host system 110. Storage access commands communicated by the storage interface 112 can include write data and read data commands issued by the host system 110. Read and write commands can specify a logical address (e.g., logical block addresses or LBAs) used to access the data storage system 120. The controller 130 can execute the received commands in the media 140.


Data storage system 120 can store data communicated by the host system 110. In other words, the data 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. The logical interface can present to the host system 110 data storage system's memory as a set of logical addresses (e.g., contiguous address) where user data can be stored. Internally, the controller 130 can map logical addresses to various physical locations or addresses in the media 140. The controller 130 includes a buffer 132, which can comprise volatile memory, such as random access memory (RAM) (e.g., DRAM, SRAM, etc.). In one embodiment, the buffer 132 is external to the controller 130. The controller 130 also includes a compression and formatting module 134 configured to compress and format host data for storing in the media 140, and decompress and format stored data for providing to the host system 110. The compression and formatting module 134 can utilize the buffer 132 for storing and retrieving data while performing compression and/or formatting tasks. In one embodiment, the compression and formatting module 134 is implemented in hardware, such as a system on-chip (SoC) hardware module. Hardware implementation can be realized using an application specific integrated circuit (ASIC), field-programmable gate array (FPGA), or a combination thereof. In another embodiment, the compression and formatting module 134 can be implemented in firmware or as a combination of hardware and firmware.


In some embodiments, the host system 110 stores in the data storage system 120 and the data storage system returns to the host system data formatted as one or more logical host data units. Logical host data units can span ranges of logical addresses, with each logical address corresponding to a physical location in the media 140. Host data units can be fixed sized data units of any suitable size, such as 512 bytes, 1024 bytes (1 KB), 2048 bytes (2 KB), 4096 bytes (4 KB), and the like. In one embodiment, 512 byte data units or sectors are utilized by the host system 110. In some embodiments, the media 140 is divided into fixed sized physical media storage units (or memory data units) of a suitable size, such as 512 bytes, 1024 bytes (1 KB), 2048 bytes (2 KB), 4096 bytes (4 KB), and the like. Physical media storage units can correspond to the smallest programmable and readable portion of memory and can span physical addresses of individual memory locations. In some embodiments, different media types include media storage units of different sizes. For example, the solid-state memory array 150 can be divided into dies, blocks, and pages, such as 2 KB pages, and the magnetic recording media 164 can be divided into tracks, clusters, and sectors, such as 512 byte sectors.


Compression and Formatting



FIG. 2 illustrates compression and formatting 200 utilized by the data storage system 120 according to some embodiments of the invention. The host system 110 provides host data (or user data) for storing in the data storage system 120. The host system 110 can provide host data in form of fixed sized host data units, such as 512 byte logical sectors. The host system 110 can provide host data as part of one or more write data commands. On the data storage system 120 side, the compression and formatting module 134 compresses and formats host data units for storage in the media 140.


In some embodiments, host data units are processed by a mapping unit module 210. A mapping unit can be selected as an integer multiple of the host data unit size, such as N×s1 or s1/N, where s1 is the host data unit size (e.g., 512 bytes) and N is an integer. The size of the mapping unit can be selected so as to achieve an optimal or substantially optimal balance between reduction of storage space gained from compression and latency associated with accessing compressed and formatted data stored in the media. In some embodiments, a mapping unit constructor 212 assembles one or more host data units into one or more mapping units. In some embodiments, the mapping unit constructor 212 assembles consecutive or sequential host data units into one or more mapping units. In one embodiment, consecutive or sequential host data units are associated with sequential logical addresses. In addition, aligned host data units of the size equal to the integer multiple size of the host data unit size can be stored into a mapping unit. For example, suppose that the host system 110 sends write data commands with host data units corresponding to 512-byte logical sectors 0-7, 8-15, and 16-23. Suppose that the mapping unit constructor 212 is configured to assemble aligned 4 KB of host data (or eight aligned 512-byte logical sectors) into a mapping unit, where “aligned” refers to alignments of the starting (and ending) logical addresses as well as the size. For the above example, the mapping unit constructor 212 generates three mapping units containing host data units for logical sectors 0-7, 8-15, and 16-23. Continuing the previous example, suppose that the host system 110 sends write data commands with host data units corresponding to logical sectors 1-8. These host data units are associated with eight logical sectors and have 4 KB aggregate size. However, these host data units are not aligned with chunks of eight logical sectors (e.g., a media storage unit boundary line is crossed). That is, the starting logical sector of these host data units is 1, not 0. Accordingly, the mapping unit constructor 212 generates two separate partial mapping units as discussed below: the first corresponding to logical sectors 1-7 and the second corresponding to logical sector 8. In some embodiments, the mapping units constructor 212 assembles non-aligned host data units into mapping units. In some embodiments, the mapping unit constructor 212 assembles non-consecutive or consecutive and non-consecutive host data units into mapping units.


In some embodiments, the mapping unit constructor 212 generates partial mapping units (or PMUs) that comprise less host data than the selected or target mapping unit size. For example, suppose that the host system sends write data commands with host data units corresponding to 512-byte logical sectors, 0-10 and that the mapping unit constructor 212 is configured to assemble aligned 4 KB of host data (or eight aligned 512-byte logical sectors) into a mapping unit. The mapping unit constructor 212 generates a first full or complete mapping unit corresponding to host data units for logical sectors 0-7 and a second partial mapping unit corresponding to host data units for logical sectors 8-10. Partial mapping unit corresponding to data associated with logical sector 8-10 can be later integrated into a full mapping unit when the host system 110 writes data into logical sectors 11-15.


In some embodiments, mapping units (full or partial) constructed by the mapping unit module 210 are compressed, and optionally encrypted, by the compression and encryption module 220. In some embodiments, a data compression module 222 first compresses and then, optionally, encrypts the compressed data. Encryption is performed after compression as encrypted data is randomized and may not be compressible. In some embodiments, lossless compression is used, such as Lempel-Ziv-Welch (LZW) compression. Compressed mapping unit(s) generated by the data compression module 222 can be referred to as compressed payload. In some embodiments, partial mapping units are not compressed in order to make later integration into full mapping units more efficient. In some embodiments, full mapping units are not compressed. For example, one uncompressed mapping unit can be stored as a virtual storage unit, as explained below.


In some embodiments, compressed (and optionally encrypted) mapping unit data has a size that is smaller (or equal) than that of an uncompressed mapping unit. Accordingly, compressed mapping units can have variable size. However, as explained above, the media 140 can have fixed size storage granularity, such as fixed sized media storage units (or memory data units). For example, the solid-state memory array 150 can comprise memory pages, with a page being the smallest programmable and/or retrievable memory unit. As another example, the magnetic recording media 164 can comprise sectors, with a sector being the smallest programmable and/or retrievable memory unit. Compressed mapping units are provided to the virtual storage unit module 230 that assembles one or more compressed mapping units (or, in some embodiments, uncompressed mapping units) into fixed sized storage units for storing in the media.


In some embodiments, a virtual storage unit constructor 232 is configured to assemble compressed mapping units into virtual storage units having a size that is aligned with the size of the media storage unit. For example, the size of the virtual storage unit can be an integer multiple of the media storage unit, such as N×s2 or s2/N, where s2 is the media storage unit size and N is an integer. In one embodiment, the size of the virtual storage unit is the same as the size of the media storage unit, such as 4 KB. In another embodiment, the size of the virtual storage unit is selected such that one or more compressed mapping units are assembled into a virtual storage unit. In some embodiments, different sizes of media storage units can be utilized for different types of media. As is illustrated in FIG. 1, the data storage system 120 includes solid-state memory 140 and magnetic storage 160, which can have different sizes of media storage units. For example, solid-state memory 140 can include memory pages that are 8 KB in size, while the magnetic recording media 164 can include 4 KB sectors. The virtual storage unit constructor 232 can assemble two types of virtual storage units: 8 KB storage unit for being programmed in the solid-state memory 140 and 4 KB storage unit for being written in the magnetic recording media 164.


In some embodiments, a virtual storage unit that includes one or more compressed (or uncompressed) data units is padded with filler data so that the size of the virtual storage unit is aligned with the size of a corresponding media storage unit (e.g., corresponding to the media where the virtual storage unit will be stored). For example, suppose that the size of a compressed mapping unit is 3.5 KB and 4 KB virtual storage units are used. The virtual storage unit constructor 232 can assemble 3.5 KB compressed mapping unit along with 0.5 KB (or 512 bytes) of filler data into a virtual storage unit. As another example, suppose that the combined size of two compressed mapping units is 3.7 KB and 4 KB virtual storage units are used. The virtual storage unit constructor 232 can assemble the two compressed mapping units having combined size of 3.7 KB along with 0.3 KB of filler data into a virtual storage unit. Filler data can comprise one or more suitable values, such as all zero values.


In some embodiments, compressed mapping units can be split across multiple virtual storage units. Compressed mapping units can include compressed payload or uncompressed payload (e.g., partial mapping unit payload may not be compressed). For example, suppose that a first compressed mapping unit is sized 1 KB, a second compressed mapping unit is sized 3.5 KB, a third compressed mapping unit is sized 3 KB, and 4 KB virtual storage units are used. The virtual storage unit constructor 232 can assemble the first compressed mapping unit (sized 1 KB) and 3 KB of the second compressed mapping unit (or split compressed mapping unit) into a first virtual storage unit. Further, the virtual storage unit constructor 232 can assemble the remaining 0.5 KB of the second compressed mapping unit (or remainder compressed mapping unit), third compressed mapping unit (sized 3 KB), and 0.5 KB of filler data into a second virtual storage unit. In some embodiments, compressed mapping units are split across sequential virtual storage units. In other embodiments, compressed mapping units are split across non-sequential virtual storage units.


In some embodiments, multiple compressed mapping units assembled into a virtual storage unit include only sequential host data units. For example, a first compressed mapping unit that includes host data units corresponding to logical 512-byte sectors 0-7 and a second compressed mapping unit that includes host data units corresponding to logical sectors 8-15 are combined into a virtual storage unit. In some embodiments, virtual storage units can include non-sequential host data units. For example, a first compressed mapping unit that includes host data units corresponding to logical sectors 0-7 and a second compressed mapping unit that includes host data units corresponding to logical sectors 32-39 are combined into a virtual storage unit.


In some embodiments, the mapping unit module 210, compression and encryption module 220, and virtual storage unit module 230 operate on data stored in the buffer 132. That is, mapping units, compressed mapping units, and virtual storage units are created and manipulated in the buffer 132. Assembled virtual storage units can be stored in the non-volatile media 140.


In some embodiments, reading data comprises performing the inverse of the operations associated with writing data. In response to a read data command received from the host system, the command including logical addresses for host data to be retrieved, the virtual storage unit deconstructor 234 identifies or locates in the media 140 (and/or in the buffer 132) one or more virtual storage units with the host data to be retrieved. As explained below, the virtual storage unit deconstructor 234 can use mapping data for performing the identification. The virtual storage unit deconstructor 234 identifies one or more compressed mapping units from the retrieved one or more virtual storage units, the one or more compressed mapping units containing host data to be retrieved. Data decrypter and decompressor 224 decrypts (if the data is encrypted) and decompresses (if the data is compressed) the payloads of the one or more compressed mapping units to obtain one or more mapping units containing host data to be retrieved. Mapping unit deconstructor 214 unpacks host data to be retrieved from the one or more mapping units. Host data to be retrieved is returned to the host system 110.


In some embodiments, one or more of the mapping unit module 210, compression and encryption module 220, and virtual storage unit module 230 are implemented in hardware, such as in in one or more a system on-chip (SoC) hardware modules. Hardware implementation can be realized using an application specific integrated circuit (ASIC), field-programmable gate array (FPGA), or a combination thereof. In another embodiment, modules 210, 220, and 230 can be implemented in firmware or as a combination of hardware and firmware.



FIG. 3 illustrates compression and formatting data flow 300 utilized by a data storage system according to some embodiments of the invention. The data flow 300 can be implemented by the controller 130 and/or the compression and formatting module 134. Host data 310 is received from the host system 110 as a set of host data units 312. In one embodiment, a host data unit 312 is a logical sector, such as a 512-byte logical sector. A host data unit 312 includes host (or user) data and error correction and detection (EDC) data that enables error detection and/or reconstruction of the host data. In one embodiment, EDC data can be parity data checksum, cyclic redundancy check (CRC) data, or a suitable error correction code. In one embodiment, a 512-byte logical sector of host data includes 4 bytes of EDC data.


In some embodiments, host data 310 is assembled into one or more mapping units 320 as discussed above. This can be performed by the mapping unit module 210. As explained above, a mapping unit 320 can be selected as an integer multiple of the host data unit size. In some embodiments, a mapping unit 320 includes one or more host data units 324 (which collectively make up a mapping unit payload), mapping unit metadata 322, and mapping unit EDC 326. Mapping unit metadata 322 can include the following information: payload type (e.g., compressed or uncompressed), count (or number) of host data units in the payload, logical addresses of one or more host data units in the payload, and payload length. In other embodiments, metadata 322 can include additional or alternative fields. In some embodiments, when the mapping unit module 210 assembles sequential host data units into a mapping unit, the logical address of the first host data unit in the payload and the host data unit size are sufficient to identify and locate all host data units in the payload. For example, if host data units corresponding to 512-byte logical sectors 0-7 are assembled into a 4 KB mapping unit, starting logical address associated with logical sector 0 and logical sector size (512 bytes) are sufficient to describe all logical sectors. The count of the host units in the payload in this case is set to 8. As another example, if host data units corresponding to 512-byte logical sectors 0-4 are assembled into a partial mapping unit, the count of the host units in the payload is set to 5.


In some embodiments, mapping unit EDC 326 is calculated for the entire payload of the mapping unit. The size of the mapping unit EDC 326 is smaller than the aggregate size of EDC data associated with the host data units 324 in the payload. For example, suppose that 512-byte logical sector of host data includes 4 bytes of EDC data and 8 logical sectors (or 4 KB) are assembled into a mapping unit 320. A 4-byte mapping unit EDC 326 can be generated, which results in a 28 byte savings as compared to the aggregate size of EDC data (32 bytes) for the host data units in the payload. In some embodiments, this saving of space allows for including metadata 322 into the mapping unit 320 without taking up any additional space. In some embodiments, mapping unit EDC 326 is seeded by the starting logical address of the payload.


In some embodiments, mapping units 320 are compressed, and optionally encrypted, to produce one or more compressed mapping units 330 as discussed above. This can be performed by the compression and encryption module 220. A compressed mapping unit, such as mapping units 331, 337, or 338, includes compressed payload 334 (corresponding to the compressed mapping unit), compressed mapping unit metadata 332, and mapping unit EDC 336, which can be the same as EDC 326. Mapping unit metadata 332 can include the following information: payload type (e.g., compressed or uncompressed), count (or number) of host data units in the compressed payload, logical addresses of one or more host data units in the compressed payload, and compressed payload length. In other embodiments, metadata 332 can include additional or alternative fields. Because compression produces variable sized data, compressed payload length field can be different for two or more different compressed mapping units, such as compressed mapping units 331, 337, and 338. In some embodiments, when sequential host data units are assembled into a mapping unit and into the compressed payload, the logical address of the first host data unit in the compressed payload and the host data unit size are sufficient to describe all host data in the compressed payload.


In some embodiments, when encryption is performed after compression, the compressed payload 334 and the mapping unit EDC 336 are encrypted. The metadata 332 is not encrypted or compressed. The metadata 332 can describe the contents of compressed payload, including describing logical addresses associated with host data in the compressed payload. Because in some embodiments, the host system 110 provides the decryption and/or encryption key(s) to the data storage system 120, not encrypting the metadata 332 allows the data storage system to manipulate compressed payload for various background or housekeeping tasks without having to perform decryption first. For example, the data storage system 120 can perform garbage collection without having to obtain the decryption key(s) from the host system 110. Garbage collection can include omitting or removing from a virtual storage unit one or more mapping units having invalid data. For example, suppose that a virtual storage unit includes mapping units for host data units corresponding to 512-byte logical sectors 0-7. Suppose further that as a result of host system activity, host data stored in logical sector 3 is updated, thereby making data in the virtual storage unit corresponding to logical sector 3 invalid. Garbage collection operation can create a new virtual storage unit that includes mapping units corresponding to logical sectors 0-2 and 4-7. As another example, the data storage system 120 can repack compressed payload without the decryption key(s). Repacking can include defragmentation of compressed payload, such as assembling partial mapping units into full mapping units, format conversion, such as storing virtual storage unit payload in a virtual storage unit of a different size for storage on different type of media, and the like. Defragmentation can include reordering the mapping units for host data units in a virtual storage unit. For example, suppose that a virtual storage unit includes mapping units for host data units corresponding to 512-byte logical sectors 0, 1, 3, 2, and 4-7. Defragmentation operation can reorder the mappings units in the virtual sector so that the mapping units are arranged in the order corresponding to host data units for logical sectors 0-7. In some embodiments, defragmentation can be performed in conjunction with garbage collection. For example, suppose that a virtual storage unit includes mapping units for host data units corresponding to 512-byte logical sectors 0, 1, 2, 4, 3, and 5-7. Suppose further that as a result of host system activity, host data stored in logical sector 2 is updated, thereby making data in the virtual storage unit corresponding to logical sector 2 invalid. Performing garbage collection in conjunction with defragmentation can create a new virtual storage unit that includes mapping units corresponding to logical sectors 0, 1, 3, 4, 5, 6, and 7 in that order. In some embodiments, the metadata 332 is encrypted and/or compressed.


In some embodiments, partial, full, and/or multiple compressed/uncompressed mapping units are assembled into a virtual storage unit 340. This can be performed by the virtual storage unit module 230. In some embodiments, virtual storage units can include one or more of the following: uncompressed mapping unit(s) (full and/or partial), parts (split/remainder parts) of one or more compressed mapping units split across several virtual storage units, compressed mapping unit(s), filler data, and so on. In the illustrated example, the virtual storage unit 340 comprises one or more full or partial compressed mapping units 344 (collectively making up compressed payload), optional filler data 346 so that the size of the virtual storage unit is aligned with the size of a corresponding media storage unit, virtual storage unit metadata 342, and virtual storage unit EDC 348 determined for the contents of the virtual storage unit. Virtual storage unit metadata 342 can include the following information: virtual storage unit logical address for identifying the physical location of the virtual storage unit in the media 140, offset within the virtual storage unit of metadata field of the first compressed mapping unit in the compressed payload, and a sequence number of the virtual storage unit (or another form of a timestamp). In other embodiments, metadata 342 can include additional or alternative fields.


In some embodiments, returning stored data to the host system 110 comprises performing the inverse of the operations associated with writing data. In response to a read data command received from the host system, the command including logical addresses for the host data to be retrieved, the virtual storage unit module 230 identifies or locates in the media 140 (and/or in the buffer 132) one or more virtual storage units 340 with the host data to be retrieved. In some embodiments, the virtual unit storage unit module 230 utilizes a mapping table (or another suitable data structure) that reflects associations between the logical addresses used by the host system 110 for addressing data stored in the data storage system 120 and virtual storage units storing data associated with the logical addresses. The virtual storage unit module 230 can also use virtual storage unit metadata 342 to identify and retrieve from the media (and/or from the buffer) virtual storage units with the host data to be retrieved.


Using the metadata 332, the virtual storage unit module 230 identifies one or more compressed mapping units from the retrieved one or more virtual storage units, the one or more compressed mapping units containing host data to be retrieved. In some embodiments, a retrieved virtual storage unit can include one or more compressed mapping units that contain host data to be retrieved as well as one or more compressed mapping units that do not contain sought after host data. This classification can be performed using the metadata fields of the compressed mapping units. In such cases, one or more mapping units that do not contain host data to be retrieved are skipped, thereby improving efficiency of the data transfer operation. For example, suppose that the host system 110 requested host data corresponding to logical sector 3, but a retrieved mapping unit contains host data corresponding to logical sectors 0-7. The data storage system can return host data corresponding only to logical sector 3. As another example, suppose that the host system 110 requested host data corresponding to logical sectors 0-7, and a first retrieved mapping unit contains host data corresponding to logical sectors 0-7. Suppose further that a second mapping unit contains a “fresh” (or latest) copy of host data corresponding to logical sector 3. The data storage system can return host data contained in the first mapping unit for logical sectors 0-2 and 4-7 (thereby skipping host data for logical sector 3 contained in the first mapping unit) and return host data contained in the second mapping unit for logical sector 3. Data compression and encryption module 220 decrypts (if the data is encrypted) and decompresses (if the data is compressed) one or more compressed mapping units that contain host data to be retrieved. Mapping unit module 210 unpacks host data to be retrieved from the obtained one or more mapping units. Host data to be retrieved is returned to the host system 110. In some embodiments, mapping unit metadata 322 is used to ensure that correct data is returned to the host system 110.


The above described packing schemes used in one or more embodiments are particularly useful in a mixed media environment where several types of media are present in the data storage system (e.g., a hybrid hard disk with solid state memory). As the media types have various physical sector/memory unit sizes, the package schemes enable packing characteristics to be easily adjusted across the media sizes. Thus, a controller employing the packing schemes can service the mixed media storage components and handle migration of data from one media component to another, while fulfilling the requirements of a compression and encryption-based system. For example, the virtual storage unit size can be adjusted depending on the storage destination. In one embodiment, the migration can be performed seamlessly, with repacking, if any, being handled automatically inline. Also, in one embodiment the packing/unpacking processing (including the necessary metadata handling, data mapping, compression, decompression, encryption, decryption) is automated in hardware, further enhancing the performance of the overall system.


Processes for Writing and Reading Data



FIG. 4 is a flow diagram illustrating a process 400 of writing or programming data in the data storage system 120 according to some embodiments of the invention. The illustrated process can be executed by the controller 130 and/or the compression and formatting module 134. In block 402, the process 400 receives one or more write data commands from a host system 110. A write data command specifies one or more host data units to be written to corresponding logical addresses. Host data units have fixed size. The process 400 transitions to block 404 where it assembles the one or more host data units into one or more mapping units. In some embodiments, sequential and aligned (e.g., not crossing a host data unit alignment boundary) host data units are assembled into full mapping units. The process 400 transitions to block 406 where it compresses the one or more mapping units, thereby obtaining compressed mapping units, which are variable sized due to the compression operation. The process 400 optionally encrypts the compressed data. In block 408, the process 400 assembles the one or more compressed mapping units into one or more fixed sized virtual storage units. In block 410, the process 400 stores the assembled one or more virtual storage units in the media 140.



FIG. 5 is a flow diagram illustrating a process 500 of reading or retrieving stored data from the data storage system 120 according to some embodiments of the invention. The illustrated process can be executed by the controller 130 and/or the compression and formatting module 134. In block 502, the process 500 receives a read command from the host system 100, the read command specifying a range of logical addresses associated with host data stored in the data storage system 120. The process 500 transitions to block 504, where it identifies one or more virtual storage units that contain host data to be retrieved. In block 506, the process 500 retrieves the identified one or more virtual storage units from the media (and/or buffer). The process 500 transitions to block 508, where it identifies or locates in the one or more retrieved virtual storage units one or more compressed mapping units whose payloads contain host data to be retrieved. As explained above, the process 500 can skip compressed mapping units whose payload does not contain host data to be retrieved. The process 500 transitions to block 510, where it decrypts (if the payload is encrypted) and decompresses (if the payload is compressed) the payloads of the identified one or more compressed mapping units. In block 512, the process 500 unpacks the host data to be retrieved and returns the data to the host system 110.


CONCLUSION

Disclosed approaches for compression and formatting of data for data storage systems can increase capacity, reliability, and performance. In some embodiments, the throughput as measured by data write and/or read rates is increased because compressed data which is smaller in size is stored and retrieved from the media. Because read rates are increased, resume time of the host system can be decreased. This allows the host system to “wake up” faster following power on, reboot, sleep, and/or hibernate events. In some embodiments, storing compressed data increases the effective capacity of the media. This can also reduce costs as, for example, less solid-state cache memory may be needed, and increase cache hit rates and overall performance. In some embodiments, particularly for solid-state memory media, lower write amplification and increased overprovisioning are achieved.


Other Variations


Those skilled in the art will appreciate that in some embodiments, additional or alternative modules can be used to perform compression and formatting. Mapping units, compressed mapping units, and/or virtual storage units can include additional or alternative fields. The actual steps taken in the disclosed processes, such as the processes illustrated in FIGS. 4 and 5, may differ from those shown in the figures. Additional system components can be utilized, and disclosed system components can be combined or omitted. Depending on the embodiment, certain of the steps described above may be removed, others may be added.


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 the 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 spirit of the protection. 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 systems and methods disclosed herein can be applied to hard disk drives, hybrid hard drives, and the like. In addition, other forms of storage (e.g., DRAM or SRAM, battery backed-up volatile DRAM or SRAM devices, EPROM, EEPROM memory, etc.) may additionally or alternatively be used. As another 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.

Claims
  • 1. A data storage system comprising: non-volatile memory (NVM) configured to store a plurality of memory data units, a memory data unit being a unit of storage in the NVM; anda controller configured to, in response to processing a read data command associated with a range of logical addresses corresponding to a plurality of host data units: identify and retrieve from the NVM at least one storage unit that includes the plurality of host data units associated with the read data command and a storage unit metadata portion indicating a position in the at least one storage unit of one or more compressed mapping units;identify, using the position, a plurality of compressed mapping units in the retrieved at least one storage unit, wherein combined compressed payloads of the plurality of compressed mapping units comprise at least the plurality of host data units associated with the read data command;decompress the compressed payloads of the identified plurality of compressed mapping units; andprovide the plurality of host data units obtained from the decompressed payloads to a host system.
  • 2. The data storage system of claim 1, wherein: at least one compressed mapping unit of the plurality of compressed mapping units comprises a compressed mapping unit metadata portion indicating a plurality of logical addresses associated with host data units of the compressed payload; andthe controller is further configured to identify the at least one compressed mapping unit using its compressed mapping unit metadata portion.
  • 3. The data storage system of claim 2, wherein the controller is further configured to compare the range of logical addresses associated with the read data command with the plurality of logical addresses of the compressed mapping unit metadata portion of the at least one compressed mapping unit.
  • 4. The data storage system of claim 2, wherein the compressed mapping unit metadata portion associated with the at least one compressed mapping unit is not compressed.
  • 5. The data storage system of claim 2, wherein the at least one compressed mapping unit comprises compressed payload that is encrypted, and the controller is further configured to decrypt the compressed payload.
  • 6. The data storage system of claim 5, wherein the compressed mapping unit metadata portion of the at least one compressed mapping unit is not uncompressed and not encrypted.
  • 7. The data storage system of claim 1, wherein the controller is further configured to skip, within the retrieved at least one storage unit, an unrelated compressed mapping unit including a compressed mapping unit metadata portion that does not indicate that the unrelated compressed mapping unit includes host data units that correspond to any of logical addresses in the range of logical addresses associated with the read data command.
  • 8. The data storage system of claim 1, wherein the NVM comprises at least one of a solid-state memory array or magnetic recording media.
  • 9. The data storage system of claim 8, wherein: the solid-state memory array is configured to store a plurality of memory data units of a first size and the magnetic recording media is configured to store a plurality of a memory data units of a second size; anda size of the at least one storage unit is aligned with the first or second size based at least in part on whether the at least one storage unit is stored in the solid-state memory array or the magnetic recording media.
  • 10. The data storage system of claim 1, wherein the at least one storage unit is padded with filler data of a size selected to permit a size of the at least one storage unit to be aligned with the memory data unit of the NVM.
  • 11. A method of storing data in a non-volatile storage system comprising a non-volatile memory (NVM) configured to store a plurality of memory data units, a memory data unit being a unit of storage in the NVM, the method comprising: in response to processing a read data command associated with a range of logical addresses corresponding to a plurality of host data units: identifying and retrieving from the NVM at least one storage unit that includes the plurality of host data units associated with the read data command and a storage unit metadata portion indicating a position in the at least one storage unit of one or more compressed mapping units;identifying, using the position, a plurality of compressed mapping units in the retrieved at least one storage unit, wherein combined compressed payloads of the plurality of compressed mapping units comprise at least the plurality of host data units associated with the read data command;decompressing the compressed payloads of the identified plurality of compressed mapping units; andproviding the plurality of host data units obtained from the decompressed payloads to a host system,wherein the method is performed under control of a controller.
  • 12. The method of claim 11, wherein: at least one compressed mapping unit of the plurality of compressed mapping units comprises a compressed mapping unit metadata portion indicating a plurality of logical addresses associated with host data units of the compressed payload; andthe method further comprises identifying the at least one compressed mapping unit using its compressed mapping unit metadata portion.
  • 13. The method of claim 12, further comprising comparing the range of logical addresses associated with the read data command with the plurality of logical addresses of the compressed mapping unit metadata portion of the at least one compressed mapping unit.
  • 14. The method of claim 12, wherein the compressed mapping unit metadata portion associated with the at least one compressed mapping unit is not compressed.
  • 15. The method of claim 12, wherein the at least one compressed mapping unit comprises compressed payload that is encrypted, and the method further comprises decrypting the compressed payload.
  • 16. The method of claim 15, wherein the compressed mapping unit metadata portion of the at least one compressed mapping unit is not uncompressed and not encrypted.
  • 17. The method of claim 11, further comprising skipping, within the retrieved at least one storage unit, an unrelated compressed mapping unit including a compressed mapping unit metadata portion that does not indicate that the unrelated compressed mapping unit includes host data units that correspond to any of logical addresses in the range of logical addresses associated with the read data command.
  • 18. The method of claim 11, wherein the NVM comprises at least one of a solid-state memory array or magnetic recording media.
  • 19. The method of claim 18, wherein: the solid-state memory array is configured to store a plurality of memory data units of a first size and the magnetic recording media is configured to store a plurality of a memory data units of a second size; anda size of the at least one storage unit is aligned with the first or second size based at least in part on whether the at least one storage unit is stored in the solid-state memory array or the magnetic recording media.
  • 20. The method of claim 11, wherein the at least one storage unit is padded with filler data of a size selected to permit a size of the at least one storage unit to be aligned with the memory data unit of the NVM.
CROSS REFERENCE TO RELATED APPLICATION

This application is a continuation of U.S. patent application Ser. No. 13/902,504, filed on May 24, 2013, which claims priority to provisional U.S. Patent Application No. 61/798,909, filed on Mar. 15, 2015. The disclosure of each of these prior applications is incorporated by reference in its entirety. This application is also related to U.S. patent application Ser. No. 13/902,485, filed on May 24, 2013, and issued as U.S. Pat. No 9,335,950, the disclosure of which is hereby incorporated by reference in its entirety.

US Referenced Citations (168)
Number Name Date Kind
5465186 Bajorek et al. Nov 1995 A
5861661 Tang et al. Jan 1999 A
6228689 Liu May 2001 B1
6351352 Khan et al. Feb 2002 B1
6381099 Mei Apr 2002 B1
6382499 Satoh et al. May 2002 B1
6614623 Nakamura et al. Sep 2003 B2
6639757 Morley et al. Oct 2003 B2
6656772 Huang Dec 2003 B2
6757137 Mei Jun 2004 B1
6856556 Hajeck Feb 2005 B1
6992862 Childers et al. Jan 2006 B2
7075701 Novotny et al. Jul 2006 B2
7126857 Hajeck Oct 2006 B2
7154708 Chhabra et al. Dec 2006 B2
7245458 Zhang et al. Jul 2007 B2
7298593 Yao et al. Nov 2007 B2
7359154 Yao et al. Apr 2008 B2
7372669 Deguchi et al. May 2008 B2
7375874 Novotny et al. May 2008 B1
7388733 Swanson et al. Jun 2008 B2
7394139 Park et al. Jul 2008 B2
7415530 Fallon Aug 2008 B2
7430136 Merry, Jr. et al. Sep 2008 B2
7440236 Bennin et al. Oct 2008 B1
7447807 Merry et al. Nov 2008 B1
7502256 Merry, Jr. et al. Mar 2009 B2
7509441 Merry et al. Mar 2009 B1
7515240 Lu et al. Apr 2009 B2
7525769 Yao et al. Apr 2009 B2
7596643 Merry, Jr. et al. Sep 2009 B2
7652890 Ohsawa et al. Jan 2010 B2
7653778 Merry, Jr. et al. Jan 2010 B2
7685337 Merry, Jr. et al. Mar 2010 B2
7685338 Merry, Jr. et al. Mar 2010 B2
7685374 Diggs et al. Mar 2010 B2
7697102 Hirakata et al. Apr 2010 B2
7706538 Hughes Apr 2010 B1
7733712 Walston et al. Jun 2010 B1
7764467 Hanya et al. Jul 2010 B2
7765373 Merry et al. Jul 2010 B1
7876664 Tsukagoshi et al. Jan 2011 B2
7898855 Merry, Jr. et al. Mar 2011 B2
7912991 Merry et al. Mar 2011 B1
7936603 Merry, Jr. et al. May 2011 B2
7962792 Diggs et al. Jun 2011 B2
8015692 Zhang et al. Sep 2011 B1
8030576 Kamei et al. Oct 2011 B2
8054879 Fallon et al. Nov 2011 B2
8078918 Diggs et al. Dec 2011 B2
8090899 Syu Jan 2012 B1
8090936 Fallon et al. Jan 2012 B2
8095851 Diggs et al. Jan 2012 B2
8108692 Merry et al. Jan 2012 B1
8111483 Arai Feb 2012 B2
8122185 Merry, Jr. et al. Feb 2012 B2
8127048 Merry et al. Feb 2012 B1
8135903 Kan Mar 2012 B1
8151020 Merry, Jr. et al. Apr 2012 B2
8161227 Diggs et al. Apr 2012 B1
8166245 Diggs et al. Apr 2012 B2
8189407 Strasser et al. May 2012 B2
8243525 Kan Aug 2012 B1
8254172 Kan Aug 2012 B1
8261012 Kan Sep 2012 B2
8266496 Flynn et al. Sep 2012 B2
8296625 Diggs et al. Oct 2012 B2
8312207 Merry, Jr. et al. Nov 2012 B2
8316176 Phan et al. Nov 2012 B1
8341339 Boyle et al. Dec 2012 B1
8375151 Kan Feb 2013 B1
8392635 Booth et al. Mar 2013 B2
8397107 Syu et al. Mar 2013 B1
8407449 Colon et al. Mar 2013 B1
8423722 Deforest et al. Apr 2013 B1
8433858 Diggs et al. Apr 2013 B1
8443167 Fallone et al. May 2013 B1
8447920 Syu May 2013 B1
8458435 Rainey, III et al. Jun 2013 B1
8478930 Syu Jul 2013 B1
8489854 Colon et al. Jul 2013 B1
8503237 Horn Aug 2013 B1
8521972 Boyle et al. Aug 2013 B1
8549236 Diggs et al. Oct 2013 B2
8583835 Kan Nov 2013 B1
8601311 Horn Dec 2013 B2
8601313 Horn Dec 2013 B1
8612669 Syu et al. Dec 2013 B1
8612804 Kang et al. Dec 2013 B1
8615681 Horn Dec 2013 B2
8638602 Horn Jan 2014 B1
8639872 Boyle et al. Jan 2014 B1
8683113 Abasto et al. Mar 2014 B2
8700834 Horn et al. Apr 2014 B2
8700950 Syu Apr 2014 B1
8700951 Call et al. Apr 2014 B1
8706985 Boyle et al. Apr 2014 B1
8707104 Jean Apr 2014 B1
8713066 Lo et al. Apr 2014 B1
8713357 Jean et al. Apr 2014 B1
8719531 Strange et al. May 2014 B2
8724422 Agness et al. May 2014 B1
8725931 Kang May 2014 B1
8745277 Kan Jun 2014 B2
8751728 Syu et al. Jun 2014 B1
8769190 Syu et al. Jul 2014 B1
8769232 Suryabudi et al. Jul 2014 B2
8775720 Meyer et al. Jul 2014 B1
8782327 Kang et al. Jul 2014 B1
8788778 Boyle Jul 2014 B1
8788779 Horn Jul 2014 B1
8788880 Gosla et al. Jul 2014 B1
8793429 Call et al. Jul 2014 B1
20010017749 Stefansky Aug 2001 A1
20050030670 Ando et al. Feb 2005 A1
20050195528 Bennin Sep 2005 A1
20050204081 Wang Sep 2005 A1
20050243472 Kamigama et al. Nov 2005 A1
20060098347 Yao et al. May 2006 A1
20060146262 Yu et al. Jul 2006 A1
20060157869 Huang et al. Jul 2006 A1
20070246251 Shiraishi et al. Oct 2007 A1
20080002303 Wang et al. Jan 2008 A1
20080016281 Gower et al. Jan 2008 A1
20080068757 Kamigama et al. Mar 2008 A1
20080088975 Bennin et al. Apr 2008 A1
20080140724 Flynn Jun 2008 A1
20080225439 Komura et al. Sep 2008 A1
20090151994 Ohsawa et al. Jun 2009 A1
20090190760 Bojinov et al. Jul 2009 A1
20090211789 Yeates et al. Aug 2009 A1
20090253233 Chang et al. Oct 2009 A1
20100118444 Rothenberg et al. May 2010 A1
20100174849 Walston et al. Jul 2010 A1
20100176827 Yamazaki et al. Jul 2010 A1
20100188778 Castagna Jul 2010 A1
20100195474 Tsukuda et al. Aug 2010 A1
20100228800 Aston et al. Sep 2010 A1
20100250793 Syu Sep 2010 A1
20110099323 Syu Apr 2011 A1
20110107052 Narayanasamy May 2011 A1
20110235697 Fallon et al. Sep 2011 A1
20110252183 Cho et al. Oct 2011 A1
20110282849 Williams et al. Nov 2011 A1
20110283049 Kang et al. Nov 2011 A1
20110317309 Shum et al. Dec 2011 A1
20120005557 Mardiks et al. Jan 2012 A1
20120067626 Mizutani Mar 2012 A1
20120260009 Lu et al. Oct 2012 A1
20120260020 Suryabudi et al. Oct 2012 A1
20120265737 Potkonjak Oct 2012 A1
20120278531 Horn Nov 2012 A1
20120284460 Guda Nov 2012 A1
20120324191 Strange et al. Dec 2012 A1
20130132638 Horn et al. May 2013 A1
20130145106 Kan Jun 2013 A1
20130290793 Booth Oct 2013 A1
20140059405 Syu et al. Feb 2014 A1
20140101369 Tomlin Apr 2014 A1
20140115427 Lu Apr 2014 A1
20140133220 Danilak et al. May 2014 A1
20140136753 Tomlin et al. May 2014 A1
20140149826 Lu et al. May 2014 A1
20140157078 Danilak et al. Jun 2014 A1
20140181432 Horn Jun 2014 A1
20140223255 Lu et al. Aug 2014 A1
20140281302 Horn Sep 2014 A1
20140365785 DeForest et al. Dec 2014 A1
Foreign Referenced Citations (4)
Number Date Country
101636712 Jan 2010 CN
WO 2008070799 Jun 2008 WO
WO 2009025923 Feb 2009 WO
WO 2011-081898 Jul 2011 WO
Non-Patent Literature Citations (7)
Entry
Fitzpatrick, Michael E. “4K Sector disk drives: transitioning to the future with advanced format technologies.” Toshiba. URL: http://storage. toshiba. com/docs/services-support-documents/toshiba_4kwhitepaper. pdf (vid. pág. 349) (2011).
US 7,337,529, Oct. 8, 2014 (withdrawn).
International Search Report and Written Opinion dated Aug. 13, 2014 from related PCT Serial No. PCT/ US2014/026863, 10 pages.
International Search Report and Written Opinion dated Aug. 21, 2014 from related PCT Serial No. PCT/US2014/026701, 13 pages.
Marvin R. Deforest, et al, U.S. Appl. No. 14/010,350, filed Aug. 26, 2013, 31 pages.
Robert L. Horn, U.S. Appl. No. 13/902,485, filed May 24, 2013, 40 pages.
Chinese Office Action for corresponding Chinese Application No. 201480015686X, dated Dec. 12, 2017, in 46 pages.
Related Publications (1)
Number Date Country
20160371037 A1 Dec 2016 US
Provisional Applications (1)
Number Date Country
61798909 Mar 2013 US
Continuations (1)
Number Date Country
Parent 13902504 May 2013 US
Child 15250264 US