The invention relates to implementing a multi-level memory subsystem with direct non-volatile access.
Phase-Change Memory and Switch (PCMS) is a non-volatile storage technology under development as a successor to the NAND non-volatile storage ubiquitous in today's solid state storage devices. PCMS offers much higher performance than NAND flash and in fact begins to approach the performance points of the Dynamic Random Access Memory (DRAM) currently used as primary dynamic storage in most client computing devices. While PCMS storage may initially be more expensive per-bit than NAND storage, that relationship is forecasted to change over time until, eventually, PCMS is less expensive than NAND.
The following description and accompanying drawings are used to illustrate embodiments of the invention. In the drawings:
The combination of technologies such as PCMS non-volatile storage, with the decrease in the size and the increase in performance of transistors in integrated circuits, may allow System-on-a-Chip (SoC) architectures to take advantage of the opportunity to create exciting new systems while achieving new combinations of low cost, low power, and high performance solutions. This advance is based on a revision to the existing memory hierarchy that establishes a different balance between the amounts of static random access memory (SRAM), dynamic RAM (DRAM), and non-volatile storage deployed in a low-cost smartphone, tablet, notebook, or other form of a mobile computing device. There are many types of non-volatile storage, though according to many embodiments described, non-volatile random access memory (NVRAM) storage is utilized and is described in greater detail below.
There are many possible technology choices for NVRAM, including phase change memory (PCM), Phase Change Memory and Switch (PCMS) (the latter being a more specific implementation of the former), byte-addressable persistent memory (BPRAM), 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), magnetoresistive memory, magnetic memory, magnetic random access memory (MRAM), and Semiconductor-oxide-nitride-oxide-semiconductor (SONOS, also known as dielectric memory).
NVRAM has the following characteristics:
As mentioned above, in contrast to FLASH memory, which must be rewritten and erased a complete “block” at a time, the level of granularity at which NVRAM is accessed in any given implementation may depend on the particular memory controller and the particular memory bus or other type of bus to which the NVRAM is coupled. For example, in some implementations where NVRAM is used as system memory, the NVRAM may be accessed at the granularity of a cache line (e.g., a 64-byte or 128-Byte cache line), notwithstanding an inherent ability to be accessed at the granularity of a byte, because cache line is the level at which the memory subsystem accesses memory. Thus, in some embodiments, when NVRAM is deployed within a memory subsystem, it may be accessed at the same level of granularity as DRAM used in the same memory subsystem. Even so, in some embodiments, the level of granularity of access to the NVRAM by the memory controller and memory bus or other type of bus is smaller than that of the block size used by Flash and the access size of the I/O subsystem's controller and bus.
NVRAM may also incorporate wear leveling algorithms to account for the fact that the storage cells begin to wear out after a number of write accesses, especially where a significant number of writes may occur such as in a system memory implementation. Since high cycle count blocks are most likely to wear out in this manner, wear leveling spreads writes across the far memory cells by swapping addresses of high cycle count blocks with low cycle count blocks. Note that most address swapping is typically transparent to application programs because it is handled by hardware, lower-level software (e.g., a low level driver or operating system), or a combination of the two.
NVRAM is distinguishable from other instruction and data memory/storage technologies in terms of its characteristics and/or its application in the memory/storage hierarchy. For example, NVRAM is different from:
NVRAM may be used as instruction and data storage that is directly addressable by a processor and is able to sufficiently keep pace with the processor in contrast to FLASH/magnetic disk/optical disc applied as mass storage. Direct addressability refers to a processor, such as a CPU or GPU, being able to send memory requests to the NVRAM as if it were standard DRAM (e.g., through standard memory store and load commands). Moreover, as discussed above and described in detail below, NVRAM may be placed on a memory bus and may communicate directly with a memory controller that, in turn, communicates directly with the processor.
NVRAM may be combined with other instruction and data storage technologies (e.g., DRAM) to form hybrid memories (also known as Co-locating PCM and DRAM; first level memory and second level memory; FLAM (FLASH and DRAM)). Note that at least some of the above technologies, including PCM/PCMS may be used for mass storage instead of, or in addition to, system memory, and need not be random accessible, byte addressable or directly addressable by the processor when applied in this manner.
For convenience of explanation, most of the remainder of the application will refer to “NVRAM” or, more specifically, “PCM,” or “PCMS” as the technology selection for the non-volatile memory. As such, the terms NVRAM, PCM, and PCMS may be used interchangeably in the following discussion. However it should be realized, as discussed above, that different technologies may also be utilized.
Multi-Level Memory (MLM) is a revolutionary change to a PC platform topology.
If a typical computing device were implemented with double data rate 3 (DDR3) components, then the latency for a memory read transaction, initiated by a processor, that misses the on-die caches, might be on the order of 30 nanoseconds (ns) from the time that the transaction was passed to the memory controller to the time that the data was returned to the on-die cache block (e.g., 15 ns for a DRAM page hit, 30 ns for a DRAM page empty, 45 ns for a DRAM page miss). This latency is often a significant driver of processor application performance.
The peak bandwidth on a single channel of DDR3-1600 memory is 12.8 gigabytes (GB) per second. The effective bandwidth of such a channel would typically be around 70% of that number. This effective memory bandwidth can play a fundamental role in the performance of general purpose processors and graphics processors.
In a simple form, 2-level memory can be considered a mechanism that replaces a system's bulk DDR DRAM storage with NVRAM storage (e.g., with PCMS storage), which is shown in
The solution shown in
Another issue specifically with PCMS that requires caution when replacing DRAM is the sharp difference between PCMS' read and write bandwidth capability. With DRAM, every memory device is capable of reading and writing data at the same rate. PCMS cores, however, by their physical nature, require a much longer time to write a piece of data than they do to read a piece of data. The read/write bandwidth ratio for PCMS is 4:1. In other words, data can be read from a PCMS device four times faster than data can be written to that device.
Taken as a whole, a computing device writes data to volatile memory (traditional DRAM) for one of three reasons:
At least the heap space, stack space, and DMA buffers are temporary by definition. Temporary storage usages, such as these, can be held in a smaller DRAM footprint with an efficient caching that implements traditional replacement algorithms and eliminates most traffic to and from the PCMS. At the core of an MLM-based memory system is a large write-back DRAM that retains recently used data, absorbs write transactions, and allows the system substantial read-around-write capabilities. The DRAM essentially is utilized as a cache for PCMS.
A cache that is unnecessarily blind to the characteristics of the data that it contains is often simplest to implement, but can be sub-optimal. For that reason, the MLM architecture comprehends that it may be better to allocate dedicated regions of the near memory for specific uses.
3. Multi-Level Memory with Direct Access (MLMD)
MLMD is a solution that retains the ability to run productivity, entertainment, and gaming applications under off-the-shelf Microsoft® Windows® and Linux operating systems at the same time that it removes external DRAM from the system in favor of new forms of non-volatile storage combined with embedded SRAM or DRAM devices.
In a handheld device or tablet, non-volatile storage will almost always be implemented using solid state devices like NAND or NVRAM, such as PCMS. When a device implements a MLM using NVRAM devices, it is natural to implement the entire storage system with NVRAM and it is desirable of course for the far memory and the storage system to share the NVRAM devices.
For PCMS specifically, the most visible issues include:
Similarly to the memory descriptors, there are also storage descriptors in the storage remap table. In the embodiment shown in
Returning to remap tables 700 and 702, in other embodiments, these tables are stored in a reserved portion of DRAM that stores MLMD and other control data structures.
Essentially,
In some embodiments, there are separate software drivers utilized for manipulating the memory and storage portions of the remapping system. In other embodiments, there is one software driver that includes logic, such as software driver logic 706, that handles both remap tables. According to some embodiments, memory descriptors may be handled in hardware while storage descriptors are handled by a software driver.
Although
Once storage and memory have been located in the same physical device and their addresses intermingled, it becomes unnecessary to perform disk-related DMA operations in a traditional way—specifically it becomes unclear that data should be copied from one part of the NVRAM into another part. Instead, the data might simply be referenced in-place by modifying pointers in the remap tables 700 and 702. In this way, applications see that data appears in their address spaces without first having been copied there. This remapping capability is called “direct access” and accounts for the “D” in an MLMD system.
The process begins by processing logic in a user process (e.g., a software application running on an OS) allocating a 3-page buffer from the OS for a 3-block read from non-volatile storage (e.g., PCMS) (processing block 900). In other embodiments, this may be a smaller or larger number of pages in the page buffer and a smaller or larger number of blocks for the read. Next, processing logic in the OS frees 3 pages in physical DRAM and maps pointers from the user space in the OS to physical memory pages A, B, and C (processing block 902). Pages A, B, and C are actual DRAM device physical address pages. Although processing logic at block 902 is described as being in the OS, in other embodiments, this processing logic may be implemented in hardware for faster allocation. Additionally, although the user buffer is described as being in DRAM, in other embodiments, the user buffer may be present in a specialized SRAM or in a dedicated portion of the processor's cache as opposed to simply being present in DRAM.
Then processing logic in the user process requests the OS to move data from non-volatile storage addresses X, Y, and Z (representing the 3 blocks in non-volatile storage) to the user buffer. Additionally, at this time the user process is set into an idle state by the OS (processing block 904). Next, processing logic in the OS walks through all memory translations to get to the physical memory page addresses and requests a storage driver running on the OS to move the data from storage addresses X, Y, and Z to physical memory pages A, B, and C. (processing block 906). Again, the processing logic in blocks 904 and 906 may be in hardware, rather than in the OS, in other embodiments. Furthermore, in other embodiments, hardware logic may be used in place of the storage driver to move data from storage address to physical memory pages.
Then processing logic in the storage driver requests a storage/device mapping for LBA storage addresses X, Y, and Z and changes pointers to memory pages A, B, and C to those for X, Y, and Z (processing block 908). The storage driver then informs the OS that the transfer has been completed (processing block 910), the OS marks the user process as active again (processing block 912), and the user process then receives the data (processing block 914). In other embodiments that are not shown, there is a single table mapping memory and storage to physical NVRAM pages where an entry for each page in the single table has a bit field that indicates whether the page is being utilized for storage or memory. In this embodiment, remapping from storage to memory, or vice versa, simply involves flipping the bit to designate the page in the other format.
Accesses to the storage space are directly mapped into the memory space in the following way:
Essentially, what was previously a designated storage location in physical NVRAM space (800 in
Although many forms of NVRAM may be utilized for these implementations, PCMS is a good candidate due to low read latencies. But PCMS has a substantial asymmetry between its read and write latencies. Thus, when dealing with PCMS, there are certain processes that may be utilized to minimize the shortcomings of PCMS writes. As a result of the much slower write times, there can be substantial delay added to read latencies when an ongoing write is occupying the PCMS memory system.
According to some embodiments, writes are performed only to pages that have been pre-cleaned (actually pre-set), since writing data to a pre-cleaned page is substantially faster than writing to a page that hasn't been prepared. Unfortunately, having a policy that writes only to pre-cleaned pages is not energy-efficient because this roughly doubles the energy taken to write each bit.
In many embodiments, a mechanism is utilized to write to pre-cleaned pages when the PCMS memory system is relatively busy and writes to non-cleaned pages when the PCMS memory system is relatively quiet. The net effect is to provide minimum power consumption while the system is lightly loaded and to trade higher power for improved performance when the system becomes busy.
There are also significant write time deviations between setting a PCMS storage element (a bit) to “1,” which takes a relatively long time, versus setting the same element to “0,” which takes roughly the same amount of time as it takes to read an element. Thus, it is highly beneficial to preset free pages of PCMS memory to all l's, and then, while performing a write to the page with information, only the bits that need to be set to 0 would need to be changed.
Therefore, in many embodiments, a pool of preset pages (pages in which every bit is set to 1) is utilized for write operations. The PCMS storage/memory controller is responsible for scheduling transfers of read and write data between any controller caches or write buffers that are used to store data in motion to and from the PCMS devices. Optimally, all data that won't be accessed for a while would be moved into PCMS in order to make room in controller caches and write buffers for other data. Additionally, moving data that will be used soon into controller caches will increase system performance.
According to many embodiments, the process shown in
More specifically, a free page pool 1002 of free PCMS memory pages is accessible to the write buffer/cache management logic 1000. When the management logic decides to go ahead and retire a write request, a page from the free page pool 1002 is mapped into phantom address space 1004 (step 1—denoted by the 1 in the circle in
Page cleaning logic 1010 then pulls a page from the dirty pool and cleans it (step 4). In many embodiments, the cleaning process sets all bits in the page to “1” to pre-set the page for fast writes. A stream of pages (step 5) is then sent by the page cleaning logic 1010 to the free page pool 1002. Similarly to the dirty page pool 1008, the free page pool 1002 may be pointed to by a free page pool pointer. The free page pool pointer points to the page at the front of a list of free pages of PCMS memory. When a page is taken from the list and mapped to phantom address space for a write, the pointer then points to the next page in the list. When a clean page arrives from the stream of clean pages, that page is appended to the end of the list.
The page cleaning logic 1010 generally operates independently from the write buffer/cache management logic 1000. The page cleaning process, per page, is governed at a rate that takes into consideration overriding system considerations, such as power and performance operating points. In many embodiments, the page cleaning logic 1010 keeps a count of pages that need cleaning, by incrementing a counter for every page that arrives at the dirty page pool 1008 and decrementing the same counter for every page that is pulled out of the dirty page pool 1008 to be cleaned. This is in addition to keeping track of the pointer to the front of the list of pages that comprises the dirty page pool 1008. In other embodiments, the dirty page pool 1008 and clean page pool 1002 may be kept in tables rather than in lists.
According to some embodiments, write buffer/cache management logic 1000 may include logic that fills gaps for partially cached pages. For example, if the write buffer has partial data from a page to write to a clean page mapped into phantom address space, then the logic can perform a read from the PCMS device to get the remaining information for the page to fill in the gaps of write data.
Additionally, the write buffer/cache management logic 1000 includes a mechanism that is capable of physically writing data from the write buffer 1006 to a physical PCMS page of memory. With the page cleaning logic 1010 in operation, there could always be some number of pre-set pages available for writes.
The process begins with a page of data in a write buffer that needs to be flushed (processing block 1100). The page is waiting to be written out to a PCMS memory device and the process of flushing the buffer accomplishes the write. The process continues with processing logic determining if the entire page of data is valid (processing block 1102). If the entire 4K page of data is not valid then processing logic fetches data for the portions of the page that are not valid from the old PCMS page that had the data which went into the write buffer (processing block 1104). Then regardless of whether processing block 1104 is performed, the next step for either logic flow path is for processing logic to find the next free PCMS page in the free page pool (processing block 1106).
Once the free page is located, in some embodiments, processing logic writes the entry or entries from the write buffer to the found free page in the free pool (processing block 1108). In some embodiments, processing logic then modifies the pointer in the phantom address table (which also can be referred to as the memory remap table 700 from
The PCMS page status table 1200 includes two bits per page entry that is encoded as follows:
At 2-bits per entry with 256 million entries for a TB of PCMS, the table would require 64 MB of storage. This page status table allows for a distinction between pages that have been pre-cleaned (e.g., pages that have all bits with “1”) and pages that haven't been cleaned (e.g., pages that have old data in them and also known as “dirty” pages).
For access to free pages, two pointers are provided. A first pointer 1202 points to a list (i.e., pool) of cleaned free pages 1204. A second pointer 1206 points to the list/pool of dirty free pages 1208. In many embodiments, these pools comprise a list of addresses to the locations in PCMS physical address space. In some embodiments, these two pools may be maintained in adjacent locations to the PCMS page status table 1200. In other embodiments, these two pools may be maintained elsewhere in the system, such as in DRAM.
Page cleaning logic 1010 (which is potentially located within memory/storage control in
In other embodiments, page cleaning logic 1010 can additionally search the PCMS page status table 1200 for free/not clean pages (01) to be cleaned. For found pages that are not clean, page cleaning logic 1010 can add the page to the dirty free page pool 1208.
During times when there is little or no PCMS traffic, page cleaning logic 1010 may decide to clean one or more pages located in the dirty free page pool 1208. When this happens to a page, page cleaning logic then adjusts the status bits for that page in the PCMS page status table 1200 to 00, which signifies the page is free and clean. Then page cleaning logic 1010 may move that page from the dirty free page pool 1208 to the cleaned free page pool 1204. When there is significant PCMS traffic, page-cleaning logic may not attempt to clean any pages to not adversely impact PCMS memory performance.
To determine when there is PCMS traffic, a memory traffic monitor 1212 is utilized to track recently consumed PCMS bandwidth. During operation, the memory traffic monitor logic is constantly counting the number of memory transactions within a given period of time, such as 1 microsecond (μs). If the number of PCMS transactions during this given period is greater than a programmable value (the programmable value may be programmed through BIOS or elsewhere), then a bit is set in a shift register located within memory traffic monitor 1212. A separate piece of logic in the memory traffic monitor 1212 monitors the shift register in order to understand how many “busy” periods of time the system has had during the past “n” periods of time. If the number of busy periods is greater than a programmable number, then the logic will cause the next free pointer 1214 to be sourced from the cleaned free page pool 1204. If the number of busy periods is less than or equal to the value, then the next free pointer 1214 will be sourced from the not-cleaned free page pool 1208.
As mentioned above, this same memory traffic monitoring logic may be utilized to help page cleaning logic 1210 determine when to clean pages, thus, the memory traffic monitor 1212 is additionally communicatively coupled to the page cleaning logic 1210 in many embodiments.
In another embodiment, the system could choose to pre-clear pages in all cases where the device was connected to alternating current (AC) power, since the power consumption may only be a problem when a device is running on battery.
Returning to
Thus, to remedy this issue,
In
In many embodiments, when the logic illustrated in
The memory pool write mechanism will always write data to an empty memory-allocated page.
The storage pool, represented by NVRAM addresses that are mapped into storage remapping table 702, interacts with the memory write mechanism to write to storage-allocated pages, migrating the written page to the storage pool when the write completes.
The storage pool pushes pages that are no longer necessary into the write pool when it notices they are no longer needed. In some embodiments, they are pushed into the free page pool 1304, which may or may not be a “clean” pool (i.e. a pool of free pages that have been pre-set for writes, such as the one discussed above in regard to
When a page is written to storage, these attributes for this process will cause the written page to migrate from the memory pool to the storage pool and the page previously allocated to the storage location to migrate from the storage pool to the memory pool.
The process is started through a periodic timer or write counter (timer/counter: T/C 1308) that may be present within the memory/storage swap hardware logic 1300. At a certain point, the T/C 1308 fires (which refers to a specified amount of time passing for the counter or a specified number of writes taking place) and causes the data in a PCMS device page allocated to a storage (a current storage page mapped into storage remap table 702) to be copied to write buffer 1006 (step 1). Once the write buffer 1006 has the data to be written to an empty page in NVRAM memory space (a page allocated to memory remap table 700), then a free page from the free page pool 1304 is allocated and mapped into the memory remap table 700 (step 2A).
Once the page is allocated in the table, then the write buffer is flushed and the data originally received from the current storage page is written into the new mapped free page in memory remap table 700 (step 2B). At this point, the data that was stored in the current storage page in storage space is now located in the new mapped free page in memory space. After this takes place, or potentially in conjunction with steps 2A and 2B, the NVRAM address to the current storage page (which now has old data in it) is reallocated into memory space as the new migrated memory page (step 3). Thus, the physical NVRAM page that this address points to changes from being allocated as storage space in the storage remap table 702 to being allocated as memory space in the memory remap table 700. At the same time of this reallocation or at a later time, the new mapped free page, which now has the storage data written to it that arrived from the write buffer 1006 in step 2B, is reallocated as a new migrated storage page (step 4). Therefore, the physical NVRAM page that this address changes from being allocated as memory space in the memory remap table 700 to being allocated as storage space in the storage remap table 702.
At this point the migration has completed. This migration can methodically happen for page after page of physical NVRAM memory. Whenever the T/C 1308 fires, another memory allocated page is migrated to storage and a corresponding storage allocated page is migrated to memory. When this process is repeated throughout all NVRAM physical pages over time, the result is an evenly worn NVRAM device from the bottom to top of the device's physical memory addresses.
Additional power and performance considerations may be necessary for efficiency purposes depending on the “plane” configuration of an NVRAM physical device. For example, with PCMS in many cases there are multiple “planes,” which refer to regions of memory that are efficient when working with consecutive accesses in a given plane, but the device loses transaction efficiency (from both a power and performance perspective) when consecutive accesses to different physical memory locations cross planes.
PCMS generally has fairly short latencies for most accesses, about 50 nanoseconds (ns) for current generation devices, but requires longer latencies, about 100 ns when successive accesses are to two different planes in the memory device, where a plane may represent about a quarter of the entire memory space in the device. Additionally, there can be substantial power/energy penalties for crossing planes between accesses.
Thus, a mechanism is suggested to alleviate these penalties as much as possible by eliminating as many unnecessary plane transitions as possible.
In many embodiments, there is a set of PCMS device accesses (A1 through A5) that are shown in order on the actual planes in view 1400. Access 1 is to a physical location in plane 1, access 2 is in a physical location in plane 2, access 3 is in a physical location in plane 3, access 4 is in a physical location in plane 4, and access 5 is in a physical location in plane 1. In view 1402, the transitions (T1 through T4) between planes are shown when the accesses are retired in order. Specifically, plane transition 1 takes place between accesses 1 and 2, plane transition 2 takes place between accesses 2 and 3, plane transition 3 takes place between accesses 3 and 4, and plane transition 4 takes place between accesses 4 and 5. So with a standard access order view 1404 of accesses in the order received, there are 4 plane transitions.
With a memory control logic having transaction buffers that are queued (incoming read and write requests are queued prior to execution, it is possible and actually desirable to re-order the transaction order when logic has knowledge of the physical locations of the accesses. Thus, memory control logic, which may include a PCMS transaction re-order logic unit, has the capability of performing lookups from queued PCMS transactions by using memory/storage remapping logic (discussed above) to obtain physical PCMS addresses for each transaction. Based on having knowledge of the physical location of each PCMS transaction in a transaction queue, a PCMS transaction re-order logic unit may perform a re-order of transactions to increase the plane transition efficiency of a set of transactions.
For
Although not shown, each CPU core may internally include one or more instruction/data caches, execution units, prefetch buffers, instruction queues, branch address calculation units, instruction decoders, floating point units, retirement units, etc. Each core present is located on a CPU semiconductor die. For each logic unit shown other than the core(s) 1502 in the SoC Package 1500, the logic unit may be on the CPU core(s) 1502 semiconductor die in some embodiments or on another die in other embodiments. If a given logic unit is not on the same die as CPU core(s) 1502, that logic unit would be on a different semiconductor die, though in the same SoC package 1500, which can include several dies communicatively coupled with each other in the package.
The SoC 1500 also includes at least one lower level CPU cache, such as CPU cache 1506. This may be a general purpose cache that is capable of storing a significant amount of data retrieved from memory locations in volatile memory 1518 and/or NVRAM 1520. In different embodiments, CPU cache 1506 may be shared among all cores or each core may have its own lower level cache.
One or more GPU core(s) 1504 are also included in SoC package 1500 as well as a lower level GPU cache 1508 which may store graphics related data for the GPU Core(s) 1504 to work on. GPU core(s) 1504 may internally include one or more execution units and one or more instruction and data caches utilized to feed the execution units with information to process. Additionally the GPU core(s) 1504 may contain other graphics logic units that are not shown in
SoC package 1500 may also include a home agent 150 that incorporates components coordinating and operating core(s) 1502 as well as other elements of SoC package 1500. Home agent unit 1510 may include, for example, a power control unit (PCU). The PCU may include logic and components needed for regulating the power state of the core(s) among other tasks.
In
“Volatile memory” 1518 is an intermediate level of memory configured in conjunction with NVRAM 1520 that has lower read/write access latency relative to NVRAM 1520 and/or more symmetric read/write access latency (i.e., having read times which are roughly equivalent to write times). As discussed above, in some embodiments, the volatile memory 1518 has significantly lower write latency than the NVRAM 1520 but similar (e.g., slightly lower or equal) read latency; for instance the volatile memory 1518 may be a volatile memory such as volatile random access memory (VRAM) and may comprise a DRAM or other high speed capacitor-based memory. Note, however, that the underlying principles of the invention are not limited to these specific memory types. Additionally, the volatile memory 1518 may have a relatively lower density and/or may be more expensive to manufacture than the NVRAM 1520.
In some embodiments, volatile memory 1518 is configured between the NVRAM 1518 and the CPU cache 1506. In some of the embodiments described below, volatile memory 1518 is utilized to mask the performance and/or usage limitations of the NVRAM 1520 including, for example, read/write latency limitations and memory degradation limitations. In these implementations, the combination of volatile memory 1518 and NVRAM 1520 operates at a performance level which approximates, is equivalent or exceeds a system which uses only DRAM as system memory.
Although shown in a specific configuration in
In many embodiments, an input/output (I/O) subsystem 1530 is present in the system in
Additionally, there may be one or more wireless protocol I/O adapters. Examples of wireless protocols, among others, are used in personal area networks, such as IEEE 802.15 and Bluetooth, 4.0; wireless local area networks, such as IEEE 802.11-based wireless protocols; and cellular protocols
A Basic Input/Output System (BIOS) flash 1536 device may additionally be present in the system to provide a set of boot instructions when the system powers on or reboots. For BIOS flash 1536 device, some of the protocols that I/O adapters 1534 may translate include Serial Peripheral Interface (SPI), Microwire, among others.
In the following description, numerous specific details such as logic implementations, means to specify operands, resource partitioning/sharing/duplication implementations, types and interrelationships of system components, and logic partitioning/integration choices are set forth in order to provide a more thorough understanding of the present invention. It will be appreciated, however, by one skilled in the art that the invention may be practiced without such specific details. In other instances, control structures, gate level circuits and full software instruction sequences have not been shown in detail in order not to obscure the invention. Those of ordinary skill in the art, with the included descriptions, will be able to implement appropriate functionality without undue experimentation.
References in the specification to “one embodiment,” “an embodiment,” “an example embodiment,” etc., indicate that the embodiment described may include a particular feature, structure, or characteristic, but every embodiment may not necessarily include the particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same embodiment. Further, when a particular feature, structure, or characteristic is described in connection with an embodiment, it is submitted that it is within the knowledge of one skilled in the art to effect such feature, structure, or characteristic in connection with other embodiments whether or not explicitly described.
In the following description and claims, the terms “coupled” and “connected,” along with their derivatives, may be used. It should be understood that these terms are not intended as synonyms for each other. “Coupled” is used to indicate that two or more elements, which may or may not be in direct physical or electrical contact with each other, co-operate or interact with each other. “Connected” is used to indicate the establishment of communication between two or more elements that are coupled with each other.
Embodiments of the invention may also be provided as a computer program product which may include a non-transitory machine-readable medium having stored thereon instructions which may be used to program a computer (or other electronic device) to perform a process. The non-transitory machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, ROMs, RAMs, EPROMs, EEPROMs, magnet or optical cards, propagation media or other type of media/machine-readable medium suitable for storing electronic instructions. Embodiments of the invention may also be downloaded as a computer program product, wherein the program may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
While the invention has been described in terms of several embodiments, those skilled in the art will recognize that the invention is not limited to the embodiments described, can be practiced with modification and alteration within the spirit and scope of the appended claims. The description is thus to be regarded as illustrative instead of limiting.
The present application is a continuation, claims the benefit of and priority to previously filed U.S. application Ser. No. 15/640,373 filed on Jun. 30, 2017, now U.S. Pat. No. 10,241,710, which in turn is a continuation of U.S. application Ser. No. 15/214,005 filed on Jul. 19, 2016, now U.S. Pat. No. 9,703,502, which in turn is a continuation of U.S. application Ser. No. 14/879,004 filed on Oct. 8, 2015, now U.S. Pat. No. 9,430,151, which in turn is a continuation of U.S. application Ser. No. 13/993,695 filed on Jun. 13, 2013, now U.S. Pat. No. 9,190,124, which in turns claims benefit of International Application No. PCT/US2011/067824 filed on Dec. 29, 2011. The entire Specifications of which are hereby incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
Parent | 15640373 | Jun 2017 | US |
Child | 16363576 | US | |
Parent | 15214005 | Jul 2016 | US |
Child | 15640373 | US | |
Parent | 14879004 | Oct 2015 | US |
Child | 15214005 | US | |
Parent | 13993695 | Jun 2013 | US |
Child | 14879004 | US |