WO2016209494A1 - Power management circuit with per activity weighting and multiple throttle down thresholds - Google Patents

Power management circuit with per activity weighting and multiple throttle down thresholds Download PDF

Info

Publication number
WO2016209494A1
WO2016209494A1 PCT/US2016/034071 US2016034071W WO2016209494A1 WO 2016209494 A1 WO2016209494 A1 WO 2016209494A1 US 2016034071 W US2016034071 W US 2016034071W WO 2016209494 A1 WO2016209494 A1 WO 2016209494A1
Authority
WO
WIPO (PCT)
Prior art keywords
circuit
credit count
signal
memory devices
threshold
Prior art date
Application number
PCT/US2016/034071
Other languages
French (fr)
Inventor
James Alexander
Muthukumar P. Swaminathan
Richard P. Mangold
Original Assignee
Intel Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corporation filed Critical Intel Corporation
Priority to EP16814953.2A priority Critical patent/EP3314365B1/en
Priority to CN201680029895.9A priority patent/CN107646106B/en
Publication of WO2016209494A1 publication Critical patent/WO2016209494A1/en

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0668Interfaces specially adapted for storage systems adopting a particular infrastructure
    • G06F3/0671In-line storage system
    • G06F3/0673Single storage device
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3206Monitoring of events, devices or parameters that trigger a change in power modality
    • G06F1/3228Monitoring task completion, e.g. by use of idle timers, stop commands or wait commands
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/3243Power saving in microcontroller unit
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/26Power supply means, e.g. regulation thereof
    • G06F1/32Means for saving power
    • G06F1/3203Power management, i.e. event-based initiation of a power-saving mode
    • G06F1/3234Power saving characterised by the action undertaken
    • G06F1/329Power saving characterised by the action undertaken by task scheduling
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0602Interfaces specially adapted for storage systems specifically adapted to achieve a particular effect
    • G06F3/0625Power saving in storage systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F3/00Input arrangements for transferring data to be processed into a form capable of being handled by the computer; Output arrangements for transferring data from processing unit to output unit, e.g. interface arrangements
    • G06F3/06Digital input from, or digital output to, record carriers, e.g. RAID, emulated record carriers or networked record carriers
    • G06F3/0601Interfaces specially adapted for storage systems
    • G06F3/0628Interfaces specially adapted for storage systems making use of a particular technique
    • G06F3/0653Monitoring storage devices or systems
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F9/00Arrangements for program control, e.g. control units
    • G06F9/06Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
    • G06F9/46Multiprogramming arrangements
    • G06F9/50Allocation of resources, e.g. of the central processing unit [CPU]
    • G06F9/5094Allocation of resources, e.g. of the central processing unit [CPU] where the allocation takes into account power or heat criteria
    • YGENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
    • Y02TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
    • Y02DCLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
    • Y02D10/00Energy efficient computing, e.g. low power processors, power management or thermal management

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Software Systems (AREA)
  • Human Computer Interaction (AREA)
  • Power Sources (AREA)

Abstract

A method is described. The method includes receiving an indication of an activity of load circuitry of a power supply. The method includes, in response to the indication, generating a first signal that describes the activity and a second signal that describes whether the event is initiating or completing. The method includes determining a weight amount from the first signal and adjusting a credit count by the weight amount up or down based on the second signal. The method includes comparing the credit count against a first threshold. The method includes calculating an average credit count that accounts for the credit count and previous credit counts and comparing the average credit count against a second threshold. The method includes adjusting an activity level of the load circuitry if either threshold is crossed.

Description

