HYPERVISOR CLOCK FREQUENCY TECHNIQUES
This disclosure generally relates to time and timer techniques that may be used to virtualize one or more virtual machines. In an example, a plurality of host machines may each have clocks that operate at pre-determined or known frequencies, such that it may be possible to easily migrate a virtual machine from one host machine to another host machine using an offset, thereby providing consistent time information to the virtual machine. In some examples, a scale factor or multiplier may also be used in order to achieve a consistent frequency. For example, a first host machine may have a clock operating at 1 GHz, while a second host machine may have a clock operating at 500 MHz. In such an example, a multiplier may be used to double the frequency of the second host machine to match the clock of the first host machine, thereby providing consistent time information.
Latest Microsoft Patents:
- SELECTIVE MEMORY RETRIEVAL FOR THE GENERATION OF PROMPTS FOR A GENERATIVE MODEL
- ENCODING AND RETRIEVAL OF SYNTHETIC MEMORIES FOR A GENERATIVE MODEL FROM A USER INTERACTION HISTORY INCLUDING MULTIPLE INTERACTION MODALITIES
- USING A SECURE ENCLAVE TO SATISFY RETENTION AND EXPUNGEMENT REQUIREMENTS WITH RESPECT TO PRIVATE DATA
- DEVICE FOR REPLACING INTRUSIVE OBJECT IN IMAGES
- EXTRACTING MEMORIES FROM A USER INTERACTION HISTORY
This application claims priority to U.S. Provisional Application No. 62/560,565, entitled “Hypervisor Clock and Timer Techniques,” filed on Sep. 19, 2017, the entire disclosure of which is hereby incorporated by reference in its entirety.
BACKGROUNDIn a virtualized environment, a guest operating system may rely on a clock and set timers during normal execution of the virtual machine. However, if the virtual machine is suspended and/or migrated between host machines, it may be difficult to ensure that a consistent execution environment is provided for the virtualized guest. For example, the clock on the new host machine may operate at a different frequency as compared to the old physical host, or timer states may not be preserved.
It is with respect to these and other general considerations that examples have been described. Also, although relatively specific problems have been discussed, it should be understood that the examples should not be limited to solving the specific problems identified in the background.
SUMMARYThis disclosure generally relates to time and timer techniques that may be used to virtualize one or more virtual machines. In order to ensure consistent time information and preserve timers when suspending and resuming a virtual machine, or when performing a live migration, a host machine (e.g., a hypervisor, hardware of the host machine, etc.) may provide a clock having a pre-specified or known frequency and may enable varying modes for setting timers.
A plurality of host machines may each have clocks that operate at pre-determined or known frequencies, such that it may be possible to easily migrate a virtual machine from one host machine to another host machine using an offset so as to provide consistent time information to the virtual machine. In some examples, a scale factor or multiplier may also be used in order to achieve a consistent frequency. For example, a first host machine may have a clock operating at 1 GHz, while a second host machine may have a clock operating at 500 MHz. In such an example, a multiplier may be used to double the frequency of the second host machine in order to match the clock of the first host machine so as to provide consistent time information to the virtual machine.
Further, it may be possible to save and restore a timer of a virtual machine while preserving timer information associated with the timer (e.g., an expiration time, whether the most recent expiration has been signaled, and the enable bit, etc.). For example, a first mode may enable restoring a timer based on a previously-existing enable bit, thereby retaining the state of the timer (e.g., whether the timer is programmed to fire and/or whether the most recent expiration has been signaled). By contrast, a second mode of setting a timer may automatically set the enable bit, thereby automatically enabling the timer to fire, as may be expected by a virtual machine when setting a timer.
This summary is provided to introduce a selection of concepts in a simplified form that are further described below in the Detailed Description. This summary is not intended to identify key features or essential features of the claimed subject matter, nor is it intended to be used to limit the scope of the claimed subject matter.
Non-limiting and non-exhaustive examples are described with reference to the following Figures.
In the following detailed description, references are made to the accompanying drawings that form a part hereof, and in which are shown by way of illustrations specific embodiments or examples. These aspects may be combined, other aspects may be utilized, and structural changes may be made without departing from the present disclosure. Examples may be practiced as methods, systems or devices. Accordingly, examples may take the form of a hardware implementation, an entirely software implementation, or an implementation combining software and hardware aspects. The following detailed description is therefore not to be taken in a limiting sense, and the scope of the present disclosure is defined by the appended claims and their equivalents.
In some examples, different host machines may each have clocks that operate at different frequencies. Accordingly, migrating a virtual machine between such host machines may involve performing complex computations in order to provide consistent time information to the virtual machine. As such, aspects disclosed herein relate to using pre-determined or known frequencies for various clocks, such that it may be possible to easily migrate a virtual machine from one host machine to another host machine using an offset so as to provide consistent time information to the virtual machine. In some examples, a scale factor or multiplier may also be used in order to achieve a consistent frequency.
As shown in
In an example, the clock 160 may have a pre-specified or known frequency. For example, the clock 160 may have a frequency of 1 GHz and a different host machine similar to the host machine 100 may also have a clock with a frequency of 1 GHz. As such, performing a live migration of the virtual machine 130 may be simplified as a result of the clocks having a similar frequency. By contrast, migrating the virtual machine 130 to a host machine 100 that does not have a clock with a similar frequency may require additional computations in order to adapt the clock to provide similar time information as the host machine 100. It will be appreciated that a similar frequency may be provided by a clock with the same frequency as the clock 160 (e.g., 1 GHz) or by a clock having a frequency that may be scaled (e.g., multiplied) to the frequency of the clock 160 (e.g., a 500 MHz clock may be multiplied by two to provide a 1 GHz clock). In another example, the clock 160 may be a clock for which a frequency may be specified, such that a consistent frequency may be requested from the clock 160. In some examples, the frequency of the clock 160 may vary (e.g., according to processor load, power constraints, etc.), such that the frequency may be scaled accordingly in order to provide a consistent frequency to the virtual machine 130. It will be appreciated that while example clock frequencies are described herein, any of a variety of frequencies may be used.
In the example shown in
In the example shown in
Once the hypervisor 120 is initialized, it may create one or more virtual machines 130. Each virtual machine 130 may emulate a computer system and, as such, may provide the functionality of a physical computing device. In some examples, the virtual machine 130 may include a privileged kernel 150 and a normal kernel 140.
The privileged kernel 150 may be configured to execute a secure operating system. As such, the privileged kernel 150 can run one or more secure programs that contain various secretes utilized by the virtual machine 130, the hypervisor 120, and/or the normal kernel 140. For example, the privileged kernel 150 may store various credentials, encryption keys and the like.
The normal kernel 140 may be configured to execute various “normal” programs and applications, such as, for example, word processing applications, browser applications, spreadsheet applications and so on. However, due to the less secure security configuration (e.g., when compared to the security configuration of the privileged kernel 150) of the normal kernel 140, the normal kernel 140 may not store any credentials, encryption keys, or other secrets that may be utilized by the virtual machine 130 and/or the hypervisor 120. As such, when various secrets are needed by the various applications running on the normal kernel 140, the normal kernel 140 may request those secrets from the privileged kernel 150. In another implementation, the normal kernel 140 may request that the privileged kernel 150 perform one or more actions, using one or more of the stored secrets, on behalf of the normal kernel 140 and/or one or more applications executing on the normal kernel.
In some instances and due to the hypervisor 120 executing both the privileged kernel 150 and the normal kernel 140, the hypervisor 120 may execute in a privileged context. The privileged context enables the hypervisor 120 to switch between the privileged kernel 150 and the normal kernel 140 and/or various user modes.
As the hypervisor 120 is responsible for various virtual machines 130 and each virtual machine's respective kernels, it is important that the hypervisor 120 be one of the most, if not the most secure component on the host machine 100. For example, if the hypervisor 120 is software, the hypervisor 120 may have the highest privilege level when compared to other software that may be executing on the host machine 100. In some cases, the hardware 110 provides the hypervisor 120 with privilege level architecture that enables the hypervisor 120 to run and to exert authority over every virtual machine 130 the hypervisor 120 creates. As will be explained in more detail below with respect to
In some examples, the hardware 110 may provide timer functionality, which may be used by the virtual machine 130 to set one or more timers. For example, the virtual machine 130 may set a timer for a specified time duration, which, when reached, may cause an interrupt to occur. As another example, the virtual machine 130 may set a recurring timer, such that the timer may fire periodically. However, in an example, the virtual machine 130 may be suspended before such the time duration has elapsed, such that the timer may not have fired (e.g., the timer may still be enabled). In another example, the virtual machine 130 may be suspended after the timer has fired, such that the timer may still be set but is no longer enabled. Thus, when suspending the virtual machine 130, it may be important to capture such timer information in order to be able to save and restore such information when the virtual machine 130 is suspended and resumed, respectively.
In an example, the hypervisor 120 may store one or more timers set by the virtual machine 130 while preserving various aspects of each timer. For example, the hypervisor 120 may store an expiration time, whether the most recent expiration has been signaled, and/or the enable bit for a timer. Thus, when resuming the virtual machine 130, the hypervisor 120 may set each timer at hardware 110, while retaining the stored aspects of each timer. As an example, the hypervisor 120 may set a timer while preserving the timer's enable bit, such that a timer that was enabled before suspending the virtual machine 130 may remain enabled, while a timer that was disabled before the virtual machine 130 was suspended may be disabled. As a result, timers that have already fired for the virtual machine 130 will be indicated as such by an appropriate enable bit (e.g., indicating that the timer is disabled), while timers that have yet to fire may be enabled as indicated by an appropriate enable bit. By contrast, when the virtual machine 130 sets a timer, the timer may be automatically enabled by the hardware 110, thereby causing the timer to automatically have the appropriate enable bit. As a result of the hardware 110 providing such varying modes that allow automatic and manual control over the enable bit for a timer, it may be possible to provide transparent auto-enabled timers for the virtual machine 130, while also allowing the hypervisor 120 to save and accurately restore timers.
In some cases, the software layer 260 may be responsible for certain aspects of the hardware 210. For example, the software layer 260 may be responsible for putting the host machine 200 in a sleep state, resuming programs or applications when the host machine 200 awakens from a sleep state and so on.
It is also possible that the software layer 260 has a higher privilege level than the hypervisor 220. In such cases, the hypervisor 220 should be configured to communicate directly with the software layer 260. That is, any communication between the software layer 260 and any of the other components (e.g., the privileged kernel 250, the normal kernel 240 etc.) of the host machine 200 should be routed or otherwise mediated through the hypervisor 220. For example, any communication that occurs between the normal kernel 240 and the software layer 260 should be handled by the hypervisor 220.
In some cases when the software layer 260 is present, it may be desirable for the hypervisor 220 to be able to turn off or deactivate the software layer 260. For example, once the hypervisor 220 has been initialized, the hypervisor 220 may be configured to turn off the software layer 260, suspend operations performed by the software layer 260, intercept commands provided by or sent to the software layer 260 and so on. In this way, the hypervisor 220 may have the highest privilege level within the host machine 200. As such, security features of the host machine 200 may be improved as the hypervisor 220 controls communications between the various components of the host machine 200. As will also be described below, the host machine 200 may be able to determine that the hypervisor 220 was securely launched thereby preventing any attacks that may be brought to the host machine 200.
Additionally, the hypervisor 320, and/or the hardware 310, may be able to create, run, and/or command another virtual machine (shown in
The hypervisor 2 360 may communicate with and run the privileged kernel 2 390 and the normal kernel 2 380 in a similar manner as described above. For example, the hypervisor 2 360 may run in a privileged context, which enables the hypervisor 2 360 to switch between the privileged kernel 2 390 and the normal kernel 2 380. The hypervisor 2 360 may believe that it is the only hypervisor in the host machine 300. However, the hypervisor 2 360 may be subject to and commanded by the hypervisor 320. That is, any communications between the hypervisor 2 360 and the hardware 310 may be passed through the hypervisor 320.
Although not shown in
Regardless of the configuration of the host machine 300, a clock provided by the hardware 310 may provide a pre-specified or known frequency (e.g., determined by a crystal, as part of a processor, etc.), which may be used to provide consistent virtualized time to the virtual machine 330. As a result, if the virtual machine 330 is migrated (e.g., suspended on the host machine 300 and resumed on a different host machine, as part of a live migration, etc.) from the host machine 300 to a different host machine, an offset and/or scaling factor may be determined for the clock of hardware 310, which may be used to configure a clock of the different host machine, such that the virtual machine 330 may continue to receive consistent virtualized time information. In some examples, the different host machine may also comprise a clock having a pre-specified or known frequency, such that only the offset is required to provide consistent time information. In other examples, a multiplier or scale factor may also be used. For example, the clock of the host machine 300 may have a frequency of 1 GHz, while the clock of the different host machine may have a frequency of 250 MHz, such that a multiplier of four may be used in addition to the offset. Thus, as compared to traditional techniques, which may require complicated computations in order to translate the clock of a host machine to match the expected time information of a virtual machine, it may be possible to provide consistent time information using only an offset and, in some examples, a scale factor.
Method 400 begins at operation 410, where an offset may be determined from a first execution environment. In an example, the execution environment may be an environment in which one or more virtual machines are executing, such as the host machine 100 in which the virtual machine 130 is executing, as described above with respect to
Flow then proceeds to operation 420, where a clock of a second execution environment may be prepared using the determined offset. In an example, the second execution environment may be a different host machine (e.g., in the case of a live migration, or resuming a suspended virtual machine on a different host machine) or may be the same host machine as provided the first execution environment (e.g., in the case of resuming a suspended virtual machine on the same host machine). In some examples, preparing the clock of the second execution environment may comprise configuring a hypervisor of the second execution environment based on the offset so as to provide consistent time information to the virtual machine from the clock of the second execution environment. In other examples, a scale factor or frequency may be used to adapt a clock of the second execution environment (e.g., either alone or in conjunction with the offset, as was described above) in order to provide a frequency similar to that of the first execution environment. For example, a clock may be configured to have the same frequency or may be scaled according to aspects disclosed herein.
Once the second execution environment has been prepared, flow proceeds to operation 430, where virtual machine execution may continue in the second execution environment. In an example, continuing execution may comprise completing a live migration of the virtual machine. In another example, execution may be continued by resuming the virtual machine in the second execution environment. As a result of applying the offset and, in some examples, the scale factor, to the second execution environment, the virtual machine may be able to obtain consistent time information from the clock of the second execution environment. Flow terminates at operation 430.
Method 450 begins at operation 460, where a time request may be generated at a virtual machine. In an example, the request may be generated to determine how much time has elapsed, to generate a timestamp, to provide a system timer, or to synchronize instruction execution, among other examples. The request may be provided to a hypervisor (e.g., hypervisor 120 in
At operation 470, time information may be received. In some cases, the time information may be determined based on an offset as described above. As compared to traditional techniques, determining the time information based on an offset may provide a simplified and more expedient method of providing virtualized time to a virtual machine (e.g., as compared to generating potentially inexact and/or drifting time information based on clock frequencies that may vary between host machines based on complex computations). In some examples, a multiplier may be used in order to scale a clock frequency to a pre-specified or known frequency, as was discussed above. Flow terminates at operation 470.
Method 500 begins at operation 510, where an indication may be received to suspend a virtual machine. In some examples, the indication may be received as a result of user input or in response to the occurrence of an event, among other reasons. In other examples, the indication may specify a virtual machine to suspend (e.g., based on a virtual machine identifier, a host system identifier, etc.). While method 500 is discussed with respect to suspending a virtual machine, it will be appreciated that similar techniques may be applied to performing a live migration, among other virtualization operations.
Flow progresses to operation 520, where a timer associated with the virtual machine may be accessed. In an example, the timer may be accessed by a hypervisor, such as hypervisor 120 in
At operation 530, the accessed timer may be stored and the virtual machine may be suspended, such that the accessed timer information may be stored as part of a saved state for the virtual machine or otherwise associated with the virtual machine. In some examples, the timer information may be stored using a data store, a local or remote storage device, or a database, among other storage. As discussed above, the timer information may comprise information relating to whether the timer has fired and/or whether the most recent expiration of the timer has been signaled. Flow terminates at operation 530.
Method 540 begins at operation 550, where an indication may be received to resume a virtual machine. In some examples, the indication may be received as a result of user input or in response to the occurrence of an event, among other reasons. In other examples, the indication may specify a virtual machine to resume (e.g., based on a virtual machine identifier, a host system identifier, etc.). While method 540 is discussed with respect to resuming a virtual machine, it will be appreciated that similar techniques may be applied to performing a live migration, among other virtualization operations.
Flow progresses to operation 560, where a stored timer associated with the virtual machine may be accessed. In an example, the stored timer may have been generated by performing one or more aspects of method 500 as was discussed above with respect to
Moving to operation 570, the timer information may be used to restore the stored timer. For example, restoring the timer may comprise instantiating a timer at a host machine based on the timer information, and indicating that the timer should not be auto-enabled. Rather, the timer may be restored based on the state of the stored enable bit, such that a timer that was enabled when the virtual machine was suspended remains enabled, while a timer that had already fired remains in a state that indicates to the virtual machine that the most recent expiration has been signaled. Other aspects of the timer may be similarly restored, such as the expiration time, whether the most recent expiration has been signaled, and/or whether the timer is a one-shot or periodic timer, etc. As a result, rather than requiring a hypervisor for the virtual machine to provide a synthetic timer that retains the state of a virtual machine's timer, it may be possible to restore the state of the timer by indicating that the timer should not be auto-enabled but should instead retain the enable bit as of when the virtual machine was suspended. Flow terminates at operation 570.
Method 580 begins at operation 585, where a request to set a timer may be received from a virtual machine. In some examples, the request may be received by hardware of a host machine from a virtual machine or from a hypervisor on behalf of a virtual machine. The request may comprise an indication of whether the timer is a one-shot timer or a periodic timer, as well as a timer interval or expiration time, among other information.
Moving to operation 590, a timer may be set based on the received request, wherein setting the timer may comprise automatically setting the enable bit for the timer to indicate that the timer is enabled but has not yet fired. By contrast, method 540 discussed above did not result in automatically setting the enable bit to indicate that the timer was enabled, given that the timer had a previous state by virtue of representing the state of a suspended virtual machine. However, in method 580, the virtual machine contemporaneously requests the timer to be set, such that automatically enabling the timer provides the expected behavior to the virtual machine. Thus, it may be possible to provide transparent auto-enabled timers for a virtual machine according to method 580, while also providing functionality to save and accurately restore timers according to method 540. Flow terminates at operation 590.
In a basic configuration, the computing device 600 may include at least one processing unit 610 and a system memory 615. Depending on the configuration and type of computing device 600, the system memory 615 may comprise, but is not limited to, volatile storage (e.g., random access memory), non-volatile storage (e.g., read-only memory), flash memory, or any combination of such memories. The system memory 615 may include an operating system 625 and one or more program modules 620 or components suitable for identifying various objects contained within captured images such as described herein.
The operating system 625, for example, may be suitable for controlling the operation of the computing device 600. Furthermore, examples of the disclosure may be practiced in conjunction with a graphics library, other operating systems, or any other application program and is not limited to any particular application or system. This basic configuration is illustrated in
The computing device 600 may have additional features or functionality. For example, the computing device 600 may also include additional data storage devices (removable and/or non-removable) such as, for example, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
As stated above, a number of program modules and data files may be stored in the system memory 615. While executing on the processing unit 610, the program modules 620 (e.g., a hypervisor 605) may perform processes including, but not limited to, the aspects, as described herein.
Furthermore, examples of the disclosure may be practiced in an electrical circuit comprising discrete electronic elements, packaged or integrated electronic chips containing logic gates, a circuit utilizing a microprocessor, or on a single chip containing electronic elements or microprocessors. For example, examples of the disclosure may be practiced via a system-on-a-chip (SOC) where each or many of the components illustrated in
When operating via an SOC, the functionality, described herein, with respect to the capability of client to switch protocols may be operated via application-specific logic integrated with other components of the computing device 600 on the single integrated circuit (chip). Examples of the disclosure may also be practiced using other technologies capable of performing logical operations such as, for example, AND, OR, and NOT, including but not limited to mechanical, optical, fluidic, and quantum technologies. In addition, examples of the disclosure may be practiced within a general purpose computer or in any other circuits or systems.
The computing device 600 may also have one or more input device(s) 645 such as a keyboard, a trackpad, a mouse, a pen, a sound or voice input device, a touch, force and/or swipe input device, etc. The output device(s) 650 such as a display, speakers, a printer, etc. may also be included. The aforementioned devices are examples and others may be used. The electronic device 600 may include one or more communication connections 655 allowing communications with other computing devices 660. Examples of suitable communication connections 655 include, but are not limited to, radio frequency (RF) transmitter, receiver, and/or transceiver circuitry; universal serial bus (USB), parallel, and/or serial ports.
The term computer-readable media as used herein may include computer storage media. Computer storage media may include volatile and nonvolatile, removable and non-removable media implemented in any method or technology for storage of information, such as computer readable instructions, data structures, or program modules.
The system memory 615, the removable storage device 635, and the non-removable storage device 640 are all computer storage media examples (e.g., memory storage). Computer storage media may include RAM, ROM, electrically erasable read-only memory (EEPROM), flash memory or other memory technology, CD-ROM, digital versatile disks (DVD) or other optical storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, or any other article of manufacture which can be used to store information and which can be accessed by the computing device 600. Any such computer storage media may be part of the computing device 600. Computer storage media does not include a carrier wave or other propagated or modulated data signal.
Communication media may be embodied by computer readable instructions, data structures, program modules, or other data in a modulated data signal, such as a carrier wave or other transport mechanism, and includes any information delivery media. The term “modulated data signal” may describe a signal that has one or more characteristics set or changed in such a manner as to encode information in the signal. By way of example, and not limitation, communication media may include wired media such as a wired network or direct-wired connection, and wireless media such as acoustic, radio frequency (RF), infrared, and other wireless media.
In a basic configuration, the mobile computing device 700 is a handheld computer having both input elements and output elements. The mobile computing device 700 typically includes a display 705 and one or more input buttons 710 that allow an individual to enter information into the mobile computing device 700. The display 705 of the mobile computing device 700 may also function as an input device (e.g., a display that accepts touch and/or force input).
If included, an optional side input element 715 allows further input. The side input element 715 may be a rotary switch, a button, or any other type of manual input element. In alternative aspects, mobile electronic device 700 may incorporate more or less input elements. For example, the display 705 may not be a touch screen in some examples. In yet another alternative embodiment, the mobile computing device 700 is a portable phone system, such as a cellular phone. The mobile computing device 700 may also include an optional keypad 735. Optional keypad 735 may be a physical keypad or a “soft” keypad generated on the touch screen display.
In various examples, the output elements include the display 705 for showing a graphical user interface (GUI) (such as the one described above that provides visual representation of a determined pronunciation and may receive feedback or other such input, a visual indicator 720 (e.g., a light emitting diode), and/or an audio transducer 725 (e.g., a speaker). In some aspects, the mobile computing device 700 incorporates a vibration transducer for providing an individual with tactile feedback. In yet another aspect, the mobile computing device 700 incorporates input and/or output ports, such as an audio input (e.g., a microphone jack), an audio output (e.g., a headphone jack), and a video output (e.g., a HDMI port) for sending signals to or receiving signals from an external device.
One or more application programs 750 may be loaded into the memory 745 and run on or in association with the operating system 755. Examples of the application programs include phone dialer programs, e-mail programs, personal information management (PIM) programs, word processing programs, spreadsheet programs, Internet browser programs, messaging programs, and so forth.
The system 740 also includes a non-volatile storage area 760 within the memory 745. The non-volatile storage area 760 may be used to store persistent information that should not be lost if the system 740 is powered down.
The application programs 750 may use and store information in the non-volatile storage area 760, such as email or other messages used by an email application, and the like. A synchronization application (not shown) also resides on the system 740 and is programmed to interact with a corresponding synchronization application resident on a host computer to keep the information stored in the non-volatile storage area 760 synchronized with corresponding information stored at the host computer.
The system 740 has a power supply 765, which may be implemented as one or more batteries. The power supply 765 may further include an external power source, such as an AC adapter or a powered docking cradle that supplements or recharges the batteries.
The system 740 may also include a radio interface layer 770 that performs the function of transmitting and receiving radio frequency communications. The radio interface layer 770 facilitates wireless connectivity between the system 740 and the “outside world,” via a communications carrier or service provider. Transmissions to and from the radio interface layer 770 are conducted under control of the operating system 755. In other words, communications received by the radio interface layer 770 may be disseminated to the application programs 750 via the operating system 755, and vice versa.
The visual indicator 720 may be used to provide visual notifications, and/or an audio interface 775 may be used for producing audible notifications via an audio transducer (e.g., audio transducer 725 illustrated in
The audio interface 775 is used to provide audible signals to and receive audible signals from the individual (e.g., voice input such as described above). For example, in addition to being coupled to the audio transducer 725, the audio interface 775 may also be coupled to a microphone to receive audible input, such as to facilitate a telephone conversation. In accordance with examples of the present disclosure, the microphone may also serve as an audio sensor to facilitate control of notifications, as will be described below.
The system 740 may further include a video interface 780 that enables an operation of peripheral device 730 (e.g., on-board camera) to record still images, video stream, and the like.
A mobile computing device 700 implementing the system 740 may have additional features or functionality. For example, the mobile computing device 700 may also include additional data storage devices (removable and/or non-removable) such as, magnetic disks, optical disks, or tape. Such additional storage is illustrated in
Data/information generated or captured by the mobile computing device 700 and stored via the system 740 may be stored locally on the mobile computing device 700, as described above, or the data may be stored on any number of storage media that may be accessed by the device via the radio interface layer 770 or via a wired connection between the mobile electronic device 700 and a separate electronic device associated with the mobile computing device 700, for example, a server computer in a distributed computing network, such as the Internet. As should be appreciated such data/information may be accessed via the mobile computing device 700 via the radio interface layer 770 or via a distributed computing network. Similarly, such data/information may be readily transferred between electronic devices for storage and use according to well-known data/information transfer and storage means, including electronic mail and collaborative data/information sharing systems.
As should be appreciated,
In some aspects, each of the general computing device 810 (e.g., personal computer), tablet computing device 815, or mobile computing device 820 may receive various other types of information or content that is stored by or transmitted from a directory service 845, a web portal 850, mailbox services 855, instant messaging stores 860, or social networking services 865.
In aspects, and as described above, each computing device may have access to a virtual machine data store 835 (e.g., storing timer information, offset and/or frequency information, etc.) that is provided on a server 805, the cloud or some other remote computing device.
By way of example, the aspects described above may be embodied in a general computing device 810, a tablet computing device 815 and/or a mobile computing device 820. Any of these examples of the electronic devices may obtain content from or provide data to the store 840.
As should be appreciated,
As should be appreciated, the figures herein
As will be understood from the foregoing disclosure, one aspect of the technology relates to a system comprising: a first clock; at least one processor; and a memory storing instructions that, when executed by the at least one processor, perform a method for providing consistent time information to a virtual machine. The method comprises: determining an offset of a second clock in a first execution environment for the virtual machine; preparing the first clock based on the determined offset; and continuing execution of the virtual machine in a second execution environment using the at least one processor, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the first clock based on the determined offset. In an example, preparing the first clock is performed by a hypervisor of the second execution environment. In another example, the method further comprises determining a multiplier for the first execution environment. In a further example, preparing the first clock further comprises using the determined multiplier to set a pre-specified frequency for the first clock. In yet another example, preparing the first clock further comprises specifying a frequency. In a further still example, the first clock and the second clock each operate at a similar frequency. In another example, generating the response to the request is further based on the determined multiplier.
In another aspect, the technology relates to a method for providing consistent time information to a virtual machine. The method comprises: determining an offset and a multiplier of a first execution environment for the virtual machine; preparing a clock of a second execution environment based on the determined offset and the determined multiplier; and continuing execution of the virtual machine at the second execution environment, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the clock. In an example, preparing the clock is performed by a hypervisor of the second execution environment. In another example, generating the response to the request is based on the determined offset and the determined multiplier. In a further example, preparing the clock further comprises using the determined multiplier to request a pre-specified frequency for the clock. In yet another example, preparing the clock further comprises specifying a frequency. In a further still example, the first execution environment and the second execution environment each comprise a hardware clock operating at a similar frequency.
In another aspect, the technology relates to another method for providing consistent time information to a virtual machine. The method comprises: determining an offset of a first clock in a first execution environment for the virtual machine; preparing a second clock of a second execution environment based on the determined offset; and continuing execution of the virtual machine in the second execution environment, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the second clock based on the determined offset. In an example, preparing the second clock is performed by a hypervisor of the second execution environment. In another example, the method further comprises determining a multiplier for the first execution environment. In a further example, preparing the second clock further comprises using the determined multiplier to set a pre-specified frequency for the second clock. In yet another example, preparing the second clock further comprises specifying a frequency. In a further still example, the first clock and the second clock each operate at a similar frequency. In another example, generating the response to the request is further based on the determined multiplier.
The description and illustration of one or more aspects provided in this application are not intended to limit or restrict the scope of the disclosure as claimed in any way. The aspects, examples, and details provided in this application are considered sufficient to convey possession and enable others to make and use the best mode of claimed disclosure. The claimed disclosure should not be construed as being limited to any aspect, example, or detail provided in this application. Regardless of whether shown and described in combination or separately, the various features (both structural and methodological) are intended to be selectively included or omitted to produce an embodiment with a particular set of features. Additionally, each operation in the described methods may be performed in different orders and/or concurrently, simultaneously or substantially simultaneously with other operations.
Having been provided with the description and illustration of the present application, one skilled in the art may envision variations, modifications, and alternate aspects falling within the spirit of the broader aspects of the general inventive concept embodied in this application that do not depart from the broader scope of the claimed disclosure.
Claims
1. A system comprising:
- a first clock;
- at least one processor; and
- a memory storing instructions that, when executed by the at least one processor, perform a method for providing consistent time information to a virtual machine, comprising: determining an offset of a second clock in a first execution environment for the virtual machine; preparing the first clock based on the determined offset; and continuing execution of the virtual machine in a second execution environment using the at least one processor, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the first clock based on the determined offset.
2. The system of claim 1, wherein preparing the first clock is performed by a hypervisor of the second execution environment.
3. The system of claim 1, wherein the method further comprises determining a multiplier for the first execution environment.
4. The system of claim 3, wherein preparing the first clock further comprises using the determined multiplier to set a pre-specified frequency for the first clock.
5. The system of claim 1, wherein preparing the first clock further comprises specifying a frequency.
6. The system of claim 1, wherein the first clock and the second clock each operate at a similar frequency.
7. The system of claim 3, wherein generating the response to the request is further based on the determined multiplier.
8. A method for providing consistent time information to a virtual machine, comprising:
- determining an offset and a multiplier of a first execution environment for the virtual machine;
- preparing a clock of a second execution environment based on the determined offset and the determined multiplier; and
- continuing execution of the virtual machine at the second execution environment, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the clock.
9. The method of claim 8, wherein preparing the clock is performed by a hypervisor of the second execution environment.
10. The method of claim 8, wherein generating the response to the request is based on the determined offset and the determined multiplier.
11. The method of claim 8, wherein preparing the clock further comprises using the determined multiplier to request a pre-specified frequency for the clock.
12. The method of claim 8, wherein preparing the clock further comprises specifying a frequency.
13. The method of claim 8, wherein the first execution environment and the second execution environment each comprise a hardware clock operating at a similar frequency.
14. A method for providing consistent time information to a virtual machine, comprising:
- determining an offset of a first clock in a first execution environment for the virtual machine;
- preparing a second clock of a second execution environment based on the determined offset; and
- continuing execution of the virtual machine in the second execution environment, wherein continuing execution of the virtual machine comprises: receiving a request for time information by the virtual machine; and generating a response to the request using the second clock based on the determined offset.
15. The method of claim 14, wherein preparing the second clock is performed by a hypervisor of the second execution environment.
16. The method of claim 14, wherein the method further comprises determining a multiplier for the first execution environment.
17. The method of claim 16, wherein preparing the second clock further comprises using the determined multiplier to set a pre-specified frequency for the second clock.
18. The method of claim 14, wherein preparing the second clock further comprises specifying a frequency.
19. The method of claim 14, wherein the first clock and the second clock each operate at a similar frequency.
20. The method of claim 16, wherein generating the response to the request is further based on the determined multiplier.
Type: Application
Filed: Jan 19, 2018
Publication Date: Mar 21, 2019
Applicant: Microsoft Technology Licensing, LLC (Redmond, WA)
Inventors: Aditya BHANDARI (Seattle, WA), Bruce J. SHERWIN, JR. (Woodinville, WA), Xin David ZHANG (Redmond, WA)
Application Number: 15/875,772