Certain embodiments of the present description relate generally to management of memory resources.
A memory capable of storing a large amount of data frequently has drawbacks such as slower input/output speeds as compared to smaller capacity memories. Conversely, smaller memories which may be faster to operate, may have a greater cost to store data on a per bit basis, as compared to larger capacity memories. Accordingly, computer systems frequently employ a two-level memory system, often referred to as a “heterogeneous” memory system employing a smaller, faster memory as a cache memory for a second, larger and frequently slower memory.
The smaller cache memory is often positioned closer to the central processing unit and thus may have a relatively short data path to the central processing unit to facilitate faster read and write operations between the central processing unit and the cache. Hence, the cache memory is often referred to as the “near” memory. Conversely, the larger, second memory is often positioned more distant from the central processing unit. As a result, the larger, second memory typically has a longer data path to the central processing unit and is frequently referred to as the “far” memory.
Because read and write operations may often be performed more quickly for data stored in the near memory, selected data initially stored in the far memory may be read from the far memory and temporarily cached in the near memory if it is anticipated that the data will be frequently accessed. If the data is modified in the near memory, it may be transferred back to the far memory for storage.
Due to technology differences between read and write operations, read data being transferred in a read operation from a far memory to a near memory may be transferred in relatively small units of data such as a sector of data, for example, to reduce latency of such read operations. Conversely, write operations transferring write data from the near memory to the far memory may be transferred in relatively large units of data which may include many sectors of data to reduce the overhead often associated with such write operations.
Embodiments of the present disclosure are illustrated by way of example, and not by way of limitation, in the figures of the accompanying drawings in which like reference numerals refer to similar elements.
a,
4
b depict an embodiment of operations of an inter-memory transfer interface employing selective data compression/decompression in accordance with the present description.
In the description that follows, like components have been given the same reference numerals, regardless of whether they are shown in different embodiments. To illustrate one or more embodiments of the present disclosure in a clear and concise manner, the drawings may not necessarily be to scale and certain features may be shown in somewhat schematic form. Features that are described or illustrated with respect to one embodiment may be used in the same way or in a similar way in one or more other embodiments or in combination with or instead of features of other embodiments.
It is appreciated that in a data path between a near memory and a far memory, the bandwidth or data carrying capabilities of the data path may be limited for various reasons. As a result, such a bandwidth limitation may incur significant slowing in system operations during intervals of high demand on the far memory. Moreover, data traffic between the near and far memory may increase power consumption of the system.
To increase effective data transfer rates and reduce power consumption, an inter-memory transfer interface in accordance with one aspect of the present description employs selective data compression of one or more compression/decompression processes before transmitting data from the near memory to the far memory. It is appreciated that depending upon the pattern of data within a region, one compression/decompression process may be more optimal than another compression/decompression process, to increase an effective data transfer rate for that region of data.
Accordingly, an inter-memory transfer interface in accordance with one aspect of the present description, selects from multiple candidate compression/decompresses processes, a more optimal compression/decompression process to compress a region of data from the near memory before transmitting the compressed data to the far memory. In another aspect, the inter-memory transfer interface stores metadata indicating the particular compression/decompression process selected to compress that region of data. The stored metadata may then be used to identify the compression/decompression technique selected to compress a particular region of data, for purposes of subsequently decompressing data of that region when read from the far memory.
It is further appreciated that a region of memory storing multiple blocks of sectors of data may be compressed into a different number of blocks of sectors of compressed data, depending upon the particular compression/decompression technique or process selected to compress the data. As a result, the location of a sector of data targeted for a read operation within the compressed data may change as a function of the compression/decompression process selected to compress the data. Accordingly, to read and decompress the targeted sector of data, the sector of compressed data stored in the far memory containing the targeted sector is identified as a function of the metadata stored for the targeted sector, and is read from the far memory. Furthermore, the identified sector of compressed data read from the far memory, is decompressed as a function of the metadata identifying the compression/decompression process selected for the targeted sector, to restore the targeted sector.
In another aspect of an inter-memory transfer interface in accordance with the present description, a sector of data when compressed for transfer and storage in the far memory, may be completely enclosed within a similar sized sector of compressed data which is then transferred and stored in the far memory. Thus, in one embodiment, a particular sector of data when compressed does not extend beyond the boundaries of a single sector of compressed data. Such encapsulation of one or more sectors within the boundaries of a compressed sector can further increase system performance.
An inter-memory transfer interface in accordance with the present description is described herein in connection with sectors of data, blocks of sectors and regions of blocks. However, it is appreciated that an inter-memory transfer interface in accordance with the present description may be applied to other units and subunits of data such as volumes, tracks, segments, files, etc.
An inter-memory transfer interface having selective data compression/decompression in accordance with the present description may, in one embodiment, be employed in a system of one or more computers configured to perform particular operations or actions of the inter-memory transfer interface, by virtue of having software, firmware, hardware, or a combination of them installed on the system that in operation causes or cause the system to perform the actions. One or more computer programs can be configured to perform particular operations or actions of an inter-memory transfer interface having selective data compression/decompression, by virtue of including instructions that, when executed by data processing apparatus, cause the apparatus to perform the actions.
Other embodiments include corresponding computer systems, apparatus, and computer programs recorded on one or more computer storage devices, each configured to perform the actions of the methods. Implementations of the described techniques may include hardware, a method or process, or computer software on a computer-accessible medium.
It is appreciated that an inter-memory transfer interface employing selective data compression/decompression in accordance with the present description may be applied to a variety of host, storage and other memory devices such as for example, magnetic, solid state and optical disk drives, and solid state memory devices that use chalcogenide phase change material (e.g., chalcogenide glass), three-dimensional (3D) crosspoint memory, or memory that incorporates memristor technology. Additional memory devices which may benefit from an inter-memory transfer interface having selective data compression/decompression in accordance with the present description may include other types of byte-addressable, write-in-place non-volatile memory, ferroelectric transistor random-access memory (FeTRAM), nanowire-based non-volatile memory, Magnetoresistive random-access memory (MRAM), Spin Transfer Torque (STT)-MRAM, Phase Change Memory (PCM), storage class memory (SCM), universal memory, Ge2Sb2Te5, programmable metallization cell (PMC), resistive memory (RRAM), RESET (amorphous) cell, SET (crystalline) cell, PCME, Ovshinsky memory, ferroelectric memory (also known as polymer memory and poly(N-vinylcarbazole)), ferromagnetic memory (also known as Spintronics, SPRAM (spin-transfer torque RAM)), STRAM (spin tunneling RAM), magnetic memory, magnetic random access memory (MRAM), and Semiconductor-oxide-nitride-oxidesemiconductor (SONOS, also known as dielectric memory). It is appreciated that other types of memory may benefit from an inter-memory transfer interface having selective data compression/decompression in accordance with the present description, depending upon the particular application. Turning to the figures,
In alternative embodiments, system 10 may include more elements, fewer elements, and/or different elements. Moreover, although system 10 may be depicted as comprising separate elements, it will be appreciated that such elements may be integrated on to one platform, such as systems on a chip (SoCs). In the illustrative example, system 10 comprises a central processing unit or microprocessor 20, a memory controller 30, a memory 40, an offload data transfer engine 44, and peripheral components 50 which may include, for example, video controller, input device, output device, storage, network adapter, a power source (including a battery, renewable power source (e.g., photovoltaic panel), wireless charging, or coupling to an AC outlet), etc. The microprocessor 20 includes a cache 25 that may be part of a memory hierarchy to store instructions and data, and the system memory 40 may also be part of the memory hierarchy. The microprocessor 20 further includes logic 27 which may include one or more cores, for example. Communication between the microprocessor 20 and the memory 40 may be facilitated by the memory controller (or chipset) 30, which may also facilitate in communicating with the peripheral components 50.
Peripheral components 50 which are storage devices may be, for example, non-volatile storage, such as solid-state drives (SSD), magnetic disk drives including redundant arrays of independent disks (RAID), optical disk drives, a tape drive, flash memory, etc. The storage may comprise an internal storage device or an attached or network accessible storage. The microprocessor 20 is configured to write data in and read data from the memory 40. Programs in the storage are loaded into the memory and executed by the processor. The offload data transfer engine 44 facilitates memory to memory data transfers which bypass the microprocessor to lessen the load of such transfers on the microprocessor 20. As explained in greater detail below, one embodiment of an inter-memory transfer interface having selective data compression/decompression in accordance with the present description, can reduce traffic between a near memory and a far memory to improve system performance.
A network controller or adapter enables communication with a network, such as an Ethernet, a Fiber Channel Arbitrated Loop, etc. Further, the architecture may, in certain embodiments, include a video controller configured to display information represented by data in a memory on a display monitor, where the video controller may be embodied on a video card or integrated on integrated circuit components mounted on a motherboard or other substrate. An input device is used to provide user input to the processor, and may include a keyboard, mouse, pen-stylus, microphone, touch sensitive display screen, input pins, sockets, or any other activation or input mechanism known in the art. An output device is capable of rendering information transmitted from the processor, or other component, such as a display monitor, printer, storage, output pins, sockets, etc. The network adapter may embodied on a network card, such as a Peripheral Component Interconnect (PCI) card, PCI-express, or some other I/O card, or on integrated circuit components mounted on a motherboard or other substrate. The peripheral devices 50 may also include RF receiver/transmitters such as in a mobile telephone embodiment, for example. Additional examples of peripheral devices 50 which may be provided in the system include an audio device and temperature sensor to deliver temperature updates for storage in the memory.
One or more of the components of the device 10 may be omitted, depending upon the particular application. For example, a network router may lack a video controller, for example.
Any one or more of the memory devices 25, 40, and the other devices 10, 30, 50 may include a memory employing an inter-memory transfer interface having selective data compression/decompression in accordance with the present description, or be embodied as any type of data storage capable of storing data in a persistent manner (even if power is interrupted to non-volatile memory) such as but not limited to any combination of memory devices that use for example, chalcogenide phase change material (e.g., chalcogenide glass), three-dimensional (3D) crosspoint memory, or other types of byte-addressable, write-in-place non-volatile memory, ferroelectric transistor random-access memory (FeTRAM), nanowire-based non-volatile memory, phase change memory (PCM), memory that incorporates memristor technology, Magnetoresistive random-access memory (MRAM) or another Spin Transfer Torque (STT)-MRAM as described above. Such memory elements in accordance with embodiments described herein can be used either in stand-alone memory circuits or logic arrays, or can be embedded in microprocessors and/or digital signal processors (DSPs). Additionally, it is noted that although systems and processes are described herein primarily with reference to microprocessor based systems in the illustrative examples, it will be appreciated that in view of the disclosure herein, certain aspects, architectures, and principles of the disclosure are equally applicable to other types of device memory and logic devices.
One or more of the memory 40 and storage devices of the peripheral devices 50 may have a rectangular or orthogonal array of rows and columns of cells such as bit cells in which each bit cell is configured to store a bit state. An array of bit cells may be logically subdivided in an array 52 of regions 54 (
Each block 70 may in turn be subdivided into an array of sectors 74 (
In one embodiment, the inter-memory transfer interface logic 120 includes compression/decompression selection logic 122 configured to select a compression/decompression process to process a memory region of data of the near memory 110a before the data is transmitted to and stored in the far memory 110b. A metadata storage logic 124 of the inter-memory transfer interface logic 120, is configured to store metadata to indicate a compression/decompression process selected to process a region of data for transmission to the far memory 110b. As used herein, a compression/decompression process in one example, compresses data into a compressed form, or decompresses compressed data into an uncompressed form. In another example, a selected compression/decompression process may selectively leave uncompressed data as uncompressed.
The inter-memory transfer interface logic 120 further includes compression logic 130 configured to compress a memory region of uncompressed data to one or more smaller units of compressed data using the compression/decompression process selected by the compression/decompression selection logic 122. For example, the compression logic 130 may be configured to compress a region of data in several trials, each compression/decompression trial using a different candidate compression/decompression process to provide a trial result of one or more units of compressed data, depending upon the candidate compression/decompression process. The compression/decompression selection logic 122 may be configured to compare the trial results of each compression/decompression trial for a particular region, and select the candidate compression/decompression process which provided the least number of units of compressed data, to increase effective data transfer rate and reduce power consumption.
Accordingly, the metadata storage logic 124 of the inter-memory transfer interface logic 120, is configured to store metadata in association with the memory region being processed, to identify the compression/decompression process selected for the associated memory region. The inter-memory transfer interface logic is further configured to transmit one or more units of processed data such as compressed or uncompressed data for storage in the far memory 110b.
In the illustrated embodiment, each unit or block of compressed data transmitted to the far memory 110b may include multiple subunits or sectors of compressed data, each sector of compressed data including one or more sectors of data from the near memory 110a but in compressed form. In one aspect of the present description, each sector of data from the near memory 110a which has been compressed and stored in the far memory 110b, is fully contained, that is, enclosed or encapsulated within the field of data defined by a sector of compressed data transferred to and stored in the far memory 110b. Accordingly, the compressed data representing a sector of data from the near memory 110a lies within a single sector of compressed data and does not extend to more than one sector of compressed data.
The inter-memory transfer interface logic 120 is further configured to read processed data such as compressed data from the far memory 110b and decompress it if needed, to restore the data in uncompressed form for storage in the near memory 110a. In this embodiment, the inter-memory transfer interface logic includes data location identification logic 134 configured to read the metadata stored for a memory region containing a sector which has been compressed and stored in the far memory 110b. As explained in greater detail below, the data location identification logic 134 is configured to use the read metadata, to identify the sector of compressed data stored in the far memory 110b which contains the particular sector of data to be restored, as a function of the read metadata indicating the compression/decompression process selected to compress the data of the region of the particular sector, and as a function of a subunit identification such as a sector number, of the particular sector of data to be restored.
The inter-memory transfer interface logic 120 is further configured to read the identified sector of compressed data from the far memory. A decompression logic 140 of the inter-memory transfer interface logic 120, is configured to receive and decompress the sector of data read from the far memory 110b if it has been compressed. The decompression logic 140 decompresses a sector of compressed data as a function of the read metadata indicating the compression/decompression process selected to generate the sector of compressed data. In this manner, the particular sector of data is restored from the compressed sector of data read from the far memory 110b. The inter-memory transfer interface logic is further configured to store the data in uncompressed form in the near memory 110a.
In one embodiment, the inter-memory transfer interface logic 120 may be implemented in one or more memory controllers. In another embodiment, the inter-memory transfer interface logic 120 may be implemented a direct memory access (DMA) controller or engine.
a,
4
b depict examples of operations of an inter-memory transfer interface employing selective data compression/decompression in accordance with the present description.
In this embodiment, a cache logic 220 of the far memory controller 214 caches data from the far memory 110b into the near memory 110a, to facilitate read operations by a central processing unit such as the central processing unit CPU1, for example. Data cached in the near memory 110a may be evicted by the cache logic 220 for various reasons such as to make room in the near memory 110a for other data deemed more likely to be accessed by a central processing unit. Data being evicted from the near memory 110a may in some embodiments, be simply discarded if the data being evicted is unchanged and is already stored in the far memory 110b. However, if the data being evicted is new data or data that has been modified, often referred to as “dirty” data, the data being evicted may be compressed and transferred to the far memory 110b as compressed write data to the far memory 110b.
Accordingly,
The data of each region is further arranged in blocks, each block having four sectors of uncompressed data, that is, a kilobyte (1024 bytes) of uncompressed data. Hence, in the example of
The compression/decompression selection logic 122 of the far memory controller 214 selects (block 230,
In one aspect of the present description, an inter-memory transfer interface in accordance with the present description makes available multiple, different processes as candidate compression/decompression processes from which to select, to increase the benefit from compression. In that different compression/decompresses processes may be selected to compress different regions of data, a data transfer interface in accordance with another aspect of the present description stores metadata for each such processed region of data to indicate the particular compression/decompression process used to compress or otherwise process the associated region of data. Such metadata may be stored in the near memory 110a, for example, and subsequently read for use in identifying the location of a particular sector and decompressing the targeted sector if needed, as a function of the metadata indicating how the sector was processed.
The metadata storage logic 124 of the far memory controller 214 stores (block 234,
In this embodiment, the data structure 310a has an entry for each region of the near memory 110a which has been processed for transmission to the far memory 110b for storage. Each entry has a field referenced as “memory region” which identifies the associated memory region, and another field storing the metadata for the associated memory region. Thus, in this example, the metadata value 00 is stored for the associated memory region regionU0, and indicates that the memory regionU0 was processed using the selected compression/decompression process identified by the metadata value 00.
Other regions may have been processed using other selected compression/decompression processes as indicated by the values stored in the fields of the other entries of the data structure 310a as shown in
Conversely if some of the bits of the region are of the other state, such as a one state, the region is left uncompressed for transmission. Accordingly, the single metadata bit will indicate whether the region is all zeroes (metadata bit=zero) or is uncompressed (metadata bit=one). Thus, in this example, a metadata state equal to one indicates that the selected compression/decompression process is one in which the bits of the region are left unchanged, that is, not compressed.
In one example of a write operation depicted in
If it is determined (block 240,
Conversely, if it is determined (block 250,
For example, in that the regionU0 was determined (block 230) to contain all zeroes in the example of
Conversely, in that the regionU1 was determined (block 230) to contain a mixture of ones and zeroes in the example of
Having identified (block 284) the far memory sector containing the data to be read, the identified far memory sector is read (block 290) by the far memory controller 214 and processed as a function of region metadata to restore the read sector. If the sector data was compressed prior to being stored in the far memory, the processing will include decompressing the read data to restore the data. However, in the example of
As previously mentioned,
As previously mentioned, in the illustrated embodiment, the data of each region is arranged in blocks, blockU0 (
In a similar manner, the data of the sectors sectorU01, sectorU05, sectorU09 and sectorU13 of the region 610 is compressed to the compressed sectorC01, the data of the sectors sectorU02, sectorU06, sectorU10 and sectorU14 of the region 610 is compressed to the compressed sectorC02, and data of the sectors, sectorU03, sectorU07, sectorU11 and sectorU15 of the region 610 is compressed to the compressed sectorC03. Data compressed using the compression/decompression process of
In a similar manner, the data of the sectors, sectorU08 and sectorU12, of the region 610 is compressed to the compressed sectorC04 of the blockC1 Further, the data of the sectors sectorU09 and sectorU13 of the region 610 is compressed to the compressed sectorC05, the data of the sectors sectorU10 and sectorU14 of the region 610 is compressed to the compressed sectorC06, and the data of the sectors, sectorU11 and sectorU15 of the region 610 is compressed to the compressed sectorC07, of the blockC1. Data compressed using the compression/decompression process of
Thus, the data of the sectors, sectorU00, sectorU01, sectorU02, sectorU03 of the blockU0 of the region 610 (
However, the compression/decompression process of
The data of the sectors, sectorU08, sectorU09, sectorU10, sectorU11 of the blockU3 of the region 610 remains unchanged as the sectors, sectorC04, sectorC05, sectorC06, sectorC07, respectively, of the blockC1 (
The data of the sectors, sectorU12, sectorU13, sectorU14, sectorU15 of the blockU3 of the region 610 remains unchanged as the sectors, sectorC08, sectorC09, sectorC10, sectorC11, respectively, of the blockC2 (
In one aspect of the present description, each compressed sector of the various compression/decompression processes depicted in
It is appreciated that other compression/decompression processes may be utilized depending upon the particular application. For example, different combinations of compressed and uncompressed sectors may be implemented to reduce data transmission and reduce power consumption. Also, in some embodiments, the data of a compressed sector may span over more than one physical sector of the far memory, for example. Further, it is appreciated that the arrangement and numbers of resultant compressed blocks and the sectors within those blocks may vary, depending upon the particular application.
In an example of a write operation depicted in
In an example of a write operation depicted in
If it is determined (block 240,
Conversely, if it is determined (block 250,
Conversely, if it is determined (block 250,
In an example of a read operation depicted in
For example, if the regionU0 was determined (block 230,
Conversely, in that the region was determined (block 230) to contain a mixture of ones and zeroes (such that metadata does not equal 0, 00 or 000), the far memory sector containing the data to be read may be identified (block 284,
In another example, if the read operation is directed to original sectorU08 (
In another example, if the read operation is directed to original sectorU08 (
In another example, if the read operation is directed to original sectorU08 (
In another example, if the read operation is directed to original sectorU08 (
In another example, if the read operation is directed to original sectorU08 (
In another example, if the read operation is directed to original sectorU08 (
A sector read from the far memory and processed in accordance with the decompression process identified by the associated metadata of the region, may be stored in the near memory directly by the far memory controller 214. However, it is appreciated that in some embodiments, the data may be stored in the near memory utilizing the near memory controller 210.
In another aspect of the present description, it is appreciated that in some embodiments, a region of data may be stored in the far memory and some but not all sectors of that region may be cached in the near memory. In the event that one or more of those sectors is evicted from the near memory, operations may be undertaken to permit the evicted sectors to be transferred to the far memory utilizing an inter-memory transfer interface in accordance with the present description as a function of the stored metadata for the region and as a function of whether the region has been modified in the near memory.
For example, if the sectors being evicted from the near memory are from a region of data which has remained unchanged, transferring the evicted sectors back to the far memory may be bypassed since the sectors are already stored in the far memory. In addition, the metadata for the region may remain unchanged since the compression/decompression process selected for the region also remains unchanged.
In another example, if the sectors being evicted from the near memory are from a region of data which has been modified in the near memory but is uncompressed in the far memory, the modified sectors or blocks of sectors being evicted from the near memory may be transferred back to the far memory in uncompressed form without incurring any new sector reads from the far memory. In addition, the metadata for the region may remain unchanged since the compression/decompression process (which is a no compression process) selected for the region also remains unchanged.
In still another example, if the sectors being evicted from the near memory are from a region of data which has been modified in the near memory and is compressed in the far memory, sectors of the region which are missing in the near memory are read from the far memory so that the region of the modified sectors or blocks of sectors being evicted from the near memory may be recompressed and transferred to the far memory. If the compression/decompression process selected for the region remains unchanged, the metadata stored for the region may remain unchanged. However, if a different compression/decompression process is selected to recompress the region, the metadata stored for the region is also changed to indicate the new selected compression/decompression process.
In another aspect of the present description, metadata stored in the near memory may be copied to the far memory to preserve the metadata identifying the compression/decompression process selected for each region of data, in the event that the near memory goes to a low power state, sleep state or other state which may make the metadata unavailable or corrupted. Accordingly, a small portion of the far memory may be reserved to store a copy of the metadata.
It is appreciated that the operations of
The hardware, software or firmware of the inter-memory transfer interface may be physically or logically located in any component of the system including the memory itself, a controller such as a memory controller, DMA controller, a microprocessor, etc. Thus, in one embodiment, one or more of the logic elements depicted in
It is appreciated that an inter-memory transfer interface having selective data compression/decompression in accordance with the present description can, depending upon the particular application, reduce data traffic between a near memory and a far memory, and improve system efficiency. Other aspects may be achieved, depending upon the particular application.
The following examples pertain to further embodiments.
Example 1 is a system, comprising: a central processing unit, a memory subsystem including a plurality of memories including a first memory having a first region, and a second memory, and inter-memory transfer interface logic configured to control input/output operations for said memory subsystem wherein the inter-memory transfer interface logic is configured to store in the first region a plurality of units of data, each unit of data including a plurality of subunits of data, including a first subunit of data, said inter-memory transfer interface logic including: compression/decompression selection logic configured to select a compression process to compress a first plurality of subunits of data of the first region including the first subunit of data, metadata storage logic configured to store metadata to indicate a compression process selected for the first subunit of data, and compression logic configured to compress the first plurality of subunits of data of the first region with a selected compression process to provide at least a second subunit of data compressed data so that the second subunit of data encloses in compressed form the data of the first plurality of subunits of data including the first subunit of data, and wherein the inter-memory transfer interface logic is further configured to transmit a unit of compressed data to the second memory wherein the transmitted unit of compressed data includes multiple subunits of compressed data including said second subunit of data, and to store the unit of compressed data in the second memory.
In Example 2, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein each subunit of data has a subunit identification, and the inter-memory transfer interface logic further includes data location identification logic configured to read metadata indicating a compression process selected for the first subunit of data, and identify the second subunit of compressed data stored in the second memory as containing the first subunit of data as a function of the read metadata indicating the compression process selected for the first subunit of data and as a function of a subunit identification of the first subunit of data,
wherein the inter-memory transfer interface logic is further configured to read the second subunit of compressed data from the second memory, and further includes decompression logic configured to receive and decompress the second subunit of compressed data from the second memory as a function of the read metadata indicating the compression process selected for the second subunit data, to restore the first subunit of data of the from the second subunit of compressed data, and
wherein the inter-memory transfer interface logic is further configured to store a restored first subunit of data in the first memory.
In Example 3, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a compression process for compression of the first region of data, wherein the metadata storage logic is further configured to store at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if all bits of the first region have a single common state and wherein the inter-memory transfer interface logic is further configured to selectively bypass compression and transmission of the first region of data to the second memory if the metadata for the first region of data has the first defined state, and wherein the metadata for the first region of data has a second, different defined state if bits of the first region have states other than the single common state and wherein the inter-memory transfer interface logic is further configured to transmit data of the first region of data to the second memory if the metadata for the first region of data has the second defined state.
In Example 4, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the metadata storage logic is further configured to store at least two bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a third defined state if the compression process selected for the first region compresses all units of data of the first region into a single unit of compressed data, and has a fourth defined state if the compression process selected for the first region compresses a first plurality of units of data of the first region into a first unit of compressed data and compresses a second plurality of units of data of the first region into a second unit of compressed data.
In Example 5, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the metadata storage logic is further configured to store at least three bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a fifth defined state if the compression process selected for the first region compresses a plurality of units of data of the first region into a unit of compressed data and leaves a first unit of data of the first region as a unit of uncompressed data.
In Example 6, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the metadata for the first region of data has a sixth defined state if the compression process selected for the first region leaves a second unit of data of the first region as a unit of uncompressed data and compresses a plurality of units of data of the first region into a unit of compressed data.
In Example 7, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a compression process to compress the first region of data, wherein the metadata storage logic is further configured to store at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if the first region of data is compressed in a first compression process, and wherein the metadata for the first region of data has a second defined state if the first region of data is compressed in a second compression process, and wherein the metadata for the first region of data has an nth defined state if the first region of data is compressed in an nth compression process wherein the number of bits of metadata is greater than one if n is greater than two.
In Example 8, the subject matter of Examples 1-9 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a different compression process for compression of the first region of data which is different from the first compression process, wherein the metadata storage logic is further configured to update the metadata for the first region to have a different defined state to indicate the different compression process if the first region of data is compressed in the different compression process.
In Example 9, the subject matter of Examples 1-9 (excluding the present Example) can optionally include at least one of:
a display communicatively coupled to the central processing unit, a network interface communicatively coupled to the central processing unit, and a battery coupled to provide power to the system.
Example 10 is a method, comprising: selecting a compression process for selectively compressing a plurality of units of data from a first region of data of a first memory, each unit of data including a plurality of subunits of data, storing metadata indicating a compression process selected for the first region of data, and as a function of the selected compression process, selectively: compressing the plurality of units of data to provide at least a second unit of compressed data including a plurality of subunits of compressed data using a selected compression process so that each subunit of compressed data encloses in compressed form the data of a subunit of the first plurality of units of data, transmitting the second unit of compressed data to a second memory, and storing the second unit of compressed data in the second memory.
In Example 11, the subject matter of Examples 10-17 (excluding the present Example) can optionally include wherein each subunit of data of the plurality of units of data has a subunit identification. the method further comprising: reading metadata indicating a compression process selected for the first region of data, identifying a location of a subunit of compressed data stored in the second memory as containing a particular subunit of data of the first plurality of units of data as a function of the read metadata indicating the compression process selected for the first region of data and as a function of the subunit identification of the particular subunit of data, reading and transmitting a located subunit of compressed data from the second memory, receiving and decompressing the located subunit of compressed data from the second memory, as a function of the read metadata indicating the compression process selected for the region of data, to restore the particular subunit of data from the located subunit of compressed data, and storing a restored particular subunit of data in the first memory.
In Example 12, the subject matter of Examples 10-17 (excluding the present Example) can optionally include selecting a compression process for compressing the first region of data, wherein the metadata storing includes storing a bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if all bits of the first region have a single common state and the transmitting and storing are selectively bypassed if the metadata for the first region of data has the first defined state, and wherein the metadata for the first region of data has a second, different defined state if bits of the first region have states other than the single common state and the transmitting is selectively performed if the metadata for the first region of data has the second defined state.
In Example 13, the subject matter of Examples 10-17 (excluding the present Example) can optionally include wherein the metadata storing includes storing two bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a third defined state if the compression process selected for the first region compresses all units of data of the first region into a single unit of compressed data, and has a fourth defined state if the compression process selected for the first region compresses a first plurality of units of data of the first region into a first unit of compressed data and compresses a second plurality of units of data of the first region into a second unit of compressed data.
In Example 14, the subject matter of Examples 10-17 (excluding the present Example) can optionally include wherein the metadata storing includes storing three bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a fifth defined state if the compression process selected for the first region compresses a plurality of units of data of the first region into a unit of compressed data and leaves a first unit of data of the first region as a unit of uncompressed data.
In Example 15, the subject matter of Examples 10-17 (excluding the present Example) can optionally include wherein the metadata for the first region of data has a sixth defined state if the compression process selected for the first region leaves a second unit of data of the first region as a unit of uncompressed data and compresses a plurality of units of data of the first region into a unit of compressed data.
In Example 16, the subject matter of Examples 10-17 (excluding the present Example) can optionally include selecting a compression process for compressing the first region of data, wherein the metadata storing includes storing at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if the first region of data is compressed in a first compression process, wherein the metadata for the first region of data has a second defined state if the first region of data is compressed in a second compression process, and wherein the metadata for the first region of data has an nth defined state if the first region of data is compressed in an nth compression process wherein the number of bits of metadata is greater than one if n is greater than two.
In Example 17, the subject matter of Examples 10-17 (excluding the present Example) can optionally include wherein the selecting a compression process for compressing the first region of data includes selecting a different compression process for compression of the first region of data which is different from the first compression process, wherein the metadata storing includes updating the metadata for the first region to have a different defined state to indicate the different compression process if the first region of data is compressed in the different compression process.
Example 18 is an apparatus comprising means to perform a method as claimed in any preceding Example.
Example 19 is an apparatus for use with a memory subsystem including a plurality of memories including a first memory having a first region, and a second memory, comprising: inter-memory transfer interface logic configured to control input/output operations for said memory subsystem wherein the inter-memory transfer interface logic is configured to store in the first region a plurality of units of data, each unit of data including a plurality of subunits of data, including a first subunit of data, said inter-memory transfer interface logic including: compression/decompression selection logic configured to select a compression process to compress a first plurality of subunits of data of the first region including the first subunit of data, metadata storage logic configured to store metadata to indicate a compression process selected for the first subunit of data, and compression logic configured to compress the first plurality of subunits of data of the first region with a selected compression process to provide at least a second subunit of data compressed data so that the second subunit of data encloses in compressed form the data of the first plurality of subunits of data including the first subunit of data, and wherein the inter-memory transfer interface logic is further configured to transmit a unit of compressed data to the second memory wherein the transmitted unit of compressed data includes multiple subunits of compressed data including said second subunit of data, and to store the unit of compressed data in the second memory.
In Example 20, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein each subunit of data has a subunit identification, and the inter-memory transfer interface logic further includes data location identification logic configured to read metadata indicating a compression process selected for the first subunit of data, and identify the second subunit of compressed data stored in the second memory as containing the first subunit of data as a function of the read metadata indicating the compression process selected for the first subunit of data and as a function of a subunit identification of the first subunit of data, wherein the inter-memory transfer interface logic is further configured to read the second subunit of compressed data from the second memory, and further includes decompression logic configured to receive and decompress the second subunit of compressed data from the second memory as a function of the read metadata indicating the compression process selected for the second subunit data, to restore the first subunit of data of the from the second subunit of compressed data, and wherein the inter-memory transfer interface logic is further configured to store a restored first subunit of data in the first memory.
In Example 21, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a compression process for compression of the first region of data, wherein the metadata storage logic is further configured to store at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if all bits of the first region have a single common state and wherein the inter-memory transfer interface logic is further configured to selectively bypass compression and transmission of the first region of data to the second memory if the metadata for the first region of data has the first defined state, and wherein the metadata for the first region of data has a second, different defined state if bits of the first region have states other than the single common state and wherein the inter-memory transfer interface logic is further configured to transmit data of the first region of data to the second memory if the metadata for the first region of data has the second defined state.
In Example 22, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the metadata storage logic is further configured to store at least two bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a third defined state if the compression process selected for the first region compresses all units of data of the first region into a single unit of compressed data, and has a fourth defined state if the compression process selected for the first region compresses a first plurality of units of data of the first region into a first unit of compressed data and compresses a second plurality of units of data of the first region into a second unit of compressed data.
In Example 23, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the metadata storage logic is further configured to store at least three bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a fifth defined state if the compression process selected for the first region compresses a plurality of units of data of the first region into a unit of compressed data and leaves a first unit of data of the first region as a unit of uncompressed data.
In Example 24, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the metadata for the first region of data has a sixth defined state if the compression process selected for the first region leaves a second unit of data of the first region as a unit of uncompressed data and compresses a plurality of units of data of the first region into a unit of compressed data.
In Example 25, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a compression process to compress the first region of data, wherein the metadata storage logic is further configured to store at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if the first region of data is compressed in a first compression process, and wherein the metadata for the first region of data has a second defined state if the first region of data is compressed in a second compression process, and wherein the metadata for the first region of data has an nth defined state if the first region of data is compressed in an nth compression process wherein the number of bits of metadata is greater than one if n is greater than two.
In Example 26, the subject matter of Examples 19-27 (excluding the present Example) can optionally include wherein the compression/decompression selection logic is further configured to select a different compression process for compression of the first region of data which is different from the first compression process, wherein the metadata storage logic is further configured to update the metadata for the first region to have a different defined state to indicate the different compression process if the first region of data is compressed in the different compression process.
In Example 27, the subject matter of Examples 19-27 (excluding the present Example) can optionally include a system comprising: said inter-memory transfer interface logic, a central processing unit, a memory subsystem including a plurality of memories including a first memory having a first region, and a second memory, and at least one of:
a display communicatively coupled to the central processing unit, a network interface communicatively coupled to the central processing unit, and a battery coupled to provide power to the system.
Example 28 is an apparatus for use with a memory subsystem including a plurality of memories including a first memory having a first region, and a second memory, comprising: inter-memory transfer interface means for controlling input/output operations for said memory subsystem wherein the inter-memory transfer interface means is configured for storing in the first region a plurality of units of data, each unit of data including a plurality of subunits of data, including a first subunit of data, said inter-memory transfer interface means including: compression/decompression selection means for selecting a compression process to compress a first plurality of subunits of data of the first region including the first subunit of data, metadata storage means for storing metadata to indicate a compression process selected for the first subunit of data, and compression means for compressing the first plurality of subunits of data of the first region with a selected compression process to provide at least a second subunit of data compressed data so that the second subunit of data encloses in compressed form the data of the first plurality of subunits of data including the first subunit of data, and wherein the inter-memory transfer interface means is further configured for transmitting a unit of compressed data to the second memory wherein the transmitted unit of compressed data includes multiple subunits of compressed data including said second subunit of data, and to store the unit of compressed data in the second memory.
In Example 29, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein each subunit of data has a subunit identification, and the inter-memory transfer interface means further includes data location identification means for reading metadata indicating a compression process selected for the first subunit of data, and for identifying the second subunit of compressed data stored in the second memory as containing the first subunit of data as a function of the read metadata indicating the compression process selected for the first subunit of data and as a function of a subunit identification of the first subunit of data, wherein the inter-memory transfer interface means is further configured for reading the second subunit of compressed data from the second memory, and further includes decompression means for receiving and decompressing the second subunit of compressed data from the second memory as a function of the read metadata indicating the compression process selected for the second subunit data, to restore the first subunit of data of the from the second subunit of compressed data, and wherein the inter-memory transfer interface means is further configured for storing a restored first subunit of data in the first memory.
In Example 30, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the compression/decompression selection means is further configured for selecting a compression process for compression of the first region of data, wherein the metadata storage means is further configured for storing at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if all bits of the first region have a single common state and wherein the inter-memory transfer interface means is further configured for selectively bypassing compression and transmission of the first region of data to the second memory if the metadata for the first region of data has the first defined state, and wherein the metadata for the first region of data has a second, different defined state if bits of the first region have states other than the single common state and wherein the inter-memory transfer interface means is further configured for transmitting data of the first region of data to the second memory if the metadata for the first region of data has the second defined state.
In Example 31, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the metadata storage means is further configured for storing at least two bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a third defined state if the compression process selected for the first region compresses all units of data of the first region into a single unit of compressed data, and has a fourth defined state if the compression process selected for the first region compresses a first plurality of units of data of the first region into a first unit of compressed data and compresses a second plurality of units of data of the first region into a second unit of compressed data.
In Example 32, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the metadata storage means is further configured for storing at least three bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a fifth defined state if the compression process selected for the first region compresses a plurality of units of data of the first region into a unit of compressed data and leaves a first unit of data of the first region as a unit of uncompressed data.
In Example 33, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the metadata for the first region of data has a sixth defined state if the compression process selected for the first region leaves a second unit of data of the first region as a unit of uncompressed data and compresses a plurality of units of data of the first region into a unit of compressed data.
In Example 34, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the compression/decompression selection means is further configured for selecting a compression process to compress the first region of data, wherein the metadata storage means is further configured for storing at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if the first region of data is compressed in a first compression process, and wherein the metadata for the first region of data has a second defined state if the first region of data is compressed in a second compression process, and wherein the metadata for the first region of data has an nth defined state if the first region of data is compressed in an nth compression process wherein the number of bits of metadata is greater than one if n is greater than two.
In Example 35, the subject matter of Examples 28-35 (excluding the present Example) can optionally include wherein the compression/decompression selection means is further configured for selecting a different compression process for compression of the first region of data which is different from the first compression process, wherein the metadata storage means is further configured for updating the metadata for the first region to have a different defined state to indicate the different compression process if the first region of data is compressed in the different compression process.
Example 36 is a computer program product for a computing system wherein the computer program product comprises a computer readable storage medium having program instructions embodied therewith, the program instructions executable by a processor of the computing system to cause operations, the operations comprising:
selecting a compression process for selectively compressing a plurality of units of data from a first region of data of a first memory, each unit of data including a plurality of subunits of data, storing metadata indicating a compression process selected for the first region of data, and as a function of the selected compression process, selectively: compressing the plurality of units of data to provide at least a second unit of compressed data including a plurality of subunits of compressed data using a selected compression process so that each subunit of compressed data encloses in compressed form the data of a subunit of the first plurality of units of data, transmitting the second unit of compressed data to a second memory, and storing the second unit of compressed data in the second memory.
In Example 37, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein each subunit of data of the plurality of units of data has a subunit identification. the operations further comprising: reading metadata indicating a compression process selected for the first region of data, identifying a location of a subunit of compressed data stored in the second memory as containing a particular subunit of data of the first plurality of units of data as a function of the read metadata indicating the compression process selected for the first region of data and as a function of the subunit identification of the particular subunit of data, reading and transmitting a located subunit of compressed data from the second memory, receiving and decompressing the located subunit of compressed data from the second memory, as a function of the read metadata indicating the compression process selected for the region of data, to restore the particular subunit of data from the located subunit of compressed data, and storing a restored particular subunit of data in the first memory.
In Example 38, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the operations further comprise selecting a compression process for compressing the first region of data, wherein the metadata storing includes storing a bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if all bits of the first region have a single common state and the transmitting and storing are selectively bypassed if the metadata for the first region of data has the first defined state, and wherein the metadata for the first region of data has a second, different defined state if bits of the first region have states other than the single common state and the transmitting is selectively performed if the metadata for the first region of data has the second defined state.
In Example 39, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the metadata storing includes storing two bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a third defined state if the compression process selected for the first region compresses all units of data of the first region into a single unit of compressed data, and has a fourth defined state if the compression process selected for the first region compresses a first plurality of units of data of the first region into a first unit of compressed data and compresses a second plurality of units of data of the first region into a second unit of compressed data.
In Example 40, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the metadata storing includes storing three bits of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a fifth defined state if the compression process selected for the first region compresses a plurality of units of data of the first region into a unit of compressed data and leaves a first unit of data of the first region as a unit of uncompressed data.
In Example 41, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the metadata for the first region of data has a sixth defined state if the compression process selected for the first region leaves a second unit of data of the first region as a unit of uncompressed data and compresses a plurality of units of data of the first region into a unit of compressed data.
In Example 42, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the operations further comprise selecting a compression process for compressing the first region of data, wherein the metadata storing includes storing at least one bit of metadata for the first region of data to indicate a compression process selected for the first region of data wherein the metadata for the first region of data has a first defined state if the first region of data is compressed in a first compression process, wherein the metadata for the first region of data has a second defined state if the first region of data is compressed in a second compression process, and wherein the metadata for the first region of data has an nth defined state if the first region of data is compressed in an nth compression process wherein the number of bits of metadata is greater than one if n is greater than two.
In Example 43, the subject matter of Examples 36-43 (excluding the present Example) can optionally include wherein the selecting a compression process for compressing the first region of data includes selecting a different compression process for compression of the first region of data which is different from the first compression process, wherein the metadata storing includes updating the metadata for the first region to have a different defined state to indicate the different compression process if the first region of data is compressed in the different compression process.
The described operations may be implemented as a method, apparatus or computer program product using standard programming and/or engineering techniques to produce software, firmware, hardware, or any combination thereof. The described operations may be implemented as computer program code maintained in a “computer readable storage medium”, where a processor may read and execute the code from the computer storage readable medium. The computer readable storage medium includes at least one of electronic circuitry, storage materials, inorganic materials, organic materials, biological materials, a casing, a housing, a coating, and hardware. A computer readable storage medium may comprise, but is not limited to, a magnetic storage medium (e.g., hard disk drives, floppy disks, tape, etc.), optical storage (CD-ROMs, DVDs, optical disks, etc.), volatile and non-volatile memory devices (e.g., EEPROMs, ROMs, PROMs, RAMs, DRAMs, SRAMs, Flash Memory, firmware, programmable logic, etc.), Solid State Devices (SSD), etc. The code implementing the described operations may further be implemented in hardware logic implemented in a hardware device (e.g., an integrated circuit chip, Programmable Gate Array (PGA), Application Specific Integrated Circuit (ASIC), etc.). Still further, the code implementing the described operations may be implemented in “transmission signals”, where transmission signals may propagate through space or through a transmission media, such as an optical fiber, copper wire, etc. The transmission signals in which the code or logic is encoded may further comprise a wireless signal, satellite transmission, radio waves, infrared signals, Bluetooth, etc. The program code embedded on a computer readable storage medium may be transmitted as transmission signals from a transmitting station or computer to a receiving station or computer. A computer readable storage medium is not comprised solely of transmissions signals. Those skilled in the art will recognize that many modifications may be made to this configuration without departing from the scope of the present description, and that the article of manufacture may comprise suitable information bearing medium known in the art. Of course, those skilled in the art will recognize that many modifications may be made to this configuration without departing from the scope of the present description, and that the article of manufacture may comprise any tangible information bearing medium known in the art.
In certain applications, a device in accordance with the present description, may be embodied in a computer system including a video controller to render information to display on a monitor or other display coupled to the computer system, a device driver and a network controller, such as a computer system comprising a desktop, workstation, server, mainframe, laptop, handheld computer, etc. Alternatively, the device embodiments may be embodied in a computing device that does not include, for example, a video controller, such as a switch, router, etc., or does not include a network controller, for example.
The illustrated logic of figures may show certain events occurring in a certain order. In alternative embodiments, certain operations may be performed in a different order, modified or removed. Moreover, operations may be added to the above described logic and still conform to the described embodiments. Further, operations described herein may occur sequentially or certain operations may be processed in parallel. Yet further, operations may be performed by a single processing unit or by distributed processing units.
The foregoing description of various embodiments has been presented for the purposes of illustration and description. It is not intended to be exhaustive or to limit to the precise form disclosed. Many modifications and variations are possible in light of the above teaching.