1. Technical Field
The present invention relates to identifying deterministic performance boost capability of a computer system. More particularly, the present invention relates to acquiring device voltage margins and utilizing the device voltage margins during benchmark testing in order to identify a system's guaranteed minimum performance boost.
2. Description of the Related Art
Manufacturers typically guarantee a computer system's performance characteristics based upon certain criteria, such as an amount of time that a computer system requires in order to execute a benchmark test. These manufacturers may also disclose a non-guaranteed performance increase over the computer system's guaranteed characteristics.
A benchmark tester retrieves a voltage margin that corresponds to a device included in a system. The voltage margin indicates an additional amount of voltage to apply to a nominal voltage that results in the device operating at a power limit while executing a worst-case power workload. Next, the benchmark tester (or thermal power management device) sets an input voltage for the device to a value equal to the sum of the voltage margin and the nominal voltage. The benchmark tester then dynamically benchmark tests the system, which includes adjusting the device's frequency and input voltage while ensuring that the device does not exceed the device's power limit. In turn, the benchmark tester records a guaranteed minimum performance boost for the system based upon a result of the benchmark testing.
The foregoing is a summary and thus contains, by necessity, simplifications, generalizations, and omissions of detail; consequently, those skilled in the art will appreciate that the summary is illustrative only and is not intended to be in any way limiting. Other aspects, inventive features, and advantages of the present invention, as defined solely by the claims, will become apparent in the non-limiting detailed description set forth below.
The present invention may be better understood, and its numerous objects, features, and advantages made apparent to those skilled in the art by referencing the accompanying drawings, wherein:
Certain specific details are set forth in the following description and figures to provide a thorough understanding of various embodiments of the invention. Certain well-known details often associated with computing and software technology are not set forth in the following disclosure, however, to avoid unnecessarily obscuring the various embodiments of the invention. Further, those of ordinary skill in the relevant art will understand that they can practice other embodiments of the invention without one or more of the details described below. Finally, while various methods are described with reference to steps and sequences in the following disclosure, the description as such is for providing a clear implementation of embodiments of the invention, and the steps and sequences of steps should not be taken as required to practice this invention. Instead, the following is intended to provide a detailed description of an example of the invention and should not be taken to be limiting of the invention itself. Rather, any number of variations may fall within the scope of the invention, which is defined by the claims that follow the description.
Device tester 100 provides test program 120, frequency 130 (e.g., clock signal), and voltage 140 to device 110. Test program 120 is a program that tests device 110 in various ways, such as testing race conditions and stressing various portions of device 110. Frequency 130 and voltage 140 are a system clock and supply voltage, respectively, that device tester 100 adjusts during manufacturing test.
In order to identify device 110's minimum operational voltage, device tester 100 supplies frequency 130 at a rate equal to the nominal frequency plus a frequency guard band (e.g., 8%), and provides test program 120, which exercises device 110's worst case timing paths. Device tester 100 decreases voltage 140 until device 110 fails at one of the timing path tests. At this point, voltage 140 is at its minimum operating voltage, which device tester 100 logs. As one skilled in the art can appreciate, the minimum operational voltage may be set by technology, reliability requirements, circuit failure, and/or other criteria.
In order to identify device 110's maximum voltage, device tester 100 supplies frequency 130 at a rate equal to the nominal frequency and provides test program 120, which executes on device 110 at a worst-case power workload. Next, device tester 100 increases voltage 140 until device tester 100 detects that power 150 reaches device 110's rated power limit, which is a parameter that device 110's thermal design specification specifies. At this point, voltage 140 is at its maximum voltage, which device tester 100 logs.
Device tester 100 uses the minimum voltage and the maximum voltage to compute a voltage margin for device 110 (see
Once device tester 100 computes and records device 110's voltage margin, a benchmark tester tests a computer system that includes device 100 in order to identify a guaranteed minimum performance boost for the computer system. As one skilled in the art can appreciate, the computer system may include multiple devices and/or a thermal power management device (TPMD) (see
Benchmark tester 240 is an information handling system, which includes one or more processors and computer memory, that is capable of performing the computing operations described herein. Benchmark tester 240 begins by initializing system 200 and providing benchmark program 260, voltage margin A 265, and voltage margin B 270 to system 200. System 200 loads benchmark program 260 onto device A 210 and device B 220, which tests the devices under various benchmark conditions. TPMD 230 adds voltage margin A 265 and voltage margin B 270 to device A 210's and device B 220's nominal voltage, respectively. As such, TPMD 230 provides input voltage 280 to device A 210 at a value that is the sum of voltage margin A 265 and device A 210's nominal voltage. In turn, TPMD 230 provides input voltage 285 to device B 220 at a value that is the sum of voltage margin B 270 and device B 220's nominal voltage. As one skilled in the art can appreciate, voltage 280 and 285 may be different voltage levels.
During benchmark testing, TPMD 230 dynamically adjusts frequency 275, input voltage 280, and input voltage 285 while monitoring power A 290 and power B 295 in order to ensure that neither device exceeds its power limit. Once benchmark testing completes, TPMD 230 provides benchmark result 299 to benchmark tester 240. For example, benchmark result 299 may be in terms of the amount of required time to complete the benchmark test (benchmark completion time), a number of transactions per second, or some other metric. Benchmark tester 240 stores this value, which is system 200's guaranteed minimum performance boost, in performance store 250. As a result, a manufacturer may guarantee system 200 to operate at a minimum performance equal to the guaranteed minimum performance boost for the benchmark under test (see
Voltage margin 340 represents a computed or measured voltage value to add to the device's nominal voltage under worst-case power workload conditions and a particular frequency, which causes the device to reach the device's power limit. As can be seen, adding voltage margin 340 to nominal curve 320 produces a new adjusted curve 360. During benchmark testing, the thermal power management device utilizes points along adjusted curve 360 while monitoring the device's power in order to identify a system's guaranteed minimum performance boost (see
In one embodiment, manufacturing computes voltage margins for each device that results in each device operating at power limit 470. As can be seen, when device A 410 operates at a voltage level that is the sum of its nominal voltage and voltage margin, device A 410 produces power that is the sum of power Anom 415 plus power Amar 420. Likewise, when device B 430 operates at a voltage level that is the sum of its nominal voltage and voltage margin, device B 430 produces power that is the sum of power Bnom 435 plus power Bmar 440. And, when device C 450 operates at a voltage level that is the sum of its nominal voltage and voltage margin, device C 450 produces power that is the sum of power Cnom 455 plus power Cmar 460. As can be seen, since each device produces different power levels at their respective nominal voltage, each device requires a different voltage margin, which produces a different amount of additional power, in order to reach power limit 470.
Once processing computes the voltage margin, processing determines whether there are more devices in which to test (decision 530). If there are more devices in which to test, decision 530 branches to “Yes” branch 532, which loops back to select and process another device. This looping continues until there are no more devices to test, at which point decision 530 branches to “No” branch 538.
At step 540, processing builds a system using one or more of the tested devices. The system may include multiple devices and may also include a thermal power management device that manages each device's voltage, frequencies, and power limits (see
Processing determines whether to configure the system for an absolute frequency boost mode (decision 570). This configuration sets and maintains the device frequency to a highest value reached by the device frequency during the benchmark testing. For example, if the highest frequency reached during benchmark testing was 4.12 GHz, processing configures the system, which includes each of the devices, to operate exactly at 4.12 GHz when a user invokes the absolute frequency boost mode.
If processing should configure the system for an absolute frequency boost mode configuration, decision 570 branches to “Yes” branch 572 whereupon processing configures the system to operate at a fixed increased frequency when a user places the system in boost mode (step 580).
On the other hand, if processing should not configure the system for the absolute frequency boost mode, decision 570 branches to “No” branch 578, bypassing configuration step 580, and processing ends at 590.
Once processing acquires the minimum voltage and maximum voltage, processing computes a nominal voltage by dividing by two the sum of the minimum voltage and the maximum voltage (step 640). Next, processing computes a voltage margin by subtracting the nominal voltage from the maximum voltage (step 650). At step 660, processing stores the voltage margin for the device in voltage margin store 160, and processing returns at 670.
At step 720, processing sets each device's supply voltage to their maximum power-managed voltage by adding their respective voltage margins to their respective nominal voltages. For example, device “A” may have a nominal voltage of 1.2 volts and a voltage margin of 0.3 volts and device “B” may have a nominal voltage of 1.4 volts and a voltage margin of 0.4 volts. In this example, processing sets device A's input voltage to 1.5 volts (1.2+0.3) and sets device B's input voltage to 1.8 volts (1.4+0.4).
Processing begins benchmark testing at step 730. During the benchmark test, processing (e.g., utilizing a thermal power management device (TPMD)) dynamically scales device voltages and frequencies while maintaining power limits of each device during step 740. Once the benchmark test completes, processing records the test performance in performance store 250, which includes the frequency at which one or more of the devices reached their power limit (step 750). Processing returns at 760.
Processing applies a voltage margin to the nominal voltage that causes the device to operate at a higher voltage (step 830). Processing performs this step in order to identify a voltage at which the device operates at the device's power limit (see below). At step 840, processing executes a worst-case power workload test on the device and, at step 850, processing logs the device's socket power dissipation.
Processing determines whether the socket power reaches the device's power limit (decision 860). If the socket power has not reached the device's power limit, decision 860 branches to “No” branch 862, which loops back to increase the voltage margin (step 870) and re-execute the worst-case power workload. This looping continues until the socket power reaches the power limit, at which point decision 860 branches to “Yes” branch 868.
Processing stores the voltage margin value in voltage margin store 160 that resulted in the device reaching the power limit (step 880), and processing ends at 890. The device is now ready for insertion into a system for benchmark testing (see
One of the preferred implementations of the invention is a set of instructions (program code) or other functional descriptive material in a code module that may, for example, be resident in the random access memory of the computer. Until required by the computer, the set of instructions may be stored in another computer memory, for example, in a hard disk drive, or in a removable memory such as an optical disk (for eventual use in a CD ROM) or floppy disk (for eventual use in a floppy disk drive). Thus, the present invention may be implemented as a computer program product for use in a computer. In addition, although the various methods described are conveniently implemented in a general purpose computer selectively activated or reconfigured by software, one of ordinary skill in the art would also recognize that such methods may be carried out in hardware, in firmware, or in more specialized apparatus constructed to perform the required method steps. Functional descriptive material is information that imparts functionality to a machine. Functional descriptive material includes, but is not limited to, computer programs, instructions, rules, facts, definitions of computable functions, objects, and data structures.
While particular embodiments of the present invention have been shown and described, it will be obvious to those skilled in the art that, based upon the teachings herein, changes and modifications may be made without departing from this invention and its broader aspects. Therefore, the appended claims are to encompass within their scope all such changes and modifications as are within the true spirit and scope of this invention. Furthermore, it is to be understood that the invention is solely defined by the appended claims. It will be understood by those with skill in the art that if a specific number of an introduced claim element is intended, such intent will be explicitly recited in the claim, and in the absence of such recitation no such limitation is present. For non-limiting example, as an aid to understanding, the following appended claims contain usage of the introductory phrases “at least one” and “one or more” to introduce claim elements. However, the use of such phrases should not be construed to imply that the introduction of a claim element by the indefinite articles “a” or “an” limits any particular claim containing such introduced claim element to inventions containing only one such element, even when the same claim includes the introductory phrases “one or more” or “at least one” and indefinite articles such as “a” or “an”; the same holds true for the use in the claims of definite articles.
Number | Name | Date | Kind |
---|---|---|---|
5557548 | Gover et al. | Sep 1996 | A |
5657253 | Dreyer et al. | Aug 1997 | A |
5719800 | Mittal et al. | Feb 1998 | A |
5796637 | Glew et al. | Aug 1998 | A |
5832284 | Michail et al. | Nov 1998 | A |
5974557 | Thomas et al. | Oct 1999 | A |
6112318 | Jouppi et al. | Aug 2000 | A |
6233531 | Klassen et al. | May 2001 | B1 |
6275782 | Mann | Aug 2001 | B1 |
6546359 | Week | Apr 2003 | B1 |
6678777 | Rao et al. | Jan 2004 | B2 |
6731292 | Burk et al. | May 2004 | B2 |
6792392 | Knight | Sep 2004 | B1 |
6836849 | Brock et al. | Dec 2004 | B2 |
7047471 | Monfared et al. | May 2006 | B2 |
7051221 | Clabes et al. | May 2006 | B2 |
7194545 | Urien | Mar 2007 | B2 |
7197419 | Floyd et al. | Mar 2007 | B2 |
7340378 | Floyd et al. | Mar 2008 | B1 |
7382366 | Klock et al. | Jun 2008 | B1 |
7475175 | Klein et al. | Jan 2009 | B2 |
7533003 | Floyd et al. | May 2009 | B2 |
7576569 | Carpenter et al. | Aug 2009 | B2 |
7681054 | Ghiasi et al. | Mar 2010 | B2 |
7908493 | Bieswanger et al. | Mar 2011 | B2 |
20020073255 | Davidson et al. | Jun 2002 | A1 |
20040216113 | Armstrong et al. | Oct 2004 | A1 |
20040236993 | Adkisson et al. | Nov 2004 | A1 |
20040237003 | Adkisson et al. | Nov 2004 | A1 |
20050021292 | Vock et al. | Jan 2005 | A1 |
20050081101 | Love et al. | Apr 2005 | A1 |
20050102539 | Hepner et al. | May 2005 | A1 |
20050108591 | Mendelson et al. | May 2005 | A1 |
20050155021 | DeWitt et al. | Jul 2005 | A1 |
20050177344 | Khaleel | Aug 2005 | A1 |
20050183065 | Wolczko et al. | Aug 2005 | A1 |
20050283677 | Adkisson et al. | Dec 2005 | A1 |
20060031691 | Bacchus et al. | Feb 2006 | A1 |
20060179359 | Floyd et al. | Aug 2006 | A1 |
20070001715 | Brown et al. | Jan 2007 | A1 |
20070033425 | Clark | Feb 2007 | A1 |
20070052453 | Wald | Mar 2007 | A1 |
20070266263 | Lee et al. | Nov 2007 | A1 |
20070285080 | Abuhamdeh et al. | Dec 2007 | A1 |
20080065912 | Bodner et al. | Mar 2008 | A1 |
20080086395 | Brenner et al. | Apr 2008 | A1 |
20080091962 | Cepulis et al. | Apr 2008 | A1 |
20080281476 | Bose et al. | Nov 2008 | A1 |
20080307238 | Bieswanger et al. | Dec 2008 | A1 |
20090187777 | Clark | Jul 2009 | A1 |
Number | Date | Country | |
---|---|---|---|
20100125436 A1 | May 2010 | US |