Power management is being implemented in computers of all sizes, e.g., to extend battery life in mobile devices and to curtail energy costs in large installations. Users, administrators, and automated power-management programs can turn off unused hardware and software components and set other components to lower performance levels to save power. Also, usage profiles can be established and selected so that users are riot required to consider the settings for each component separately. For example, a “mobile” profile can include diming a display to save battery capacity and turning on a cellular modem to maintain connectivity while a “docked” profile can use a brighter display but turn off the cellular modem (in favor of an Ethernet connection provided by the dock). Other preset and user-defined profiles can be provided.
Advantages of one or more disclosed embodiments may become apparent upon reading the following detailed description and upon reference to the drawings in which:
A computer 100, as shown in
In some embodiments, an external power manager can generate the power-consumption data, e.g., at the factory that manufacturers the computer. In other embodiments, an internal power manager can be configured to generate the power-consumption data, e.g., in the field, so that the data can be current and take the current configuration. and current conditions into account. For example, the power consumed by a wireless radio can be affected by the distance of the computer from a wireless access point; the effect of the distance to the wireless access point can be more readily accounted for when the data is determined in the field, e.g., by an internal power manager.
Accordingly, as shown in
Computer components 305 can include what are referred to herein as “software components” 330. However, as those skilled in the art would understand, software per se consumes no power; rather the hardware included in executing software consumes power. Thus, herein, reference to the power consumption of a software component refers to a difference in power consumption by hardware components when the software component is active rather than inactive (not being executed or being maintained in some baseline state). One example of a software component can include an operating-system shell 311, e.g., the Aero interface that can be activated and inactivated in Windows 7, available from Microsoft Corporation. In addition, system services 333 such as background print spooling, screen savers, and auto-updating programs can be activated and deactivated so as to have an effect on power consumption.
As shown in
Components with more than one non-baseline setting may be represented by more than one row. For example, “backlight” has “bright” and “dim” non-baseline settings as opposed to a “minimum” or “off” baseline setting. Depending on the component, the baseline setting may be an “off”, “disabled”, “idle”, or other minimum setting. Some components, e.g., power manager 301, a power supply 341 and integrated input devices 343 (e.g., a laptop keyboard) are not represented in table 303 because the available power profiles do not provide for different modes of operation for these components.
In
Power manager 301 can include an event monitor 351, a user interface 353, a sequencer 355, a power measurement circuit 357, a validator 359, a calculator 361, and a power advisor 363. Event monitor 351 can be adapted to detect events, such as a configuration change, that might cause current power data in table 303 (or data being collected) to be invalid. For example, if a new component is added to the computer, or if a new service pack is applied to the operating system, power consumption can be impacted. Thus, event monitor 351 can be used to suggest or determine when to update table 303. User interface 353 can be adapted to allow a user to determine whether or not to proceed with updating table 303 and to allow a user to select a power profile setting based on table 303.
When it is determined that table 303 is to be updated, sequencer 355 may control the settings of the components to be assessed, and power measurement circuit 357 can be used to determine the power consumptions of components at times determined in part by sequencer 357. By keeping specific control over the component settings, the resulting power measurement can be used to isolate and approximate power consumption for individual devices and/or software services running on the computer. Power measurer 357 can be, for example, an HP Power Monitoring Circuit (PMC) as used in business notebook computers available from Hewlett-Packard Company.
During a testing sequence, event monitor 351 can monitor for events that might: invalidate a power measurement. Thus, event monitor 351 can be used to ensure power measurements taken while during transient conditions are not used in computing power values. Also, event monitor 351 is adapted to invalidate power data if a configuration change (e.g., a switch from battery power to AC power) occurred as the data was collected. Validator 359 can be configured to make validation determinations based at least in part on event detections (or lack thereof) by event monitor 351. if the power measurement data is valid, calculator 361 can be used to calculate a value or values to be inserted in the mWatt power column of the appropriate row.
Advisor 363 can use the power consumption data in table 303 for predicting battery life and/or power cost impacts. In addition, advisor can be used to recommend power configurations and to otherwise assist users in making and understanding device, software, and system configuration decisions. In the context of a laptop or other battery-operated computer, advisor 363 can provide recommendations for extending battery life while minimally impairing performance. In the context of an enterprise computer system, advisor 363 can provide recommendations for achieving performance objectives while minimizing energy costs.
Power manager 301 is configured to implement method 400 shown in flow-chart in
In response to a user accepting a recommendation to update or a user-initiated command to update, block 420 provides for updating table 303. In some cases, this can include adding component-setting rows to table 303. For example, when a new device is added via a peripheral component interconnect (PCI) or PCIe slot of a computer, one or more rows can be added to table 303 to represent that device's non-baseline settings. In other cases, no rows are added. For example, the opening of a new user account or the detection of a newly available wireless access point may trigger an update that does not include adding rows to table 303.
In one embodiment, block 420 may include several subblocks, herein just referred to as “blocks”. At block 421, event monitor 351 can be configured to monitor for invalidating events. Block 421 can be ongoing throughout block 420.
At block 422, a component can be selected for measurement. If there are multiple non-baseline settings for the component, they can be selected on different iterations of block 422. In an iteration of block 422, no component is selected so that a baseline computer power-consumption measurement can be obtained. Block 423 may include initiating the selected non-baseline component setting or the baseline computer setting. This can include turning components off, turning components on, and/or adjusting component settings.
Block 424 can include waiting for steady state conditions to be achieved before measurements are considered valid. This can include monitoring Central Processing Unit (CPU) utilization, which may typically rise during initialization and fall to a steady-state level; power measurement can begin once CPU utilization has reached a steady relatively low level. Alternatively, block 424 can include sequencer 355 waiting a preset period of time known to be sufficient for steady state conditions to be achieved. Alternatively, event monitor 351 can detect: an event (e.g., a “ready” acknowledgement” indicating steady state has been achieved. Alternatively, power measurement data can be collected and analyzed to determine when steady state was achieved so that transient data can then be discarded.
Power consumption can be measured at block 425. This can include sensing current at the computer input or at the output of an internal power supply. In one example, the sensing is continuous and block 425 can identify durations beginning after transients have subsided.
At block 426, validator 359 can check data from event monitor 331 to determine if any invalidating conditions occurred during a time that presumed valid data was collected. If a user switched from alternating current (AC) power to battery power or launched an application during a presumed valid duration, the data can then be invalidated. In that case, the measurement can be repeated by returning to block 423. AC power may refer to external AC power accessed via a wall outlet.
If there were no invalidating conditions (for the current iteration), calculator 361 can calculate a power-consumption value for the baseline, component, or component setting at block 427. In the case of a baseline measurement, an average power of the valid time period can be taken. In the case of a component or a component setting, the difference between the average power of the valid time period and a previously obtained baseline power value can be obtained. For iterations in which a component or component setting is being evaluated, the result can be stored in the appropriate cell of table 303.
Due to component dependencies, some calculations may combine a difference between a current component power-consumption measurement and a previously obtained power-consumption measurement for another component with the power value associated with the other component. For example, determining a power associated with a disk intensive application may require that the disk be operating when determining a power value for the application. In such a case, the power consumed when the application is running can be compared with the power consumed when the application is not running but the disk is running, rather than a baseline condition when the disk is not running.
At block 428, sequencer 355 can determine whether there are one or more components or component settings for which power consumption measurements are to be made. If so, block 420 can return to block 422 for the next iteration. Otherwise, power manager 301 can present a recommended power profile setting to the user at block 431. At block 432, the user selects a power profile setting, either accepting the recommendation or selecting an alternative. At block 433, power manager 301 can implement the selected power profile.
While it allows a user to individually activate, inactivate, and adjust the settings for individual components, power manager 353 can present a user with power-setting profiles optimized for various use scenarios. For an example applicable to a laptop computer, the settings for several components when the laptop is being used for in office use while attached to AC power can be different from use as an alarm clock and email client when using battery power. Another profile may include turning off a cellular radio when a Wi-Fi access point is in range for mobile use. By presenting power profiles in the form of common use scenarios, power manager 301 can relieve the user of having to make power-consumption decisions on a component-by-component basis.
In an alternative embodiment, the power measurements can be made by an external device inserted between AC power and the computer. The sequencer can be a software program running on the computer. Communication between the power measurement device and the sequencer can be through an input/output port, e.g., a USB port.
In another embodiment, the component power consumption table can completed at the time of manufacture. In that embodiment, a larger table may take into account all possible configurations in which the computer may he sold and some of the possible upgrade configurations (e.g., resulting from a memory upgrade).
Since power management typically includes tradeoffs, e.g., between power consumption and performance, accurate information regarding the impact a change in power configuration may have on parameters of interest (e.g., power consumption, battery life, energy cost) can lead to more effective decision making.
A “component setting” is a setting for a component, e.g., a “baseline component setting” or a “non-baseline component setting”. Typical baseline component settings include “power off”, “idle”, “unlaunched”, and “unloaded”. Typical non-baseline power states include “active”, “launched”, “high-performance settings,” and “low-performance settings”. For example, a processor can have a high-performance high-power-consumption setting, a (reduced) mid-performance mid-power-consumption setting, and a low-performance low-power setting. In some embodiments, e.g., in which a processor must be active for power consumption to be evaluated, the low-performance selling can be the baseline setting for the processor. In other embodiments, e.g., where more than one processor is available, a power off or idle state can be the baseline processor state. A computer can also have a “baseline computer setting” in which as many components as possible are in their baseline component settings.
A computer manufacturer can include a power table associating power-consumption values with non-baseline component settings. Such a table can include configurations of the computer as shipped and also configurations that: can occur in various upgrade scenarios. Such tables can be used to answer questions such as “Flow much longer will the battery last if I turn off the wireless radio?”, “How much money can I save today if I run two processors instead of four”. An administrator, user, or automated control system can then use this information in managing the computer.
Herein, a “computer” can be a system including: storage media encodable with instructions and at least one processor for executing the instructions. The computer can be implemented as a laptop computer, a portable computer, a netbook computer, a tablet computer, a cellular device, a handheld gaming system, or an ultraportable computer. Herein, “storage media” refers to non-transitory tangible storage media. Herein, “processor” refers to a hardware device including at least some conductive material such as metal for conducting electricity or optical fiber for conducting light.
Herein, a “system” can include a set of interacting elements, wherein the elements can be, by way of example and not of limitation mechanical components, electrical elements, atoms, instructions encoded in storage media, and process segments. In this specification, related art is discussed for expository purposes. Related art labeled “prior art”, if any, is admitted prior art. Related art not labeled “prior art” is not admitted prior art. The illustrated and other described embodiments, as well as modifications thereto and variations thereupon are within the scope of the following claims.
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/US10/43695 | 7/29/2010 | WO | 00 | 1/28/2013 |