HK1166389B - Method and apparatus for quick resumption - Google Patents
Method and apparatus for quick resumption Download PDFInfo
- Publication number
- HK1166389B HK1166389B HK12106918.2A HK12106918A HK1166389B HK 1166389 B HK1166389 B HK 1166389B HK 12106918 A HK12106918 A HK 12106918A HK 1166389 B HK1166389 B HK 1166389B
- Authority
- HK
- Hong Kong
- Prior art keywords
- processing system
- resume
- stage
- volatile memory
- content
- Prior art date
Links
Description
The application is a divisional application of Chinese patent application with the application date of 8/3/2006 and the application number of 200680033757.4 entitled "method and device for quick recovery".
    Technical Field
      The present invention relates generally to the field of data processing, and more particularly to a method and related apparatus for expeditiously resuming a processing system from a hibernation state.
      
        Background
      
      Advanced Configuration and Power Interface (ACPI) is an open industry specification that describes industry standard interfaces for configuration and power management of processing systems such as laptop, desktop, and server computers. Version 3.0 of the ACPI specification, dated 9/2 of 2004, is available from www.acpi.info/spec. The ACPI specification describes various sleep states and global power states. However, the present invention is not limited to ACPI compliant systems, but may be advantageously used in any suitable processing system.
      For purposes of this disclosure, a processing system may be in one of three power states, active, dormant, or off. The sleep state may also be referred to as a sleep state or a sleep mode.
      In the off state, the system is powered down and no system context is included in the system for restoring processes from an earlier active state. To transition from the off state to the active state, the boot firmware must initialize the hardware and boot the OS.
      In the active state, the system schedules and executes threads. Systems typically respond to external events in substantially real time-the response may suffer from delays due to factors such as the workload and performance limits of the processing system. However, various performance and power characteristics of the system may be dynamically adjusted within the active state. For example, the power state of various devices within the system may be dynamically changed while the processing system is in an active state. The active state may also be referred to as an active mode.
      When in the sleep state, the processing system does not execute user mode threads and the system consumes less power than the active state. The system appears to be off because various external devices or indicators (e.g., a display, certain Light Emitting Diodes (LEDs), etc.) may be powered down. In some cases, the processing system may consume no power or substantially no power in the sleep state. However, in the sleep state, the processing system saves data (i.e., system context) related to processes executing in the active state. A processing system typically transitions from a sleep state to an active state faster than from an off state to an active state. For example, in some implementations, a processing system may transition from a sleep state to an active state without rebooting the Operating System (OS).
      Resume is the transition from the dormant state to the active state.
      Conventional processing systems may take over 60 seconds for recovery. For example, a processing system with 3.4 Gigabytes (GB) of Random Access Memory (RAM) may take approximately 150 seconds to transition from a sleep mode without power to an active mode. A large portion of this time may be dedicated to restoring the system context from the hard drive to RAM. As the amount of memory in a typical processing system increases, the amount of time required to restore the typical processing system also increases. If a person desires to use a processing system, he is typically neither fun nor valuable to wait for the processing system to recover. As the present invention indicates, it is advantageous to reduce the amount of time required to restore a processing system.
    
      Brief Description of Drawings
    
    Features and advantages of the present invention will become apparent from the appended claims, the following detailed description of one or more example embodiments, and the corresponding figures, in which:
    FIG. 1 is a block diagram depicting a suitable data processing environment in which certain aspects of an example embodiment of the present invention may be implemented;
    FIG. 2 is a timeline illustrating when various operations for quickly resuming a data processing system may occur in accordance with an exemplary embodiment of the present invention;
    FIG. 3 is a block diagram depicting various data constructs that may be used to support fast recovery of a processing system in accordance with an example embodiment of the present invention; and
    fig. 4, 5 and 6 are flow diagrams describing aspects of a process for supporting fast recovery according to an example embodiment of the present invention.
    
      Detailed Description
    
    FIG. 1 is a block diagram depicting a suitable data processing environment 12 in which certain aspects of an example embodiment of the present invention may be implemented. The data processing environment 12 includes a processing system 20, the processing system 20 including various hardware components 80 and software components 82. The hardware components may include, for example, one or more processors or Central Processing Units (CPUs) 22 communicatively coupled to various other components via one or more system buses 24 or other communication paths or media.
    As used herein, the terms "processing system" and "data processing system" (DPS) are intended to broadly encompass a single machine, or a system of communicatively coupled machines or devices operating in concert. Example processing systems include, but are not limited to, distributed computing systems, supercomputers, high-performance computing systems, computing clusters, mainframe computers, minicomputers, client-server systems, Personal Computers (PCs), workstations, servers, portable computers, laptop computers, tablet computers, Personal Digital Assistants (PDAs), telephones, handheld devices, entertainment devices such as audio and/or video devices, and other devices for processing or transmitting information.
    Processing system 20 may be controlled, at least in part, by input from conventional input devices, such as a keyboard, and a pointing device such as a mouse. Processing system 20 may also be responsive to indications received from other processing systems or other input sources or signals. Processing system 20 may utilize one or more connections to one or more remote data processing systems 70, such as through a Network Interface Controller (NIC)32, a modem, or other communication ports or couplings. The processing systems may be interconnected by a physical and/or logical network 72, such as a Local Area Network (LAN), Wide Area Network (WAN), intranet, and the Internet. The communications-related network 72 may utilize various wired and/or wireless short-range or long-range carriers and protocols, including Radio Frequency (RF), satellite, microwave, Institute of Electrical and Electronics Engineers (IEEE)802.11, 802.16, 802.20, bluetooth, optical, infrared, cable, laser, and the like.
    In processing system 20, processor 22 is communicatively coupled to one or more volatile or non-volatile data storage devices, such as Random Access Memory (RAM)26, flash memory 26, mass storage devices 28, such as Integrated Drive Electronics (IDE) or Small Computer System Interface (SCSI) hard drives, and/or other devices or media, such as floppy disks, optical storage, tapes, Read Only Memories (ROMs), memory sticks, digital video disks, biological storage, etc. For purposes of this disclosure, the term "ROM" may be used to generally refer to non-volatile storage devices such as erasable programmable ROM (eprom), electrically erasable programmable ROM (eeprom), flash ROM, flash memory, and the like. The processor 22 may also be communicatively coupled to other components such as a video controller, a SCSI controller, a network controller, a Universal Serial Bus (USB) controller, input devices such as a keyboard, mouse, camera, etc. Processing system 22 may also include one or more bridges or hubs 34, such as a memory controller hub, an input/output (I/O) controller hub, a PCI root bridge, etc., for communicatively coupling system components. As used herein, the term "bus" includes a path that may be shared by more than two devices as well as a point-to-point path.
    For example, some components, such as the NIC32, may be implemented as an adapter card with an interface (e.g., a PCI connector) for communicating with a bus. Alternatively, the NIC32 and other devices may be implemented as embedded controllers using components such as programmable or non-programmable logic devices or arrays, Application Specific Integrated Circuits (ASICs), embedded computers, smart cards, and the like.
    The invention may be described herein with reference to or in conjunction with data such as instructions, functions, procedures, data structures, applications, configuration settings, etc. When data is accessed by a machine, the machine may respond by performing tasks, defining abstract data types or low-level hardware contexts, and/or performing other operations, as will be described in greater detail below. Data may be stored in volatile and/or nonvolatile data storage. For purposes of this disclosure, the term "program" is used generically to cover a wide range of software constructs, including applications, routines, modules, drivers, subroutines, processes, and other types of software components.
    For example, the data storage device 28 and/or the flash memory 26 may include multiple sets of instructions that, when executed, may perform various operations. These sets of instructions may be referred to generally as software.
    As shown in FIG. 1, in an example embodiment, programs or software components 82 may include system firmware 40 and OS 50. System firmware 40 may include one or more routines for managing the boot process, such as boot firmware 48. For purposes of this disclosure, the term "system firmware" includes boot firmware for the platform as well as any additional platform firmware that may operate upon invoking OS boot code. As described in more detail below, system firmware 40 and operating system 50 may include respective resume management routines 42 and 52 for enabling processing system 20 to quickly resume from a hibernate state to an active state.
    FIG. 2 is a timeline illustrating when various operations for quickly resuming a data processing system may occur according to an exemplary embodiment of the present invention. Still referring to FIG. 1, the timeline of FIG. 2 begins at time t0, at which point system 20 is in an active state. At time t1, OS50 may determine that processing system 20 should transition to sleep mode. This determination may be made in response to a condition such as a predetermined time of inactivity, a user input selecting a sleep mode, or the like.
    At time t2, OS50 saves the current system context to non-volatile storage and creates a resume descriptor, which will be saved in non-volatile storage and used in subsequent operations to quickly resume processing system 20. As described in detail below, the system context may be saved in two or more portions, and the resume descriptor may include data to be used by OS50 when resuming processing system 20. The resume descriptor may also include data to be used by system firmware 40 when resuming processing system 20.
    For example, the OS50 may populate the resume descriptor with various different sets of content that identify different stages in the resume process. These phases may include a first phase for restoring the system context of only a subset of the processes active at time t1, and a second phase (or phases) for restoring the system context of the remaining processes active at time t 1.
    FIG. 3 is a block diagram depicting various data constructs that may be used to support fast recovery of a processing system in accordance with an example embodiment of the present invention. In particular, FIG. 3 depicts hard disk 28 of processing system 20 with its various partitions (e.g., partitions p1 and p2) containing data (e.g., system context) to be used to restore processing system 20. This content may be referred to as a restore file 98. In an example embodiment, restore file 98 includes first stage content 94 and second stage content 96, which are to be loaded in successive first and stage loading steps, respectively, during a restore of processing system 20. As described in more detail below, in another embodiment, the first stage content and the second stage content may be stored in different storage devices. However, for the sake of simplicity, the term "restore file" as used herein includes any collection of restore data, even if all portions of the collection do not reside in the same physical file, or even on the same storage device. The hard disk 28 may also include a partition table 46 with pointers to partitions such as p1, p2, and other data.
    FIG. 3 also depicts system firmware 40 residing in flash memory 26 with a resume descriptor 92 as a firmware variable and saved in flash memory along with other firmware variables 90 (e.g., a firmware variable identifying a language for a user interface, a firmware variable specifying a primary or secondary boot device, etc.). In certain embodiments, the system firmware for processing system 20 complies with the Extensible Firmware Interface (EFI) specification, version 1.10, (hereinafter "the EFI specification") on a date of 11/26/2003. The EFI specification is available from www.intel.com/technology/EFI. In these embodiments, resume descriptor 92 may be similar to a firmware construct such as an EFI configuration table. In some embodiments, the structure of the resume descriptor is predefined by the system firmware. In other embodiments, the OS uses system firmware to create the resume descriptor.
    In addition to firmware variables, other data may be stored in flash memory 26, such as code image 44 for system firmware 40. In alternative embodiments, the resume descriptor may be stored in any suitable predetermined non-volatile location (e.g., in a file residing on a system partition of a hard disk drive). Similarly, the resume descriptor is not limited to the specific structure shown herein, but in alternative embodiments any suitable data structure or combination of data structures stored in any suitable non-volatile storage device may be used in accordance with the present invention. Alternate embodiments may also use a single data structure to hold both the resume descriptor and the first stage content.
    Turning now to the timeline shown in FIG. 2, in this example embodiment, after creating resume descriptor 92, OS50 causes processing system 20 to flush RAM26 at time t3 to ensure that the current context is properly saved. Then, at time t4, OS50 partially or completely powers down processing system 20. Thus, processing system 20 enters the sleep state at time t 4. Processing system 20 then remains in the sleep state for an indefinite period of time, from a few seconds to months or years.
    At time t5, processing system 20 detects a start event, for example, in response to a user pressing a power button of processing system 20. System firmware 40 then retrieves resume descriptor 92 and determines how to respond to the start event based at least in part on the information OS50 saved in resume descriptor 92. For example, resume descriptor 92 may include data that instructs system firmware 40 to skip initialization of one or more specified devices, to initialize only certain portions of RAM26, and so on. The data in resume descriptor 92 that indicates which resume operations should be performed by the OS may be referred to as a resume descriptor handshake. In embodiments, the resume descriptor handshake may assign any operation or combination of operations to the OS that need not be performed prior to performing the first stage load. System firmware 40 may then initialize processing system 20 based on the data in resume descriptor 92, and system firmware 40 may then pass control to the boot code of OS 50.
    Processing system 20 may therefore shorten the firmware controlled initialization process to achieve a faster return to the OS context. Initialization operations may be offloaded from system firmware 40 to OS50 via a handshake or contract communicated through a predetermined conduit, such as a firmware variable or some other communication path.
    At time t6, OS50 may retrieve resume descriptor 92 and initiate the first phase loading process for restoring the partial context from the previous active state. In an example embodiment, during the first stage loading, OS50 loads first stage content 94 from hard disk 28 into RAM26, and first stage content 94 includes context for only a subset of processes that were present in processing system 20 when the processing system was last in an active state. For example, the first stage content 94 may include context data only for the last active user program (e.g., the last program that received user input or had system focus). The first stage data may include all paged and non-paged data for the last active user program, or only non-paged data.
    In another embodiment, first stage content 94 may include context data for all programs that did not page out of memory when processing system 20 was last active. In alternative embodiments, other subsets of the system context may be saved in the first stage content and restored in the first stage loading. For example, the first stage data may include all non-paged OS data in addition to any of the subsets described above. Non-paged OS data may also be referred to as non-paged kernel data.
    Alternatively, the first stage content 94 may be saved to flash memory 26. The OS50 can therefore restore the first stage content 94 from the flash memory 26 to the RAM 26. In addition, OS50 may populate resume descriptor 92 with data indicating that system firmware 40 should skip initialization steps that are typically performed to support communication with hard disk 28. The OS50 may perform these initialization steps after the first stage loading is complete.
    As indicated at time t7, once the first phase loading process is complete, the processing system generates a user interface and is ready to receive input from a user and execute a user mode thread. For example, processing system 20 may prompt the user for credentials and, after receiving and verifying these credentials, processing system 20 may provide a user interface for the last application used by the user before processing system 20 entered sleep mode.
    In fig. 2, the time between t5 and t7 is labeled as duration d 1. Thus, in the exemplary embodiment, duration d1 is the amount of time required for processing system 20 to resume from a sleep mode without power.
    The OS50 may then initiate a second phase loading of the platform context, for example, as a background task. In an example embodiment, the first stage content is less than the second stage content, and the first stage loading takes less time than the second stage loading.
    At time t8, processing system 20 may complete the second phase load and may then complete the recovery process. The time between t7 and t8 is labeled as duration d2, and the time between t5 and t8 is labeled as duration d 3. Duration d3 is therefore equal to duration d1 plus duration d 2. In the exemplary embodiment, processing system 20 is ready for use after duration d 1. Conversely, the duration d3 (i.e., the total time between t5 and t 8) may be similar to the amount of time required to transition the processing system from sleep mode to active mode according to conventional resume procedures. However, processing systems that are restored using conventional methods are not available until all of the system context has been loaded. In contrast, according to an example embodiment, a person using processing system 20 need not wait a long time before he or she begins to use processing system 20 for valuable work because context is restored in multiple stages and the processing system does not have to wait for all of these stages to be completed before generating a user interface.
    Fig. 4, 5 and 6 are flow diagrams describing aspects of a process for supporting fast recovery according to an example embodiment of the present invention. The process depicted in FIG. 4 begins with processing system 20 detecting a start event, for example, as described above with respect to FIG. 2 and time t 5. In response to the start event, boot firmware 48 begins initializing processing system 20, as depicted at block 110. As part of this initialization process, system firmware 40 determines whether processing system 20 is resuming from a hibernation state, as depicted at block 112. If processing system 20 has not resumed from the hibernate state, system firmware 40 completes initialization of processing system 20 using a hard-boot or cold-boot process (i.e., a process that transitions from an off state to an active state), as indicated at block 114. As depicted at block 144, system firmware 40 may then pass control to OS50 for the remainder of the boot process.
    However, if processing system 20 is resuming from a sleep state, system firmware 40 then determines whether the processing system is resuming from a powered sleep state or a non-powered sleep state, as depicted in block 120. If processing system 20 is resuming from a power-on sleep state, system firmware 40 may resume from power-on sleep more or less in a conventional manner to complete initialization of processing system 20, as indicated at block 122. System firmware 40 may then pass control to OS50 for the remainder of the boot process, as depicted in block 144.
    However, if processing system 20 is resuming from a non-powered sleep state, system firmware 40 may determine whether OS50 saved the resume descriptor in preparation for entering the sleep state, as indicated at block 130. If system firmware 40 does not find a resume descriptor, system firmware 40 may raise an exception and/or may perform error handling, as depicted at block 132. For example, system firmware 40 may perform operations such as providing an output to notify a user or remote administrator of the error, saving a log entry identifying the error, returning to a hard or cold boot process, or any suitable combination of these or other operations.
    If a resume descriptor exists, system firmware 40 reads the resume descriptor (e.g., resume descriptor 92), as depicted at block 140. As indicated at block 142 and as described above, system firmware 40 may then complete its initialization process portion based on the information saved in resume descriptor 92 by OS 50. For example, if resume descriptor 92 indicates that OS50 is to initialize some device or portion of memory, system firmware 40 may save time by not initializing that device or portion of memory. In one embodiment, resume descriptor 92 lists initialization operations to be performed by components other than system firmware 40. In other embodiments, resume descriptor 92 uses other techniques to indicate which initialization operations are to be performed by system firmware 40. In either case, the resume descriptor 92 may describe the shortest path for platform initialization to support fast resume of the first stage content. As indicated at block 144, system firmware 40 may then pass control to boot code of OS50 after performing any required initialization operations.
    The process described in fig. 5 begins after system firmware 40 has detected a start event. At block 210, system firmware 40 may perform system initialization according to the process described in FIG. 4. At block 212, OS50 may receive control from system firmware 40, in accordance with the operations indicated at block 144 of FIG. 4. At block 214, the OS50 may retrieve the resume descriptor 92 from non-volatile storage. For example, in an example embodiment, OS50 retrieves resume descriptor 92 from a permanent firmware variable (i.e., a variable provided by system firmware that can be subsequently retrieved from the system firmware, even when the system is powered down between the time the variable is saved and the time the variable is retrieved).
    OS50 may then determine whether processing system 20 is resuming from a hibernate state, as depicted at block 220. If processing system 20 has not resumed from the hibernate state, OS50 may perform a hard boot or a cold boot, as indicated at block 222. If processing system 20 is resuming from a hibernation state, as depicted at block 222, OS50 may determine whether processing system 20 is resuming from a powered-on hibernation state or a non-powered-off hibernation state, as depicted at block 230. If processing system 20 is resuming from a powered sleep state, OS50 may perform a more or less conventional powered resume, as indicated at block 232.
    However, if processing system 20 is resuming from a non-powered sleep state, the process may proceed from block 230 to block 234, which depicts OS50 causing processing system 20 to perform a first stage of context loading. In some embodiments, the data processing system may perform a two-stage (or multi-stage) loading process in response to detecting the resume descriptor. Referring again to FIG. 3, in an example embodiment, when performing the first stage loading, the OS50 may load the first stage content 94 from non-volatile storage, such as the hard disk 28, to the RAM 26. As explained above, first stage content 94 may include the system context of the last program that received the user input, the last program that has system focus, all programs that did not come out of a page of memory, or some other subset of programs that existed in processing system 20 before processing system 20 entered sleep mode.
    As indicated by the dual path from block 234, after loading the first stage content, OS50 may begin the second stage loading operation while also providing a user interface to allow processing system 20 to be used before the second stage loading is complete. For example, as indicated at block 236, after loading the first stage content 94, the OS50 may begin executing user mode threads, e.g., presenting an interface to a user. If the first stage content includes the context of the last program that received the user input, OS50 may return control to the program after restoring the context for the program, thereby enabling the user to resume use of the program as if processing system 20 had never transitioned to sleep mode. Further, as indicated at block 238, processing system 20 may then receive input, such as user input. Processing system 20 then provides for user interaction before the secondary loading process is complete. Thus, one may use processing system 20 before the entire system context (i.e., the context data for all processes or programs that existed before processing system 20 entered sleep mode) is restored.
    As indicated at blocks 240 and 242, while or substantially while providing the user interface and accepting the user interaction, the OS50 may perform any further initialization operations as needed and may load the second stage content 96. These initialization operations may be the responsibilities assigned to the OS by resume descriptor 92. For example, resume descriptor 92 may include data indicating that OS50 should initialize one or more specified portions of RAM 26. The data in resume descriptor 92 that indicates which resume operations should be performed by the OS and which by the system firmware may be referred to as a resume descriptor handshake. In various embodiments, the resume descriptor handshake may assign any operation or combination of operations to the OS that need not be performed prior to performing the first stage load. Other examples of such operations may include, but are not limited to, initialization of one or more specified devices, and the like.
    The secondary load process may restore some or all of the remaining system context (e.g., the second stage content 96 from the restore file 98) to RAM 26. The recovery process may end when all of the second stage content has been recovered. In an alternative embodiment, multiple secondary or supplemental stages may be used to load the additional content after the first stage is loaded.
    Once the system has completed hard booting, has completed waking from a powered sleep state or has completed waking from a non-powered sleep state, the process may proceed from FIG. 5 through page connector A to block 250 of FIG. 6. Processing system 20 may then determine whether there is a power state transition request to enter the unpowered sleep state. This determination may be made, for example, in response to a user selecting a sleep option or in response to a predetermined amount of time passing without user input.
    When processing system 20 determines that a non-powered sleep mode should be entered, OS50 may cause the processing system to flush a paged pool of kernel data to non-volatile storage, such as hard disk 28, as indicated at block 252. The flush operation may ensure that all write-back disk caches have been flushed. As indicated at block 254, the OS50 may also copy non-paged data (or any other suitable subset of the current context) into the same or a different non-volatile device.
    In one embodiment, OS50 may treat all of the paged data as second stage content, and OS50 may save the data to hard disk 28. On the other hand, all non-paged data may be considered first stage content and OS50 may save the data to flash memory 26. In other embodiments, the processing system may include three or more different non-volatile storage devices, and items such as resume descriptors, first stage content, and second stage content may be stored on different devices, respectively. Any suitable method may be used to store the second stage content. For example, the OS50 may create a log in the second stage content 96 to identify the existing location of the paginated data or the OS50 may incorporate the paginated content into the second stage content 96.
    In an example embodiment, as shown in block 256, OS50 populates resume descriptor 92 with information to be used to resume processing system 20 and saves resume descriptor 92. For example, the OS50 may store information in resume descriptor 92 such as one or more of the following:
    data describing initialization operations that the OS50 will perform, which may include operations that boot firmware typically performs before booting the OS in conventional systems.
    Data describing the attributes of the content loaded in the first stage, such as the location of the content, the size of the content, the type of device containing the content, etc.
    Information used by system firmware 40 when system firmware 40 passes control to OS50 during a resume operation, e.g., as described in block 212 of fig. 5.
    In some embodiments, the OS may use a device provided by the system firmware to save the resume descriptor in non-volatile storage. For example, as described above, the resume descriptor data may be saved in a firmware variable (e.g., variable 92 as described in FIG. 3).
    Some embodiments may use structures similar to those described in the code fragments below to implement the resume descriptor.
    This resume descriptor may have an INIT _ MASK portion for locating the first stage content. For example, the INIT _ MASK portion may store data identifying: (a) whether the first stage content is stored in a flash memory; (b) device paths for devices containing first stage content (e.g., away bus #1, Peripheral Component Interconnect (PCI) device 7, function O, partition O); (c) the number of different memory ranges/fragments to be restored, etc. The RESOURCE DESCRIPTOR section may be used to store data identifying: (a) the type of device containing the first stage content (e.g., hard drive, flash, etc.); (b) the starting location of the first stage content on the device (e.g., byte offset of the flash memory device or LBA of the associated sector of the hard drive); (c) the size of the first stage content, etc. Other information in the resume descriptor may include data identifying different areas of data to be resumed (e.g., memory ranging from 1: 22MB, memory ranging from 40: 32MB, etc.). In other embodiments, resume descriptors having different structures may be employed.
    When transitioning from sleep mode to active mode, system firmware 40 may use the information in the resume descriptor indicating which memory regions are to be resumed to determine which memory regions are to be initialized by system firmware 40 before booting to OS 50. For example, system firmware 40 may initialize a memory region to be restored and may skip initialization of other memory regions. Because system firmware 40 may only initialize a subset of RAM26, boot firmware may complete its initialization process more quickly.
    Resume descriptor 92 may include additional structure to store information identifying which initialization operations are to be skipped by system firmware 40 and performed by OS 50. For example, the INIT MASK structure may include one or more bits to indicate whether system firmware 40 is to initialize all of memory or a subset of memory, data to indicate whether certain devices are to be initialized by system firmware 40 or OS50, and so on. In alternative embodiments, an alternative mechanism may be used to indicate which initialization operations are to be skipped by the system firmware and performed by the OS.
    At block 258, OS50 causes the contents of RAM26 to be refreshed to restore file 98. This refresh is to ensure that the memory contents of volatile components (e.g., memory, cache, CPU state) are completely refreshed to non-volatile storage. In an example embodiment, the first stage content 94 (see FIG. 3) includes kernel data flushed to disk according to block 252, and the second stage content 96 includes data flushed to the restore file 98 according to block 258. Likewise, portions of the non-paged data referenced at block 254 may be saved to the first stage content 94, while the remainder may be saved to the second stage content 96. For example, first stage content 94 may obtain relevant non-paged data from the OS and the application with focus, while the remaining non-paged data may enter second stage content 96.
    The OS50 may then cause the processing system 50 to self-power down, as indicated by block 260. The process of fig. 4-6 may be repeated as needed, for example, beginning at block 110 when processing system 20 begins its next initialization process.
    Thus, in accordance with the above description, embodiments of the present invention may enable a processing system to be restarted from a non-powered sleep state much faster than a processing system employing conventional resume techniques. For example, referring again to FIG. 2, in contrast to conventional systems that may enter active mode only after duration d3, a system according to the present disclosure may enter active mode and begin executing user mode threads after duration d 1. For example, a processing system with 3.4GB RAM has been designed that can complete a first stage load in less than 4 seconds to restore to a usable state based on 16 Megabytes (MB) per second flash memory containing 54.5MB of first stage content consisting of 22.4MB of context data for the last active application and 32MB of context data for the non-paged core contexts.
    Further, because a processing system may transition from a non-powered sleep state to an active state very quickly in accordance with the present disclosure, a user, vendor, or system administrator may configure the processing system to employ the non-powered sleep mode in situations where a powered sleep mode may be required in conventional systems. The processing system may even be designed to support (or be configured to employ) only the non-powered sleep mode. For example, embodiments of the invention may cause a processing system to resume from a non-powered sleep mode as quickly as from a powered sleep mode. Of course, non-powered sleep modes require little or no power to save state, while powered sleep modes require significant power to save state. Thus, a processing system that employs unpowered sleep modes instead of one or more powered sleep modes may conserve a significant amount of power relative to conventional systems. This power saving may translate into other advantages such as an extension of the battery powered system active standby power duration.
    Further, because the handshake mechanism allows the OS to communicate with the system firmware in a non-powered sleep state, the OS may dynamically adjust or reassign tasks or responsibilities between the firmware and the OS to achieve improved performance. For example, the OS may accept responsibility for initializing certain system storage, certain system devices, and the like.
    In view of the principles and example embodiments described and illustrated herein, it will be recognized that the described embodiments can be modified in arrangement and detail without departing from such principles. For example, while one embodiment has been described above as employing a hard disk and flash memory as non-volatile storage, alternative embodiments may employ only a hard disk, flash memory, some other type of non-volatile storage, or any suitable combination of non-volatile storage technologies.
    Also, while the above discussion has focused on particular embodiments, other configurations are also contemplated. Even though expressions such as "in one embodiment," "in another embodiment," etc. are used herein, these phrases are indicative of the possibility of referring to the embodiments generally, and are not intended to limit the invention to particular embodiment configurations. As used herein, these terms may reference the same or different embodiments that are combinable into other embodiments.
    Similarly, although the example processes have been described with reference to particular operations being performed in a particular order, numerous modifications may be applied to the processes to derive numerous alternative embodiments of the present invention. For example, alternative embodiments may include processes that employ fewer than all of the disclosed operations, processes that employ additional operations, processes that employ the same operations but in a different order, and processes in which the individual operations disclosed herein are combined, sub-divided, or otherwise altered.
    Selected embodiments of the invention also include machine-accessible media encoding instructions for performing the operations of the invention. Such embodiments may also be referred to as program products. Such machine-accessible media may include, but are not limited to, storage media such as floppy disks, hard disks, CD-ROMs, and RAMs; and electrical devices such as antennas, wires, optical fibers, microwaves, radio waves, and other electromagnetic or optical carriers. Thus, instructions or other data may be sent in the form of packets, serial data, parallel data, propagated signals, etc., over a transmission environment or network, and may be used in a distributed environment and stored locally and/or remotely for access by single or multi-processor machines.
    It should also be understood that the hardware and software components described herein represent functional elements that are suitably autonomous, such that each element may be designed, constructed, or updated substantially independently of the other elements. In alternative embodiments, many of the components may be implemented as hardware, software, or combinations of hardware and software for providing the functionality described and illustrated herein. The hardware, software, or combination of hardware and software for performing the operations of the invention may also be referred to as logic or control logic.
    In view of the wide variety of useful permutations that may be readily derived from the example embodiments described herein, this detailed description is intended to be illustrative only and should not be taken as limiting the invention. What is claimed as the invention, therefore, is all implementations that come within the scope and spirit of the following claims and equivalents to such implementations.
  Claims (13)
1. A method for fast recovery, comprising:
      loading first stage resume content and second stage resume content into a volatile memory of a processing system when transitioning the processing system from a sleep mode to an active mode;
      wherein the first stage resume content comprises context data of a first program in use before the processing system transitions to the sleep mode; and
      wherein the second stage resume content comprises context data of another program in use before the processing system transitions to the sleep mode;
      enabling the processing system to receive input of the first program before all of the second stage restore content has been loaded into the volatile memory;
      retrieving a resume descriptor when transitioning the processing system from the sleep mode to the active mode; and
      determining, based at least in part on the resume descriptor, an initialization operation to be performed by an Operating System (OS) in the processing system,
      wherein the resume descriptor assigns to the OS an operation or combination of operations that need not be performed before the first phase of loading is performed.
    2. The method of claim 1, wherein:
      the first stage restore content includes sufficient context data to allow the processing system to receive the input of the first program before all of the second stage restore content has been loaded to the volatile memory.
    3. The method of claim 1, wherein the operation of determining an initialization operation to be performed by an OS in the processing system based at least in part on the resume descriptor comprises:
      determining that the OS is assigned to perform at least one initialization operation from the group consisting of:
      initializing at least a portion of a volatile memory of the processing system; and
      initializing a device in the processing system.
    4. The method of claim 1, wherein the operation of retrieving the resume descriptor comprises retrieving the resume descriptor from a non-volatile memory.
    5. The method of claim 1, wherein the resume descriptor includes information about the first stage resume content.
    6. The method of claim 1, further comprising:
      saving the resume descriptor to non-volatile memory in preparation for transitioning the processing system from the active mode to the sleep mode.
    7. The method of claim 1, further comprising:
      in preparation for transitioning the processing system from the active mode to the sleep mode, a firmware variable is utilized to save the resume descriptor to non-volatile memory.
    8. The method of claim 1, further comprising:
      in preparation for transitioning the processing system from the active mode to the sleep mode, saving the resume descriptor to non-volatile memory, saving the first stage resume content to non-volatile memory, and saving the second stage resume content to non-volatile memory.
    9. An apparatus for fast recovery, comprising:
      means for loading first stage resume content and second stage resume content into volatile memory of a processing system when transitioning the processing system from a sleep mode to an active mode, wherein the first stage resume content comprises context data of a first program in use before the processing system transitioned to the sleep mode, and wherein the second stage resume content comprises context data of another program in use before the processing system transitioned to the sleep mode;
      means for receiving input of the first program before all of the second stage restore content has been loaded to the volatile memory;
      means for retrieving a resume descriptor when transitioning the processing system from the sleep mode to the active mode; and
      means for determining an initialization operation to be performed by an Operating System (OS) in the processing system based at least in part on the resume descriptor,
      wherein the resume descriptor assigns to the OS an operation or combination of operations that need not be performed before the first phase of loading is performed.
    10. The apparatus of claim 9, wherein the means for determining an initialization operation to be performed by an OS in the processing system based at least in part on the resume descriptor comprises:
      means for determining that the OS is assigned to perform at least one initialization operation from the group consisting of:
      means for initializing at least a portion of a volatile memory of the processing system; and
      means for initializing a device in the processing system.
    11. The apparatus of claim 9, further comprising:
      means for saving the resume descriptor to non-volatile memory in preparation for transitioning the processing system from the active mode to the sleep mode.
    12. The apparatus of claim 9, further comprising:
      means for utilizing a firmware variable to save the resume descriptor to non-volatile memory in preparation for transitioning the processing system from the active mode to the sleep mode.
    13. The apparatus of claim 9, further comprising:
      in preparation for transitioning the processing system from the active mode to the sleep mode, means for saving the resume descriptor to non-volatile memory, means for saving the first stage resume content to non-volatile memory, and means for saving the second stage resume content to non-volatile memory.
    Applications Claiming Priority (2)
| Application Number | Priority Date | Filing Date | Title | 
|---|---|---|---|
| US11/229,126 | 2005-09-15 | ||
| US11/229,126 US7523323B2 (en) | 2005-09-15 | 2005-09-15 | Method and apparatus for quick resumption | 
Publications (2)
| Publication Number | Publication Date | 
|---|---|
| HK1166389A1 HK1166389A1 (en) | 2012-10-26 | 
| HK1166389B true HK1166389B (en) | 2015-12-11 | 
Family
ID=
Similar Documents
| Publication | Publication Date | Title | 
|---|---|---|
| EP1924909B1 (en) | Method and apparatus for quick resumption | |
| EP1983431A2 (en) | Method and apparatus for quickly changing the power state of a data processing system | |
| WO2007040792A1 (en) | Accelerated power state resumption with firmware assist | |
| US9501291B2 (en) | Method and system for providing hybrid-shutdown and fast startup processes | |
| US7437575B2 (en) | Low power mode for device power management | |
| US8301917B2 (en) | Method and apparatus for managing power from a sequestered partition of a processing system | |
| US7647509B2 (en) | Method and apparatus for managing power in a processing system with multiple partitions | |
| US7962734B2 (en) | Method of restarting a computer platform | |
| CN104850435A (en) | Power management controller and method | |
| US6895517B2 (en) | Method of synchronizing operation frequencies of CPU and system RAM in power management process | |
| US20190004818A1 (en) | Method of UEFI Shell for Supporting Power Saving Mode and Computer System thereof | |
| WO2021233363A1 (en) | Computing device and bios update method therefor, and medium | |
| US7600111B2 (en) | Method of restarting a computer platform | |
| US20080168264A1 (en) | Configuring a device for operation on a computing platform | |
| US20130179672A1 (en) | Computer and quick booting method thereof | |
| US20130275739A1 (en) | Electronic apparatus, method of controlling the same, and computer-readable recording medium | |
| US20070028080A1 (en) | Sleep state resume | |
| HK1166389B (en) | Method and apparatus for quick resumption | |
| US20150317181A1 (en) | Operating system switching method | |
| US20030145240A1 (en) | System, method and computer program product for selecting a power management mode in an information handling system |