|Publication number||US6920533 B2|
|Application number||US 09/894,310|
|Publication date||Jul 19, 2005|
|Filing date||Jun 27, 2001|
|Priority date||Jun 27, 2001|
|Also published as||CN1253787C, CN1520549A, US20030005223, WO2003003202A1|
|Publication number||09894310, 894310, US 6920533 B2, US 6920533B2, US-B2-6920533, US6920533 B2, US6920533B2|
|Inventors||Richard L. Coulson, John I. Garney, Jeanna N. Matthews, Robert J. Royer|
|Original Assignee||Intel Corporation|
|Export Citation||BiBTeX, EndNote, RefMan|
|Patent Citations (27), Non-Patent Citations (18), Referenced by (40), Classifications (13), Legal Events (5)|
|External Links: USPTO, USPTO Assignment, Espacenet|
The invention relates to operating systems, and more particularly, to a non-volatile cache used in a system.
The use of a cache with a processor reduces memory access time and increases the overall speed of a device. Typically, a cache is an area of memory which serves as a temporary storage area for a device. Data frequently accessed by the processor remain in the cache after an initial access and subsequent accesses to the same data may be made to the cache.
Two types of caching are commonly used, memory caching and disk caching. A memory cache, sometimes known as cache store, is typically a high-speed memory device such as a static random access memory (SRAM). Memory caching is effective because most programs access the same data or instructions repeatedly.
Disk caching works under the same principle as the memory caching but uses a conventional memory device such as a dynamic random access memory (DRAM). The most recently accessed data from the disk is stored in the disk cache. When a program needs to access the data from the disk, the disk cache is first checked to see if the data is in the disk cache. Disk caching can significantly improve the performance of applications because accessing a byte of data in RAM can be much faster than accessing a byte on a disk. For example, a sequence of disk accesses required to load an operating system and launch system services is predictable. As a result, this initialization data can be brought into a disk cache during normal operation for faster access.
However, the memory size of a cache is limited and is generally used to store the most recently used data. Therefore, when the cache becomes full, existing lines of data stored in the cache are replaced or de-allocated to make room for newly requested lines of data. The most commonly used cache replacement is the least recently used (LRU) algorithm by which the oldest (least recently used) memory line is evicted.
Although the replacement process generally does not cause problems, replacement of certain types of data can be detrimental. Accordingly, ways to solve some of the problems that can be caused by the replacement algorithm have been suggested in the related art. For example, U.S. Pat. No. 5,913,224 entitled “Programmable Cache Including a Non-Lockable Data Way and a Lockable Data Way Configured To Lock Real-Time Data” and U.S. Pat. No. 5,974,508 entitled “Cache Memory System and Method For Automatically Locking Cache Entries To Prevent Selected Memory Items From Being Replaced” disclose a method to lock the contents of time-critical data in a volatile cache memory to prevent eviction during normal operation.
However, for the type of the data necessary during a system initialization, locking the initialization data into a volatile cache memory would not make the data available when required as the information would be lost between system boots or power cycling of the system.
The invention will be described in detail with reference to the following drawings in which like reference numerals refer to like elements wherein:
In the following description, specific details are given to provide a thorough understanding of the invention. For example, some circuits are shown in block diagram in order not to obscure the present invention in unnecessary detail. However, it will be understood by those skilled in the art that the present invention may be practiced without such specific details.
As disclosed herein, a “cache” refers to a temporary storage area and may be either a memory cache or disk cache. The term “data” refers to both data and instructions that can be stored in a cache. A “disk” refers to a hard disk drive, a floppy disk drive, a compact disc (CD) drive or any other magnetic or optical memory device for mass storage of data. The term “system initialization” refers both to a system boot when the power is first turned on, known as cold booting and a system reboot when a system is restarted, known as warm booting. For purposes of the explanation, system boot and system reboot will be used interchangeably. The term “computer readable medium” includes, but is not limited to portable or fixed storage devices, optical storage devices, and any other memory devices capable of storing computer instructions and/or data. The term “computer instructions” are software or firmware including data, codes, and programs that may be read and/or executed to perform certain tasks.
Generally, the invention provides a system and method to retain in a non-volatile storage media the data expected to be needed during a system initialization. The time required to reload an operating system and restart system services is a visible source of irritation to users. However, much of this time is devoted to reading the necessary data from a disk. Since the sequence of data read from a disk during system start-up or initiation is repeatable and can be predicted, the initialization time is reduced by having the data necessary for system initialization pre-loaded into a cache.
In particular, the data accessed during initialization (hereinafter “necessary data”) is loaded into a non-volatile cache and marked or “pinned” to prevent eviction. Accordingly, the necessary data would be resident in the cache for fast access during system initialization even following an unexpected system shutdown, thereby avoiding accesses to the disk.
An exemplary embodiment of a system 100 implementing the principles of the invention is shown in FIG. 1. The system 100 includes a processor 110 coupled to a volatile memory 120 (hereinafter “memory”) by a bus 130. In one embodiment, the memory 110 is a dynamic random-access-memory (DRAM). Also coupled to the bus 130, a memory control hub 140 controls the operations of the memory 120 via link 125, a non-volatile cache 150 (hereinafter “cache”) via link 155 and a disk 160 via link 165. The memory control hub 140 includes a logic circuit (not shown) to manage the state or metadata information of memory 120 and the cache 150. Moreover, it will be appreciated by those skilled in the art that the memory control hub 140 may also include additional circuits to control caching functions such as read, write, update and invalidate operations. Finally, a number of input/output devices 170 such as a keyboard, mouse and/or display may be coupled to the bus 130.
Although the system 100 is shown as a system with a single processor, the invention may be implemented with multiple processors, in which additional processors would be coupled to the bus 130. In such case, each additional processor would share the cache 150 and memory 120 for writing data and/or instructions to and reading data and/or instructions from the same. Also, the system 100 shows the cache 150 to be a non-volatile storage media. However, the cache 150 may be a combination of volatile and non-volatile storage media. Similarly, the memory 120 may be one or any combination of a volatile storage media and a non-volatile storage media. Moreover, the cache 150 may be implemented into the system 100 as an add-in card such as a peripheral component interconnect (PCI) add-in. In still another embodiment, a portion of the disk 160 may be allocated as the cache 150. The invention will next be described below.
In one embodiment, the pinning of data is accomplished by adding a “pinned bit” to the metadata state for each line of data in the cache 150. Typically, the metadata required for correct operation is stored in both the memory 120 and the cache 150. Because the metadata is retained between system boots, such metadata will be called “persistent metadata.” Persistent metadata may include flags to indicate whether a corresponding line of data in the cache 150 is valid and/or dirty and a tag to indicate the starting disk address for the data contained in a cache line. Metadata that is not required for correct operation, but improves performance is typically stored in a volatile storage media such as in the memory 120. Stored in a volatile storage media, such metadata is lost between system boots and will be called “non-persistent metadata.” Non-persistent metadata may include the age of each cache line for use as the least recently used (LRU) information.
In one embodiment, the pinned bit is placed in the memory 120 as a non-persistent metadata. On system reboot, the necessary data pinned during initialization of the previous system boot would already be loaded into the cache 150. However, since the pinned bit is non-persistent, the pinning bit information is lost between system boots and a determination cannot be made as to whether a line of data was pinned or whether it was simply still in the cache 150. Therefore, during each initialization sequence, a pinning procedure is performed to pin data. Here, the need to improve system boot performance and the need to keep majority of space in the cache 150 free or replaceable during normal operation should be balanced. Hence, an upper bound on the amount of data pinned into the cache 150 is set to limit the amount of space occupied during normal execution.
Although any method may be used to limit the amount of data pinned,
If there is an existing pinned line, in the associativity set for example, not cached before reboot, the memory control hub 140 causes the pinned bit(s) corresponding to that existing line(s) to be cleared (or unpinned) and the pinned bit corresponding to the currently accessed cache line to be set (block 470). If it is determined either that the currently accessed cache line was not cached before reboot in block 450 or that there is no pinned line not cached before reboot in block 460, the memory control hub 140 causes the currently accessed cache line to be brought into the cache 150 but not pinned (block 470).
After blocks 440, 470 and 480, a determination is made whether the timer has expired (block 490). If the timer has expired, the pinning procedure 400 ends. Otherwise, the procedure returns to block 430 and repeats. Until the timer expires, data is selectively pinned into the cache 150 to improve the performance of the next reboot. At the same time, the number of lines that may be pinned is limited to allow the majority of space in the cache for normal operation.
In the pinning procedure 400, preference is given to pinning lines that were already in the cache by pinning lines which were cached before reboot. If there is more than one pinned line not cached before reboot in block 460, the pinned bit corresponding to the line with the latest age is cleared using the LRU information. Therefore, the pinning procedure 400 may also give preference to lines with earlier times in order to reflect the true initialization sequence rather than possible early user activity. Furthermore, as in the pinning procedures 200 and 300, the timer should be set such that a generous amount of time is reserved for the initialization sequence and the maximum amount to pin should be set such that the majority of each set in the cache is preserved for normal operation. For example, the timer may be set to one minute and the maximum number may be set to one line per set for mass storage caches.
Once the timer expires or the maximum amount has been pinned in the pinning procedures 200-400, any further accesses will not evict the cache lines with the corresponding pinned bits set. Also, the memory control hub 140 of
By pinning data into a non-volatile cache during system initialization, the time needed for a system initialization can be reduced. This is especially significant in mass storage caches. In another embodiment, however, the pinned bit may be stored in a non-volatile storage media such that the information is retained between boots. For example, the pinned bit may be included into the metadata stored in the cache 150 or to the memory 120, if the memory 120 includes a non-volatile storage media. In such case, the pinning procedure during each system initialization would not be necessary as the pinning bit information is retained between system boots. Moreover, although the invention has been described with reference to a system initialization, the teachings of the invention is not limited to pinning data necessary during system initialization and can be applied in any operation which require repeated use of data in a non-volatile cache.
The foregoing embodiments are merely exemplary and are not to be construed as limiting the present invention. The present teachings can be readily applied to other types of apparatuses. The description of the present invention is intended to be illustrative, and not to limit the scope of the claims. Many alternatives, modifications, and variations will be apparent to those skilled in the art.
|Cited Patent||Filing date||Publication date||Applicant||Title|
|US5586291||Dec 23, 1994||Dec 17, 1996||Emc Corporation||Disk controller with volatile and non-volatile cache memories|
|US5636355||Jun 30, 1993||Jun 3, 1997||Digital Equipment Corporation||Disk cache management techniques using non-volatile storage|
|US5758149 *||Mar 17, 1995||May 26, 1998||Unisys Corporation||System for optimally processing a transaction and a query to the same database concurrently|
|US5761678||Jun 26, 1996||Jun 2, 1998||International Business Machines Corporation||Creation of clone storage area with identification of base storage area and deferred cloning of metadata|
|US5913224||Feb 26, 1997||Jun 15, 1999||Advanced Micro Devices, Inc.||Programmable cache including a non-lockable data way and a lockable data way configured to lock real-time data|
|US5974508||Oct 8, 1997||Oct 26, 1999||Fujitsu Limited||Cache memory system and method for automatically locking cache entries to prevent selected memory items from being replaced|
|US5983310||Feb 13, 1997||Nov 9, 1999||Novell, Inc.||Pin management of accelerator for interpretive environments|
|US6044478 *||May 30, 1997||Mar 28, 2000||National Semiconductor Corporation||Cache with finely granular locked-down regions|
|US6119118||Jun 1, 1999||Sep 12, 2000||Apple Computer, Inc.||Method and system for extending file system metadata|
|US6240416||Sep 11, 1998||May 29, 2001||Ambeo, Inc.||Distributed metadata system and method|
|US6295538||Dec 3, 1998||Sep 25, 2001||International Business Machines Corporation||Method and apparatus for creating metadata streams with embedded device information|
|US6298130||Jun 6, 2000||Oct 2, 2001||Genesys Telecommunications Laboratories Inc.||Metadata-based network routing|
|US6370614||Jan 26, 1999||Apr 9, 2002||Motive Power, Inc.||I/O cache with user configurable preload|
|US6463509 *||Jan 26, 1999||Oct 8, 2002||Motive Power, Inc.||Preloading data in a cache memory according to user-specified preload criteria|
|US20010043784 *||Mar 14, 2001||Nov 22, 2001||Yoshinari Shirata||Picture quality adjustment method and picture quality adjustment apparatus|
|US20020174370 *||May 17, 2001||Nov 21, 2002||International Business Machines Corporation||Power Management delay mouse pointer indicator|
|US20030005219||Jun 29, 2001||Jan 2, 2003||Royer Robert J.||Partitioning cache metadata state|
|US20030046493||Aug 31, 2001||Mar 6, 2003||Coulson Richard L.||Hardware updated metadata for non-volatile mass storage cache|
|US20030061436||Sep 25, 2001||Mar 27, 2003||Intel Corporation||Transportation of main memory and intermediate memory contents|
|US20030074524||Oct 16, 2001||Apr 17, 2003||Intel Corporation||Mass storage caching processes for power reduction|
|US20030120868||Dec 21, 2001||Jun 26, 2003||Royer Robert J.||Method and system to cache metadata|
|US20030188123||Apr 1, 2002||Oct 2, 2003||Royer Robert J.||Method and apparatus to generate cache data|
|US20030188251||Mar 27, 2002||Oct 2, 2003||Brown Michael A.||Memory architecture and its method of operation|
|EP0210384A1||Jun 6, 1986||Feb 4, 1987||Hewlett-Packard Company||Cache memory consistency control with explicit software instructions|
|EP0702305A1||Sep 12, 1995||Mar 20, 1996||Nec Corporation||Disk memory apparatus|
|GB2210480A||Title not available|
|WO2002001365A2||Jun 1, 2001||Jan 3, 2002||Intel Corporation||Non-volatile cache|
|1||C. F. Pulvarti, The Catholic University of America, IRE Transaction-Component Parts, "Ferroelectrics and their Memory Applications", 1956.|
|2||EEdesign, "Ramtron boosts serial FRAM density to 64 Kbits", Oct. 6, 1999.|
|3||J.L. Hennessy et al., "Computer Architecture: A Quantitive Approach" 3rd Edition, 2003, pp. 454-457 and pp. 689-692.|
|4||Jack Robertson, Silison Strategies, "Hyundai enters Japanese-dominated FeRAM Market", Sep. 3, 1998.|
|5||*||Microsoft Computer Dicitionary, Copiright 1999, Microsoft Press, Fourth Edition, 58-59 and 235.|
|6||O. Auciello et al., Physics Today, "The Physics of Ferroelectric Memories", Jul. 1998.|
|7||PCT Search Report, dated Nov. 14, 2002.|
|8||Pending U.S. Appl. No. 09/602,008, filed Jun. 23, 2000, to Richard Coulson, "In-Line Cache".|
|9||Pending U.S. Appl. No. 09/602,009, filed Jun. 23, 2000, to Richard Coulson, "Non-Volatile Cache Expansion Board".|
|10||Pending U.S. Appl. No. 09/602,011, filed Jun. 23, 2003 to Richard Coulson,: Non-Volatile Cache Integrated with Storage Devices.|
|11||Pending U.S. Appl. No. 09/669, 770, filed Sep. 26, 2000, to Richard Coulson, "Non-Volatile Mass Storage Cache Coherency Administrator".|
|12||Pending U.S. Appl. No. 09/895,578, Royer et al., filed Jun. 29, 2001.|
|13||Pending U.S. Appl. No. 09/945,266, Richard Coulson, filed Aug. 31, 2001.|
|14||Pending U.S. Appl. No. 10/026,398, Royer et al., filed Dec. 21, 2001.|
|15||Ramtron International Corp., data sheet "Preliminary-FM1608 64Kb Bytewide FRAM Memory", Dec. 7, 1999.|
|16||Ramtron International Corp., data sheet "Preliminary-FM24C64 64Kb FRAM Serial Memory", Dec. 7, 1999.|
|17||Ramtron International Corp., data sheet, "The FRAM Technology", Jan. 1994.|
|18||W. Merz et al., Bell Laboratories Record, "Ferroelectric Storage Devices", Sep. 1955.|
|Citing Patent||Filing date||Publication date||Applicant||Title|
|US7103724||Apr 1, 2002||Sep 5, 2006||Intel Corporation||Method and apparatus to generate cache data|
|US7162625 *||Mar 10, 2003||Jan 9, 2007||Dell Products L.P.||System and method for testing memory during boot operation idle periods|
|US7275135||Aug 31, 2001||Sep 25, 2007||Intel Corporation||Hardware updated metadata for non-volatile mass storage cache|
|US7464250 *||Mar 11, 2004||Dec 9, 2008||International Business Machines Corporation||Method to reduce disk access time during predictable loading sequences|
|US7607000 *||May 13, 2003||Oct 20, 2009||Apple Inc.||Method for booting an operating system|
|US7634689 *||Sep 22, 2005||Dec 15, 2009||Advanced Micro Devices, Inc.||Boot performance optimization for hard drive for personal internet communicator|
|US7958398 *||Jul 16, 2008||Jun 7, 2011||International Business Machines Corporation||Reference state information generation|
|US8151102 *||Mar 27, 2009||Apr 3, 2012||Lenovo (Singapore) Pte. Ltd.||System and methods for booting electronic devices|
|US8225079||Sep 25, 2009||Jul 17, 2012||Apple Inc.||Accelerating system boot using a set of control data recorded by operating system during a first OS boot|
|US8352718||Jul 13, 2009||Jan 8, 2013||American Megatrends, Inc.||Method, system, and computer-readable medium for expediting initialization of computing systems|
|US8407398 *||Oct 1, 2008||Mar 26, 2013||Lenovo (Singapore) Pte. Ltd.||Cache mapping for solid state drives|
|US8464001 *||Dec 9, 2008||Jun 11, 2013||Nvidia Corporation||Cache and associated method with frame buffer managed dirty data pull and high-priority clean mechanism|
|US8630056||Sep 12, 2011||Jan 14, 2014||Western Digital Technologies, Inc.||Hybrid drive adjusting spin-up profile based on cache status of non-volatile semiconductor memory|
|US8775845 *||Jun 2, 2011||Jul 8, 2014||Fujitsu Limited||Information processing device, power supply control method and storage medium|
|US8909889||Oct 10, 2011||Dec 9, 2014||Western Digital Technologies, Inc.||Method and apparatus for servicing host commands by a disk drive|
|US9015461||May 24, 2011||Apr 21, 2015||Intel Corporation||Booting an operating system of a system using a read ahead technique|
|US9032151||Nov 14, 2008||May 12, 2015||Microsoft Technology Licensing, Llc||Method and system for ensuring reliability of cache data and metadata subsequent to a reboot|
|US9069475||Oct 26, 2010||Jun 30, 2015||Western Digital Technologies, Inc.||Hybrid drive selectively spinning up disk when powered on|
|US9317209||Oct 31, 2014||Apr 19, 2016||Microsoft Technology Licensing, Llc||Using external memory devices to improve system performance|
|US9361183||Apr 22, 2014||Jun 7, 2016||Microsoft Technology Licensing, Llc||Aggregation of write traffic to a data store|
|US9448890||Jan 5, 2012||Sep 20, 2016||Microsoft Technology Licensing, Llc||Aggregation of write traffic to a data store|
|US9529716||Oct 18, 2013||Dec 27, 2016||Microsoft Technology Licensing, Llc||Optimizing write and wear performance for a memory|
|US9690496||Mar 24, 2016||Jun 27, 2017||Microsoft Technology Licensing, Llc||Using external memory devices to improve system performance|
|US20030046493 *||Aug 31, 2001||Mar 6, 2003||Coulson Richard L.||Hardware updated metadata for non-volatile mass storage cache|
|US20030074524 *||Oct 16, 2001||Apr 17, 2003||Intel Corporation||Mass storage caching processes for power reduction|
|US20030188123 *||Apr 1, 2002||Oct 2, 2003||Royer Robert J.||Method and apparatus to generate cache data|
|US20040181656 *||Mar 10, 2003||Sep 16, 2004||Dell Products L.P.||System and method for testing memory during boot operation idle periods|
|US20050204095 *||Mar 11, 2004||Sep 15, 2005||International Business Machines Corporation||System and method to reduce disk access time during predictable loading sequences|
|US20050289335 *||Jun 24, 2005||Dec 29, 2005||Sony Corporation||Boot system, boot method, and data processing apparatus using the boot method|
|US20060064684 *||Sep 22, 2004||Mar 23, 2006||Royer Robert J Jr||Method, apparatus and system to accelerate launch performance through automated application pinning|
|US20070038850 *||Aug 10, 2005||Feb 15, 2007||Matthews Jeanna N||System boot and resume time reduction method|
|US20070067679 *||Sep 22, 2005||Mar 22, 2007||Advanced Micro Devices, Inc.||Boot performance optimization for hard drive for personal internet communicator|
|US20080162821 *||Dec 27, 2006||Jul 3, 2008||Duran Louis A||Hard disk caching with automated discovery of cacheable files|
|US20090249055 *||Mar 27, 2009||Oct 1, 2009||Lenovo (Singapore) Pte. Ltd.||System and methods for booting electronic devices|
|US20100017591 *||Sep 25, 2009||Jan 21, 2010||Mike Smith||Method for booting an operating system|
|US20100017653 *||Jul 16, 2008||Jan 21, 2010||Naama Parush-Shear-Yashuv||Reference state information generation|
|US20100082936 *||Oct 1, 2008||Apr 1, 2010||Hobbet Jeffrey R||Cache Mapping for Solid State Drives|
|US20110225412 *||May 24, 2011||Sep 15, 2011||Van De Ven Adriaan||Booting an operating system of a system using a read ahead technique|
|US20110231643 *||Jun 2, 2011||Sep 22, 2011||Fujitsu Limited||Information processing device, power supply control method and storage medium|
|US20120303942 *||May 25, 2011||Nov 29, 2012||Eric Peacock||Caching of boot data in a storage device|
|U.S. Classification||711/145, 711/E12.075, 713/1, 713/2, 711/118|
|International Classification||G06F9/445, G06F12/08, G06F12/12|
|Cooperative Classification||G06F9/4401, G06F12/0866, G06F12/126|
|European Classification||G06F9/44A, G06F12/12B6|
|Jun 27, 2001||AS||Assignment|
Owner name: INTEL CORPORATION, CALIFORNIA
Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:COULSON, RICHARD L.;GARNEY, JOHN I.;MATTHEWS, JEANNA N.;AND OTHERS;REEL/FRAME:011956/0235
Effective date: 20010622
|Jan 15, 2009||FPAY||Fee payment|
Year of fee payment: 4
|Feb 13, 2013||SULP||Surcharge for late payment|
Year of fee payment: 7
|Feb 13, 2013||FPAY||Fee payment|
Year of fee payment: 8
|Jan 5, 2017||FPAY||Fee payment|
Year of fee payment: 12