POWER MANAGEMENT CIRCUIT WITH PER ACTIVITY WEIGHTING AND MULTIPLE THROTTLE DOWN THRESHOLDS
FIELD OF INVENTION
The field of invention pertains generally to a power management circuit with per activity weighting and multiple throttle down thresholds.
BACKGROUND
Power consumption has become one of the more critical parameters that a circuit is judged by. Here, with increasingly smaller feature sizes and increasingly faster clock speeds, semiconductor chip designers are faced with the challenge of efficiently designing extremely large numbers of faster devices into a commercially viable integrated circuit. Present day circuit designers are therefore very much focused on producing circuits that can extract the performance potential of the underlying manufacturing technology, while, at the same time, keeping operation of the overall circuit within a reasonable power budget.
FIGURES
A better understanding of the present invention can be obtained from the following detailed description in conjunction with the following drawings, in which: Fig. 1 shows an embodiment of a power management circuit;
Fig. 2 shows an embodiment of operation of the power management circuit of Fig. 1 ; Fig. 3 shows an embodiment of a averaging circuit;
Fig. 4 shows an embodiment of a DIMM card;
Fig. 5 shows an embodiment of a method performed by the power management circuit of Fig. 1;
Fig. 6 shows an embodiment of a computing system.
DETAILED DESCRIPTION
Fig. 1 shows a design for a power management circuit 100 that measures both the instantaneous power currently being consumed by a load circuit 101 and the average power that has been consumed by the load circuit 101 over a preceding time window. By measuring both types of power consumption, different triggers can be set to throttle back the power consumption of the load circuit 101, e.g., by commanding the load circuit 101 to be less active. More specifically, the power consumption of the load circuit 101 can be throttled down in response to either: 1) its instantaneous power exceeding a maximum level ("absolute" power limit of the power supply 102); or, 2) its average power exceeding a maximum level ("sustainable" power limit of the power supply 102). In various instances, the power supply 102 may have sufficient resources to briefly provide an amount of power that exceeds its sustainable power limit. Here, sustainable power is understood to be a rating that characterizes a power supply's ability to continuously maintain an amount of delivered power. Deviations about this sustainable level are generally permissible. In the case of power draw deviations below the sustainable level, the power supply is operating well within its capabilities.
Power draw deviations above the sustainable level are also generally permissible provided they are brief. For instance, as a simplistic example, if a power supply has a sustainable power level of 12W, it would be permissible to briefly draw 13W from the power supply provided the drawn power drops thereafter so that the average power drawn over some time period falls to a level within the sustainable level of 12W. In this case, the sustainable power level is not really offended because the time over which the average power is calculated includes the lower power draw time period. Thus, the circuit 101 that is supplied by the power supply 102 can enjoy a "turbo" mode in which it is permitted to briefly perform at a level that it cannot operate at for long periods of time.
A related scenario occurs in the case of regular but temporally separated runtime power draw "bursts". An example is a DIMM card having multiple memory devices and an interface to a high speed memory bus where, over the course of an extended runtime, there will be low power reads/writes from/to the memory devices for extended periods of time interspaced in time by high power bus transactions for much shorter periods of time. Here, the longer low power reads/writes may lower the average power delivered to the DIMM card to a level that permits the shorter high power bus transactions to briefly exceed the sustainable power rating of the power supply. As such, the bus driver circuits that interface to the memory bus and the memory devices may share the same power supply (that is, both circuits can be viewed as part of the load).
Allowing power draw to reach an instantaneous power limit provided an average power limit is not offended also provides for more efficient usage of the power budget that exists between the instantaneous power limit and the average power limit. That is, drawn power can remain at or near the instantaneous power level up and until the average power maximum rating is offended. Thus, using the above mentioned DIMM card example, some implementations (e.g., depending on power supply capacity and load) may have enough time to permit back-to-back high power bus transactions before offending the average power rating.
The power management circuit 100 of Fig. 1 includes an activity detection circuit 103 that detects the various requests or other activities that the load circuitry 101 is expected to handle. A scheduler 104 schedules these activities. The decisions made by the scheduler 104 essentially determine how much power the load circuitry 101 will consume. For example, by inserting idles into the load circuitry's schedule the power consumption of the load circuitry 101 will be reduced. Likewise, by inserting higher power operations closer to one another in time the power consumption of the load circuitry 101 will be increased. Depending on implementation, some, all or none of the power management circuit 100 and/or scheduler circuit 104 may be part of the load 101.
The scheduler 104 reacts to a throttle down signal 105 provided by the power management circuitry. In response to the throttle down signal 105, the scheduler 104 will insert lesser power consuming activities into the scheduler (e.g., idles or other low power tasks) and/or spread out activities to be performed farther apart in time.
The power management circuitry includes a credit pool count circuit 106. The credit pool count circuit 106 includes a register 107 or other circuit capable of holding state information. Here, register 107 holds a credit count where the total number of credits is correlated with the amount of power that the power supply can deliver. As the load circuitry 101 consumes more power, the credit count drops which, in turn, reflects the reduced capacity of the power supply to deliver additional power.
As mentioned above, the activity detection circuit 103 receives indications of what activities the load circuitry 101 will perform. The scheduler 104 subsequently schedules these activities. The activity detector 103 provides a first output 108 that indicates what type of new activity has just been detected. This output 108 is provided to a multiplexer 110 which selects one of a plurality of weights, where, the selected weight is associated with the specific new activity that has just been detected.
Here, the load circuitry 101 is assumed to be designed to perform a number of different activities where each activity has a different amount of associated power consumption. For example, again referring to the DIMM card example above, reads and/or writes consume less power than memory bus transactions. As such, reads and/or writes will have associated weights that are less than the weight associated with a memory bus transaction. A weight is a numerical value that may be stored into a register or other circuit capable of holding state information (e.g., a read only memory). Reads may also have different weights than writes depending on the technology of the memory devices. More details concerning specific embodiments in this regard are discussed further below.
When a specific new activity event is therefore detected, a numerical value corresponding to its power consumption (its weight) is selected by the multiplexer 110 and forwarded to the credit pool count circuit 106. The value of the weight is then subtracted or added to the credit count depending on whether the new activity event corresponds to the initiation of the activity or the completion of the activity. For example, in the case of a memory bus transaction that is newly being requested from a host, the weight for the transaction will be subtracted from the credit count because the transaction has yet to happen. By contrast, in the case of a memory bus transaction that has just been completed, the value of the weight will be added to the credit count because the transaction has already occurred. Thus, decrements from the credit count correspond to power consumption yet to happen and increments to the credit count correspond to the additional power budget that is freed up after an activity completes (alternative embodiments may choose to implement an opposite approach where completions detract and new events increment up).
The activity event detection circuit 103 therefore also presents a second output 109 that indicates whether the new event corresponds to a new request for a new activity or notice that an older activity has completed. This output 110 determines whether the weight for the activity is processed by an additive channel or a subtractive channel within the credit pool count circuit 106. In the case of the additive channel, the weight is added to the current credit count value and the new credit count value is stored in register 107. In the case of the subtractive channel, the weight is subtracted from the current credit count value and the new credit count value is stored in register 107.
The current credit count value with register 107, which again corresponds to how much capacity the power supply has left to supply additional power, is provided to a first threshold detector 111 and an averaging circuit 112 with second threshold detector 113. The first threshold circuit 111 is used to prevent violations of the power supply's instantaneous power rating. Here, a first threshold value Thresh_l corresponds to a very low credit count value that is representative of very little additional power left in the power supply (if any). If the current credit count falls below the first threshold, comparator 111 will trip and a throttle down signal will be raised to the scheduler 104.
The averaging circuit 112 effectively averages the current credit count value with previous credit count values over a window of time in order to calculate an average power consumption for the load 101 that is supplied by the power supply 102. The average power consumption is then provided to a second threshold detection circuit 113 that is used to prevent violations of the power supply's sustained power rating. Here, a second threshold value
Thresh_2 corresponds to a credit count that is higher than the first threshold value (there is more power budget beyond the sustainable power rating than beyond the instantaneous power rating). However if the output of the averaging circuit 112 falls below the second threshold, the second comparator 113 will trip which will also raise a throttle down signal to the scheduler. Fig. 2 schematically shows an example of the behavior of the credit count 201 and the threshold comparators in response to a sustained activity level of the load circuit that is being supplied by the power supply without a corresponding completion of such activities. In the face of a stream of new activities without the completion of any of the same, the credit count 201 will steadily diminish over time. Likewise, the average credit count 202 will also diminish over time but at a slower rate because the average will be continually calculated within a window that includes higher credit values than the current credit count value.
The first threshold level (instantaneous power consumption) Thresh_l corresponds to a lower threshold than the second threshold level (sustained power consumption) Thresh_2. The first threshold level Thresh_l is compared against the current credit count 201 but not the average credit count 202. Likewise, the second threshold Thresh_2 is compared against the average credit count 202 but not the current credit count 201.
As observed in Fig. 2, the activity level of the load continues to increase until the credit count 201 reaches a level that is just shy of the first threshold level Thresh_l. Thereafter, the activity level of the circuit remains constant (e.g., the power draw from new activities is canceled out by the completion of older activities). As such, the instantaneous power consumption rating of the circuit is never offended (the first threshold Thresh_l is not crossed). If the activity level of the load did not level off and instead followed along trajectory 203, the first threshold would have tripped at time Tl.
However, because the activity level of the circuit is elevated (it remains constant just shy of the instantaneous threshold), the average credit count 202 will continue to fall (albeit at a slower rate once the activity level stops increasing). Eventually, at time T2, the average credit count 202 crosses the second threshold Thresh_2 which trips the second comparator and raises a throttle down signal to the scheduler. In response to the throttle down signal, the scheduler reduces the new activity level of the circuit (e.g., by inserting idles) which, e.g., will have the effect of accumulating completions of older activities without adding new ones, which adds to the current credit count. As such the current credit count begins to rise after time T2.
The higher credit count will eventually cause the average 202 to cross back over the second threshold level Thresh_2 (not shown). In response, the throttle down signal will no longer be raised. In various embodiments there may be some hysteresis circuitry applied at the throttle signal output to cause the throttle down signal to be released after the average credit count has risen above the second threshold by some margin to prevent thrashing of the throttle down signal. Such hysteresis may alternatively or in combination be integrated into the scheduler (e.g., the scheduler "back off new activities for an extended period of time to ensure the credit count will rise above the second threshold with sufficient margin). Similar and/or same principles may also be applied with respect to the first threshold Thresh_l and the current credit count.
Fig. 3 shows an embodiment 312 of the averaging circuit. In the averaging circuit embodiment 312 of Fig. 3, the averaging function is implemented as a discrete filter that operates on a stream of values that are representative of the instantaneous power. In particular, the low pass filter is mathematically represented as:
P(n+1) = P(n) - (P(n)/2K) + (W/2K) Eqn. 1
where P(n+1) is the average output for the next clock cycle, P(n) is the average output of the current clock cycle, W is the current clock cycle's instantaneous power and K is a value that establishes the bandwidth of the filter which can also be viewed as the size of the time window over which the average averages. Generally, as K increases, the size of the time window narrows and the averaging circuit output will more rapidly adjust to a change in instantaneous power. Contra-wise, as K decreases, the size of the time window increases and the averaging circuit output will less rapidly adjust to a change in instantaneous power.
In various embodiments, K is determined empirically based on the observed performance of a specific environment and/or some understanding of the overall environment. Generally, however, K should be chosen to "tune" the output of the averaging circuit to the actual capabilities of the power supply. Here, the greater the amount of time that the power supply can sustain operation near the instantaneous power limit, the smaller K can be. Contra- wise, the smaller the amount of time that the power supply can sustain operation near the instantaneous power limit, the higher K should be. The former will trip the averaging threshold later, the later will trip the averaging threshold sooner. In an embodiment, a register is used to hold the averaging circuit output value. A pair of shift registers are used to implement the 1/2K terms by shifting their respective operands (P(n) and W) to the right by K bits. K may be programed into the circuit by being kept in a software/firmware writable register that is coupled to both shift registers.
In further or alternative embodiments, the specific tuning of the output of the averaging circuit is designed to match the "3 droop" of the power supply to a sudden surge in current draw (such as might result from the sudden enablement of a master clock of the load circuit). The 3rd droop is essentially a form of time constant that characterizes the response dynamics of the power supply.
Fig. 4 shows a more specific embodiment to which the power management circuitry described above can be applied. Fig. 4 shows a dual in-line memory module (DIMM) 400 having a plurality of memory chips 401 which may be used, e.g., as system memory chips. System memory or main memory is the memory of a computing system that software operates directly out of. As is understood in the art, processors or processing cores have internal register space in which to hold instructions and data of the software routines being executed. The amount of register space is not infinite however and frequently system memory is invoked to read or write instructions or data of the executing software routines.
The DIMM card 401 of Fig. 4 may be implemented in various embodiments in a computing system having a multi-leveled system memory. A multi-leveled system memory is a memory with more than one distinct architectural level of different performance capabilities. For example, a lower second layer may be implemented with slower speed but higher density emerging system memory technology (discussed in more detail further below) and a higher first layer may be implemented with faster but less dense DRAM memory. The first layer may act as a cache for the lower second layer, or, may have its own system memory address space that is different than the system memory address space allocated to the second layer.
The DIMM 401 also includes a power management circuit 402 and power supply 403. The power supply 403 provides power to the memory chips 401. The activity of the memory chips is managed by a scheduler circuit 404 that is also on the DIMM. In various embodiments, the scheduler 404 determines when read and/or write requests are actually applied to the memory devices 401 and/or when responses to requests are provided on a memory bus 405. The power management circuit 402 provides throttle down signals 406 to the scheduler 404 consistent with the preceding discussions.
In various embodiments, transactions on the memory bus 405 to which the DIMM is connected are given a higher weight by the power management circuitry 402 than reads or writes from/to the memory devices 401. Further still, the memory bus transaction weights include a read or write weight and an on die termination weight. The later weight is added to any read or write weight when a memory bus transaction (read or write) occurs with on die termination enabled. Of course, the above is just one embodiment based on a particular type of memory bus and memory technology. Other embodiments and/or implementations may include low power memory bus transactions and high power memory reads and/or writes. In these embodiments, the weight for a read/write may be higher than the weight for a bus transaction.
In various embodiments, some or all of the memory devices 401 may be implemented with an emerging system memory technology such as a three dimensional cross-point memory technology (nonvolatile or otherwise). Three dimensional means the storage cells are arranged in three dimensions (e.g., in multiple stacked layers) rather than just along a plane (e.g., along a semiconductor substrate surface as with traditional DRAM or SRAM memory). Cross-point corresponds to an architecture in which storage cell locations are defined by overlapping wiring regions. Examples of such memory technologies include, to name a few possibilities, a phase change based memory (e.g., SXP or PCMS), a ferro-electric based memory (e.g., FRAM), a magnetic based memory (e.g., MRAM), a spin transfer torque based memory (e.g., STT-RAM), a resistor based memory (e.g., ReRAM) or a "Memristor" based memory. Cross-point memories may be byte addressable (e.g., if implemented as main memory of a computing system).
In various embodiments, the power management circuit 402 uses different weights for write operations and read operations. For example, in the case of phase change memories, more power is consumed by a write operation (e.g., because the storage cell media is heated) than a read operation (e.g., which does not heat the storage cell media). Additionally, there may be different types of writes (e.g., a nominal write, a refresh write, etc.). As such, depending on the write activity that is actually applied to the memory device, a different weight will be triggered to/from the credit pool by the power management circuit 402.
Further still, in yet other embodiments, different memory technology types may exist on a same DIMM. For example, two different types of emerging memory technology, or, emerging memory technology devices and DRAM devices may be resident on a same DIMM. The different memory technologies may have their own associated weights that are different from one another and that are accounted for in the design of the power management circuit 402. For example, a DRAM device may have its own weight for a read that is different than a phase change memory read where both DRAM and phase change memory are resident on a same DIMM and the power management circuit 402 incorporates both read weights. Likewise the DRAM may have its own associated write weight that is different than any of the phase change write weights.
Note also that the power management circuit 402 can be used to implement terms of service. For example, a customer may only pay for a certain amount of "performance" of a given circuit (memory DIMM or otherwise). The amount of service is reflected in the number of credits that are programmed into the credit pool with a lesser amount of performance/service corresponding to fewer credits and a greater amount of performance/service corresponding to a greater number of credits. The natural operation of the power management circuit will throttle the scheduler to schedule tasks consistently with the agreed to performance/service. The credit pool can be made programmable by coupling register 107 of Fig. 1 to a software/firmware register or implementing register 107 as a software/firmware visible register.
Although the above embodiments have been described in relation to a scheduler as the recipient of the throttle output of the power management circuit, note that a multitude of embodiments may contemplate another type of circuit other than a scheduler that has some impact on the amount of work done by a power supply's load. Examples include a circuit that issues instructions for execution, a circuit that sends traffic into a network, and a circuit that triggers execution of an application specific task (as opposed to execution of a program code instruction).
Although the above embodiments have been described in relation to a throttle down signal, more generally, the above teachings can also be applied to generate a throttle up signal. For example, in embodiments where higher credit counts correspond to more available power, instantaneous and/or averaging threshold circuits like those discussed above may be
implemented that trigger with rising rather than falling credit count. Such a throttle up signal may trigger the load device to become more active if sufficient room in the power budget exists as exemplified by a higher credit count value. Such throttle up threshold circuitry (e.g., an instantaneous credit count throttle up threshold and/or an average credit count throttle up threshold circuit) may exist with or without the aforementioned throttle down threshold circuits.
Fig. 5 shows an embodiment of a methodology performed by circuitry described herein. The method includes receiving an indication of an activity of load circuitry of a power supply 501. The method includes, in response to the indication, generating a first signal that describes the activity and a second signal that describes whether the event is initiating or completing 502. The method includes determining a weight amount from the first signal and adjusting a credit count by the weight amount up or down based on the second signal 503. The method includes comparing the credit count against a first threshold 504. The method includes calculating an average credit count that accounts for the credit count and previous credit counts and comparing the average credit count against a second threshold 505. The method includes reducing an activity level of the load circuitry if either threshold is crossed 506.
Fig. 6 shows a depiction of an exemplary computing system 600 such as a personal computing system (e.g., desktop or laptop) or a mobile or handheld computing system such as a tablet device or smartphone. As observed in Fig. 6, the basic computing system may include a central processing unit 601 (which may include, e.g., a plurality of general purpose processing cores and a main memory controller disposed on an applications processor or multi-core processor), system memory 602, a display 603 (e.g., touchscreen, flat-panel), a local wired point- to-point link (e.g., USB) interface 04, various network I/O functions 605 (such as an Ethernet interface and/or cellular modem subsystem), a wireless local area network (e.g., WiFi) interface 606, a wireless point-to-point link (e.g., Bluetooth) interface 607 and a Global Positioning
System interface 608, various sensors 609_1 through 609_N (e.g., one or more of a gyroscope, an accelerometer, a magnetometer, a temperature sensor, a pressure sensor, a humidity sensor, etc.), a camera 610, a battery 611, a power management control unit 612, a speaker and microphone 613 and an audio coder/decoder 614. The display 603 may be an LED display that is driven by an LED driver circuit as described herein. An applications processor or multi-core processor 650 may include one or more general purpose processing cores 615 within its CPU 601, one or more graphical processing units 616, a memory management function 617 (e.g., a memory controller) and an I/O control function 618. The general purpose processing cores 615 typically execute the operating system and application software of the computing system. The graphics processing units 616 typically execute graphics intensive functions to, e.g., generate graphics information that is presented on the display 603. The memory control function 617 interfaces with the system memory 602. The system memory 602 may be a multi-level system memory. During operation, data and/or instructions are typically transferred between a lowest level nonvolatile (e.g., "disk") storage 620 and system memory 602. The power management control unit 612 generally controls the power consumption of the system 600.
Each of the touchscreen display 603, the communication interfaces 604 - 607, the GPS interface 608, the sensors 609, the camera 610, and the speaker/microphone codec 613, 614 all can be viewed as various forms of I/O (input and/or output) relative to the overall computing system including, where appropriate, an integrated peripheral device as well (e.g., the camera 610). Depending on implementation, various ones of these I/O components may be integrated on the applications processor/multi-core processor 650 or may be located off the die or outside the package of the applications processor/multi-core processor 650.
Embodiments of the invention may include various processes as set forth above. The processes may be embodied in machine-executable instructions. The instructions can be used to cause a general-purpose or special-purpose processor to perform certain processes. Alternatively, these processes may be performed by specific hardware components that contain hardwired logic for performing the processes, or by any combination of programmed computer components and custom hardware components.
Elements of the present invention may also be provided as a machine-readable medium for storing the machine-executable instructions. The machine-readable medium may include, but is not limited to, floppy diskettes, optical disks, CD-ROMs, and magneto-optical disks, FLASH memory, ROMs, RAMs, EPROMs, EEPROMs, magnetic or optical cards, propagation media or other type of media/machine-readable medium suitable for storing electronic instructions. For example, the present invention may be downloaded as a computer program which may be transferred from a remote computer (e.g., a server) to a requesting computer (e.g., a client) by way of data signals embodied in a carrier wave or other propagation medium via a communication link (e.g., a modem or network connection).
In the foregoing specification, the invention has been described with reference to specific exemplary embodiments thereof. It will, however, be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.

Claims

Claims
1. An apparatus, comprising:
means for receiving an indication of an activity of load circuitry of a power supply; means for, in response to the indication, generating a first signal that describes the activity and a second signal that describes whether the event is initiating or completing;
means for determining a weight amount from the first signal and adjusting a credit count by the weight amount up or down based on the second signal;
means for comparing the credit count against a first threshold;
means for calculating an average credit count that accounts for the credit count and previous credit counts and comparing the average credit count against a second threshold; and means for adjusting an activity level of the load circuitry if either threshold is crossed.
2. The apparatus of claim 1 wherein the means for receiving, means for generating, means for determining, means for comparing, means for calculating and means for adjusting are all performed on a DIMM card.
3. The apparatus of claim 2 wherein the load circuitry includes memory devices.
4. The apparatus of claim 3 wherein the memory devices include three dimensional crosspoint memory devices.
5. The appartus of claim 4 wherein the memory devices also include DRAM memory devices.
6. The apparatus of claim 1 wherein the weight is selected from a group consisting of:
a read and/or write weight;
a memory bus transaction weight.
7. An apparatus, comprising:
a first circuit having an input to receive an indication of an activity of a load circuit of a power supply and outputs to provide, in response to the indication, a first signal that describes the activity and a second signal that describes whether the event is initiating or completing; a multiplexer to select a weight amount based on the first signal;
a credit count circuit to adjust a credit count by the weight amount up or down based on the second signal;
a first comparator to compare the credit count against a first threshold;
an average credit count circuit to calculate an average of the credit count and previous credit counts;
a second comparator to compare the average credit count against a second threshold; and a circuit to generate a throttle signal for the load circuitry's activity level if either threshold is crossed.
8. The apparatus of claim 7 wherein the credit count circuit includes a programmable register to store a programmed credit count amount.
9. The apparatus of claim 7 wherein the first circuit, the multiplexer, the credit count circuit, the first and second comparators, the average credit count circuit and the circuit to generate the throttle signal are disposed on a DIMM card.
10. The apparatus of claim 9 wherein the DIMM card includes three dimensional cross point memory devices.
11. The apparatus of claim 10 wherein the three dimensional cross point memory devices are nonvolatile memory devices.
12. The apparatus of claim 10 wherein the DIMM card also includes DRAM memory devices.
13. The apparatus of claim 9 wherein the circuit to generate a throttle signal is coupled to a scheduler that schedules activities for the memory devices.
14. The apparatus of claim 7 wherein the circuit to generate a throttle signal is coupled to any of:
a circuit to issue instructions to be executed;
a circuit to send traffic into a network;
a circuit to trigger an application specific circuit into action.
15. A computing system, comprising:
a DIMM card having the following:
a first circuit having an input to receive an indication of an activity of a load circuit of a power supply and outputs to provide, in response to the indication, a first signal that describes the activity and a second signal that describes whether the event is initiating or completing; a multiplexer to select a weight amount based on the first signal;
a credit count circuit to adjust a credit count by the weight amount up or down based on the second signal;
a first comparator to compare the credit count against a first threshold;
an average credit count circuit to calculate an average of the credit count and previous credit counts;
a second comparator to compare the average credit count against a second threshold; and a circuit to generate a throttle signal for the load circuitry's activity level if either threshold is crossed.
16. The computing system of claim 15 wherein the DIMM card is part of a multi-level system memory.
17. The computing system of claim 15 wherein the DIMM card includes three dimensional cross point memory devices.
18. The computing system of claim 17 wherein the three dimensional cross point memory devices are nonvolatile memory devices.
19. The computing system of claim 17 wherein the DIMM card also includes DRAM memory devices.
20. The computing system of claim 17 wherein the circuit to generate a throttle signal is coupled to a scheduler that schedules activities for the memory devices.
PCT/US2016/034071 2015-06-26 2016-05-25 Power management circuit with per activity weighting and multiple throttle down thresholds WO2016209494A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
EP16814953.2A EP3314365B1 (en) 2015-06-26 2016-05-25 Power management circuit with per activity weighting and multiple throttle down thresholds
CN201680029895.9A CN107646106B (en) 2015-06-26 2016-05-25 Power management circuit with per-activity weighting and multiple throttle down thresholds

Applications Claiming Priority (2)

Application Number Priority Date Filing Date Title
US14/751,846 2015-06-26
US14/751,846 US10073659B2 (en) 2015-06-26 2015-06-26 Power management circuit with per activity weighting and multiple throttle down thresholds

Publications (1)

Publication Number Publication Date
WO2016209494A1 true WO2016209494A1 (en) 2016-12-29

Family

ID=57586067

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/US2016/034071 WO2016209494A1 (en) 2015-06-26 2016-05-25 Power management circuit with per activity weighting and multiple throttle down thresholds

Country Status (4)

Country Link
US (1) US10073659B2 (en)
EP (1) EP3314365B1 (en)
CN (1) CN107646106B (en)
WO (1) WO2016209494A1 (en)

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10459517B2 (en) 2017-03-31 2019-10-29 Qualcomm Incorporated System and methods for scheduling software tasks based on central processing unit power characteristics

Families Citing this family (9)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10048738B2 (en) * 2016-03-03 2018-08-14 Intel Corporation Hierarchical autonomous capacitance management
WO2019066928A1 (en) * 2017-09-29 2019-04-04 Intel Corporation Power monitoring for a processing platform
US11466564B2 (en) * 2018-06-13 2022-10-11 Halliburton Energy Services, Inc. Systems and methods for downhole memory tool activation and control
US11216276B2 (en) * 2018-12-27 2022-01-04 Intel Corporation Controlling power state demotion in a processor
US11048323B2 (en) 2019-04-29 2021-06-29 Apple Inc. Power throttling in a multicore system
US11287865B2 (en) * 2019-06-14 2022-03-29 Microchip Technology Incorporated USB hub with integrated power and thermal management
US11586272B2 (en) * 2019-09-27 2023-02-21 Qualcomm Incorporated Power control based on performance modification through pulse modulation
CN111949100B (en) * 2020-09-01 2023-02-28 深圳大普微电子科技有限公司 Temperature control method, device and equipment of memory and storage medium
US20220413584A1 (en) * 2021-06-25 2022-12-29 Advanced Micro Devices, Inc. System and method for controlling power consumption in processor using interconnected event counters and weighted sum accumulators

Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050254519A1 (en) * 2004-05-13 2005-11-17 International Business Machines Corporation Dynamic load-based credit distribution
US20060248355A1 (en) * 2005-04-27 2006-11-02 Thayer Larry J Power throttling system and method for a memory controller
US20080320323A1 (en) * 2005-02-09 2008-12-25 International Business Machines Corporation Power management via dimm read operation limiter
US20090138733A1 (en) * 2005-10-03 2009-05-28 Bradley Dean Winick System and Method for Throttling Memory Power Consumption
US20100169690A1 (en) * 2008-12-31 2010-07-01 Gopal Mundada System power management using memory throttle signal
WO2013095531A1 (en) 2011-12-22 2013-06-27 Intel Corporation Mechanism for facilitating power and performance management of non-volatile memory in computing devices

Family Cites Families (68)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5752050A (en) 1994-10-04 1998-05-12 Intel Corporation Method and apparatus for managing power consumption of external devices for personal computers using a power management coordinator
US6470238B1 (en) * 1997-11-26 2002-10-22 Intel Corporation Method and apparatus to control device temperature
US5912839A (en) 1998-06-23 1999-06-15 Energy Conversion Devices, Inc. Universal memory element and method of programming same
US6496536B2 (en) * 1999-03-25 2002-12-17 Qualcomm, Incorporated System and method for estimating power
US6564328B1 (en) * 1999-12-23 2003-05-13 Intel Corporation Microprocessor with digital power throttle
US7096145B2 (en) 2002-01-02 2006-08-22 Intel Corporation Deterministic power-estimation for thermal control
US7475174B2 (en) 2004-03-17 2009-01-06 Super Talent Electronics, Inc. Flash / phase-change memory in multi-ring topology using serial-link packet interface
US7590918B2 (en) 2004-09-10 2009-09-15 Ovonyx, Inc. Using a phase change memory as a high volume memory
US7430672B2 (en) 2004-10-27 2008-09-30 Intel Corporation Method and apparatus to monitor power consumption of processor
US7596707B1 (en) * 2005-05-06 2009-09-29 Sun Microsystems, Inc. System and method for efficient power throttling in multiprocessor chip
US20070005922A1 (en) 2005-06-30 2007-01-04 Swaminathan Muthukumar P Fully buffered DIMM variable read latency
KR100670674B1 (en) * 2005-06-30 2007-01-17 주식회사 하이닉스반도체 Semiconductor memory deivce
US7560956B2 (en) * 2005-08-03 2009-07-14 Micron Technology, Inc. Method and apparatus for selecting an operating mode based on a determination of the availability of internal clock signals
US7600078B1 (en) 2006-03-29 2009-10-06 Intel Corporation Speculatively performing read transactions
US7913147B2 (en) 2006-05-08 2011-03-22 Intel Corporation Method and apparatus for scrubbing memory
US7756053B2 (en) 2006-06-30 2010-07-13 Intel Corporation Memory agent with error hardware
US7493439B2 (en) 2006-08-01 2009-02-17 International Business Machines Corporation Systems and methods for providing performance monitoring in a memory system
WO2008040028A2 (en) 2006-09-28 2008-04-03 Virident Systems, Inc. Systems, methods, and apparatus with programmable memory control for heterogeneous main memory
US7681054B2 (en) 2006-10-03 2010-03-16 International Business Machines Corporation Processing performance improvement using activity factor headroom
WO2008131058A2 (en) 2007-04-17 2008-10-30 Rambus Inc. Hybrid volatile and non-volatile memory device
US20080270811A1 (en) 2007-04-26 2008-10-30 Super Talent Electronics Inc. Fast Suspend-Resume of Computer Motherboard Using Phase-Change Memory
US8429493B2 (en) 2007-05-12 2013-04-23 Apple Inc. Memory device with internal signap processing unit
CN101075999B (en) * 2007-05-31 2011-06-29 西安电子科技大学 TOA training symbol construction of indoor OFDM system and method and device for estimating TOA
US8041521B2 (en) 2007-11-28 2011-10-18 International Business Machines Corporation Estimating power consumption of computing components configured in a computing system
US8719606B2 (en) 2008-03-31 2014-05-06 Intel Corporation Optimizing performance and power consumption during memory power down state
US20090313416A1 (en) 2008-06-16 2009-12-17 George Wayne Nation Computer main memory incorporating volatile and non-volatile memory
US8230238B2 (en) 2008-08-25 2012-07-24 International Business Machines Corporation Estimating power consumption in a computing environment
JP5231149B2 (en) * 2008-09-25 2013-07-10 株式会社ジャムコ Power frequency converter
US8190930B2 (en) * 2009-03-30 2012-05-29 Intel Corporation Methods and apparatuses for controlling thread contention
US8331857B2 (en) 2009-05-13 2012-12-11 Micron Technology, Inc. Wireless interface to program phase-change memories
US8250282B2 (en) 2009-05-14 2012-08-21 Micron Technology, Inc. PCM memories for storage bus interfaces
US8504759B2 (en) 2009-05-26 2013-08-06 Micron Technology, Inc. Method and devices for controlling power loss
US20100306453A1 (en) 2009-06-02 2010-12-02 Edward Doller Method for operating a portion of an executable program in an executable non-volatile memory
US9123409B2 (en) 2009-06-11 2015-09-01 Micron Technology, Inc. Memory device for a hierarchical memory architecture
CN102597910B (en) * 2009-09-09 2015-03-25 弗森-艾奥公司 Apparatus, system, and method for power reduction management in a storage device
US8335123B2 (en) * 2009-11-20 2012-12-18 Sandisk Technologies Inc. Power management of memory systems
US8914568B2 (en) 2009-12-23 2014-12-16 Intel Corporation Hybrid memory architectures
US8612809B2 (en) 2009-12-31 2013-12-17 Intel Corporation Systems, methods, and apparatuses for stacked memory
US20110208900A1 (en) 2010-02-23 2011-08-25 Ocz Technology Group, Inc. Methods and systems utilizing nonvolatile memory in a computer system main memory
KR20110131781A (en) 2010-05-31 2011-12-07 삼성전자주식회사 Method for presuming accuracy of location information and apparatus for the same
US8412479B2 (en) 2010-06-29 2013-04-02 Intel Corporation Memory power estimation by means of calibrated weights and activity counters
US8838935B2 (en) 2010-09-24 2014-09-16 Intel Corporation Apparatus, method, and system for implementing micro page tables
US8649212B2 (en) 2010-09-24 2014-02-11 Intel Corporation Method, apparatus and system to determine access information for a phase change memory
US8612676B2 (en) 2010-12-22 2013-12-17 Intel Corporation Two-level system main memory
US8462577B2 (en) 2011-03-18 2013-06-11 Intel Corporation Single transistor driver for address lines in a phase change memory and switch (PCMS) array
US8462537B2 (en) 2011-03-21 2013-06-11 Intel Corporation Method and apparatus to reset a phase change memory and switch (PCMS) memory cell
US8635483B2 (en) * 2011-04-05 2014-01-21 International Business Machines Corporation Dynamically tune power proxy architectures
US8607089B2 (en) 2011-05-19 2013-12-10 Intel Corporation Interface for storage device access over memory bus
US8605531B2 (en) 2011-06-20 2013-12-10 Intel Corporation Fast verify for phase change memory with switch
US8694719B2 (en) * 2011-06-24 2014-04-08 Sandisk Technologies Inc. Controller, storage device, and method for power throttling memory operations
US8463948B1 (en) 2011-07-01 2013-06-11 Intel Corporation Method, apparatus and system for determining an identifier of a volume of memory
CN103946812B (en) 2011-09-30 2017-06-09 英特尔公司 Apparatus and method for realizing multi-level memory hierarchy
US9342453B2 (en) 2011-09-30 2016-05-17 Intel Corporation Memory channel that supports near memory and far memory access
CN103946813B (en) 2011-09-30 2017-08-25 英特尔公司 Generation based on the remote memory access signals followed the trail of using statistic
WO2013048483A1 (en) 2011-09-30 2013-04-04 Intel Corporation Platform storage hierarchy with non-volatile random access memory having configurable partitions
CN103946811B (en) 2011-09-30 2017-08-11 英特尔公司 Apparatus and method for realizing the multi-level store hierarchy with different operation modes
EP2761480A4 (en) 2011-09-30 2015-06-24 Intel Corp Apparatus and method for implementing a multi-level memory hierarchy over common memory channels
US9378133B2 (en) 2011-09-30 2016-06-28 Intel Corporation Autonomous initialization of non-volatile random access memory in a computer system
WO2013048490A1 (en) 2011-09-30 2013-04-04 Intel Corporation Non-volatile random access memory (nvram) as a replacement for traditional mass storage
WO2013048491A1 (en) 2011-09-30 2013-04-04 Intel Corporation Apparatus, method and system that stores bios in non-volatile random access memory
EP2761471B1 (en) 2011-09-30 2017-10-25 Intel Corporation Statistical wear leveling for non-volatile system memory
US9530461B2 (en) 2012-06-29 2016-12-27 Intel Corporation Architectures and techniques for providing low-power storage mechanisms
US8935578B2 (en) 2012-09-29 2015-01-13 Intel Corporation Method and apparatus for optimizing power and latency on a link
US20140359196A1 (en) 2013-05-31 2014-12-04 Daniel J. Ragland On-the-fly performance adjustment for solid state storage devices
US20150033045A1 (en) * 2013-07-23 2015-01-29 Apple Inc. Power Supply Droop Reduction Using Feed Forward Current Control
US9568978B2 (en) 2013-09-26 2017-02-14 Intel Corporation Controlling power consumption in processor-based systems and components thereof
US20160054779A1 (en) 2014-08-22 2016-02-25 Devadatta Bodas Managing power performance of distributed computing systems
US9588823B2 (en) 2014-12-24 2017-03-07 Intel Corporation Adjustment of execution of tasks

Patent Citations (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20050254519A1 (en) * 2004-05-13 2005-11-17 International Business Machines Corporation Dynamic load-based credit distribution
US20080320323A1 (en) * 2005-02-09 2008-12-25 International Business Machines Corporation Power management via dimm read operation limiter
US20060248355A1 (en) * 2005-04-27 2006-11-02 Thayer Larry J Power throttling system and method for a memory controller
US20090138733A1 (en) * 2005-10-03 2009-05-28 Bradley Dean Winick System and Method for Throttling Memory Power Consumption
US20100169690A1 (en) * 2008-12-31 2010-07-01 Gopal Mundada System power management using memory throttle signal
WO2013095531A1 (en) 2011-12-22 2013-06-27 Intel Corporation Mechanism for facilitating power and performance management of non-volatile memory in computing devices

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See also references of EP3314365A4

Cited By (1)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10459517B2 (en) 2017-03-31 2019-10-29 Qualcomm Incorporated System and methods for scheduling software tasks based on central processing unit power characteristics

Also Published As

Publication number Publication date
CN107646106B (en) 2022-03-08
US10073659B2 (en) 2018-09-11
EP3314365A1 (en) 2018-05-02
US20160378172A1 (en) 2016-12-29
CN107646106A (en) 2018-01-30
EP3314365B1 (en) 2020-04-01
EP3314365A4 (en) 2019-02-27

Similar Documents

Publication Publication Date Title
EP3314365B1 (en) Power management circuit with per activity weighting and multiple throttle down thresholds
US9229525B2 (en) Adaptive latency tolerance for power management of memory bus interfaces
US9575677B2 (en) Storage system power management using controlled execution of pending memory commands
TWI628537B (en) Managing power consumption in a multi-core processor
TWI512474B (en) Electronic system and method of bandwidth management
US9727267B1 (en) Power management and monitoring for storage devices
US9916104B2 (en) Techniques for entry to a lower power state for a memory device
US9746902B2 (en) System-on-chip including multi-core processor and dynamic power management method thereof
CN107408018B (en) Mechanism for adapting garbage collection resource allocation in solid state drives
CN105308571A (en) Dynamic voltage and frequency management based on active processors
TW201229743A (en) Methods and systems for dynamically controlling operations in a non-volatile memory to limit power consumption
TW201407346A (en) Thermal control apparatus and methodology
US11847008B2 (en) Technologies for providing efficient detection of idle poll loops
US10345885B2 (en) Power control of a memory device through a sideband channel of a memory bus
US20190042451A1 (en) Efficient usage of bandwidth of devices in cache applications
US10095432B2 (en) Power management and monitoring for storage devices
KR20200137981A (en) Nvram memory module with hard write throttle down
CN104798002B (en) Implement power consumption dutycycle within a processor
US20210325956A1 (en) Techniques to reduce memory power consumption during a system idle state
US20180188797A1 (en) Link power management scheme based on link's prior history
WO2022155970A1 (en) Memory control method and memory control apparatus
US11055228B2 (en) Caching bypass mechanism for a multi-level memory
US11768531B2 (en) Power management for storage controllers
US10956057B2 (en) Adaptive power management of dynamic random access memory
US9600205B1 (en) Power aware power safe write buffer

Legal Events

Date Code Title Description
121 Ep: the epo has been informed by wipo that ep was designated in this application

Ref document number: 16814953

Country of ref document: EP

Kind code of ref document: A1

NENP Non-entry into the national phase

Ref country code: DE