US20050149768A1 - Method and an apparatus for power management in a computer system - Google Patents
Method and an apparatus for power management in a computer system Download PDFInfo
- Publication number
- US20050149768A1 US20050149768A1 US10/749,855 US74985503A US2005149768A1 US 20050149768 A1 US20050149768 A1 US 20050149768A1 US 74985503 A US74985503 A US 74985503A US 2005149768 A1 US2005149768 A1 US 2005149768A1
- Authority
- US
- United States
- Prior art keywords
- threshold
- processor
- transactions
- memory controller
- power state
- Prior art date
- Legal status (The legal status 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 status listed.)
- Granted
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
- G06F1/32—Means for saving power
- G06F1/3203—Power management, i.e. event-based initiation of a power-saving mode
- G06F1/3206—Monitoring of events, devices or parameters that trigger a change in power modality
- G06F1/3215—Monitoring of peripheral devices
-
- G—PHYSICS
- G06—COMPUTING OR CALCULATING; COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/26—Power supply means, e.g. regulation thereof
- G06F1/32—Means for saving power
Definitions
- the present invention relates to computing technology, and more particularly, to power management in a computer system.
- a central processing unit (CPU) of the system supports various power states to allow robust power management in the system.
- a CPU may support five power states, such as the C0, C1, C2, C3, and C4 states.
- the C0 state is an active power state, in which the CPU executes instructions, while the remaining states, i.e., the C1, C2, C3, and C4 states, are sleeping states.
- the CPU consumes less power and dissipates less heat than in the C0 state because the CPU does not execute any instruction while in the sleeping states.
- the power consumption in the C4 state is generally less than the power consumption in the C3 state because the CPU supply voltage is lowered when the CPU enters into the C4 state.
- Each sleeping state has a latency associated with entering and exiting and is related to the power saving in each state.
- the more circuitry or logic being shutdown to save more power the more effort and longer exit latency are consumed to re-energize the circuitry and/or logic shutdown.
- the phase lock loop (PLL) and input/output (IO) of a CPU can be shut down to save more power when the CPU is in the C3 or C4 state because the CPU does not snoop while in the C3 or C4 state.
- PLL phase lock loop
- IO input/output
- the CPU can access the memory during the C0 state or snoop bus-master initiated memory traffic while in the C1 or C2 state.
- the bus master is a peripheral device having control of the bus at a given time, such as, for example, an external graphic core.
- the data movement from one device to another over a bus is, therefore, referred to as a bus mastering event.
- the CPU suspends snooping or memory access as part of the deeper sleep states.
- a CPU in either the C3 or C4 state has to exit the C3 or C4 state.
- the system has to verify whether there is an on-going bus mastering event from any peripheral device in the system that may require the CPU to snoop before entering either the C3 or C4 state. If there is an on-going bus mastering event, the CPU has to settle for a power state (e.g., C1 or C2) with higher power consumption but lower exit latency than the C3 or C4 state.
- a power state e.g., C1 or C2
- a peripheral device it may be coupled to the CPU through a root complex device via a serial interconnect, such as a PCI Express interconnect.
- a root complex device includes a host bridge and one or more root ports. Examples of a root complex device include a memory controller or IO controller functional device.
- An interconnect is an infrastructure that couples one device to another.
- PCI Express is a high speed, point-to-point serial interconnect standard. For example, the first generation of PCI Express interconnect supports 2.5 Gb/sec per lane data transmission.
- a graphic device is coupled to a chipset of the system (e.g., a memory controller hub) through a 16-lane PCI Express interconnect.
- PCI Express allows flow control by supporting an accounting scheme with credits to keep track of the traffic over a PCI Express interconnect.
- the credits indicate the available buffering in a device for various types of transactions over an interconnect.
- a memory controller can report to the software of the capability of a root complex device to transmit data by writing the information in a number of registers.
- there are a number of prescribed credits for various transactions such as, read request, write request, completion, etc.
- a graphic device issues transactions (e.g., read requests) towards the root complex device and these transactions are pending
- a credit is consumed to reflect the amount of buffering taken up in the memory controller by the pending transactions.
- the credit is released or freed up.
- the number of pending transactions, as reflected by the credits consumed indicates the likelihood of a bus mastering event that may prohibit entry into the C3 or C4 state.
- a prior art technique to indicate on-going bus mastering traffic uses a sideband signal.
- a graphic device sends a signal AGP_BUSY to the root complex device of the computer system to indicate on-going bus mastering traffic for the system that attaches the graphic device using Accelerated Graphics Port (AGP).
- AGP Accelerated Graphics Port
- the sideband signals are costly because they require one additional pin per sideband signal on each device.
- permanent connector infrastructure has to be provided for the sideband signals in the system even though future technological innovation may not use such sideband signals at all.
- FIG. 1A shows a flow diagram of one embodiment of a process to manage power in a computer system.
- FIG. 1B shows a flow diagram of one embodiment of a process to manage power in a computer system.
- FIG. 2A illustrates one embodiment of an entry threshold.
- FIG. 2B illustrates one embodiment of an exit threshold.
- FIGS. 3A-3C illustrate various embodiments of chipset partition.
- FIG. 4 shows an exemplary embodiment of a computer system.
- a method and an apparatus for power management in a computer system are disclosed.
- the method includes monitoring transactions over an interconnect coupling a chipset device and a peripheral device in the computer system, the transactions being transmitted between the peripheral device and the chipset device following a flow control protocol that allows the chipset device to keep track of the transactions.
- the embodiment further includes causing a processor in the computer system to exit from a power state if a number of coherent transactions pending in a buffer of the chipset device exceed a predetermined threshold.
- the flow control protocol is PCI Express.
- FIG. 1A shows a flow diagram of one embodiment of a process to manage power in a computer system.
- the process is performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, etc.), software (such as is run on a general purpose computer system or a dedicated machine), or a combination of both.
- processing logic may comprise hardware (e.g., circuitry, dedicated logic, etc.), software (such as is run on a general purpose computer system or a dedicated machine), or a combination of both.
- an exemplary CPU may not initiate memory access or snoop bus-master initiated traffic while in the C3 or C4 state. Therefore, in response to a CPU request to enter either the C3 or C4 state (processing block 101 ), processing logic performs a series of operations to determine whether the peripheral devices in the system are likely to request the CPU to snoop a bus master or accesses directly to system memory without snooping.
- Processing logic may receive a transaction 103 from one of the peripheral devices (processing block 104 ).
- the transaction 103 may be coherent or incoherent.
- a coherent transaction involves data currently or likely being used or modified in the cache of the CPU.
- an incoherent transaction involves data from the memory and the data is currently not being stored, used, or modified in the cache of the CPU.
- processing logic checks whether the transaction 103 received is coherent or there is any pending coherent transaction in a memory controller in the computer system (processing block 110 ). If either is true, then processing logic asserts a bus mastering indicator to prevent the CPU from entering the C3 or C4 state (processing block 130 ). In one embodiment, the CPU then enters into a default state, which may be the C1 or C2 state.
- processing logic consumes a number of credits to reflect the portion of buffer in the memory controller taken up by the incoherent transaction 103 and holds the transaction 103 as pending (processing block 112 ).
- Processing logic may check whether the total number of credits consumed exceeds or equals to an entry threshold (processing block 120 ). If the total number of credits consumed exceeds or equals to the entry threshold, the portion of the buffer in the root complex device filled by the pending transactions has exceeded a certain level corresponding to the entry threshold. With less available buffering in the memory controller, the peripheral device is less likely to send additional transactions to the memory controller.
- processing logic de-asserts the bus mastering indicator to allow the CPU to enter into either the C3 or C4 state (processing block 129 ).
- processing logic may check whether a timer has expired (processing block 122 ). If the timer has expired, processing logic de-asserts the bus mastering indicator to allow the CPU to enter into either the C3 or C4 state (processing block 130 ). Otherwise, processing logic repeats processing block 110 . Alternatively, processing logic may not check the timer at all and may simply repeat processing block 110 upon the determination that the total number of consumed credits is below the entry threshold.
- FIG. 2A illustrates one embodiment of the entry threshold.
- the entry threshold 210 may be set to modify the bus mastering indicator to cause an exemplary CPU to enter into the C3 or C4 state even when there are pending incoherent transactions in the root complex device.
- the transactions may be intentionally held pending in the memory controller with no service attempted until the number of credits consumed exceeds or equals to the entry threshold 210 in order to defer asserting the bus mastering indicator to the CPU.
- the CPU has more opportunities to enter into either the C3 or C4 state to reduce average CPU power consumption.
- the entry threshold 210 may be set at 0% for highly performance sensitive applications, such as graphic applications.
- the entry threshold may be set at different values depending on the amount of charge remaining in one or more batteries of the system when the system is running solely on such batteries. It is noted that the tradeoff for lower CPU power consumption may be degraded CPU performance state. Furthermore, in one embodiment, a timer is used to qualify how long to stall servicing the initial pending transaction in order to mitigate the impact of the tradeoff on some latency sensitive applications. If the timer expires before the entry threshold 210 is reached, then the bus mastering indicator may be reset to allow the CPU to enter the C3 or C4 state for light traffic or idle cases.
- FIG. 1B shows a flow diagram of one embodiment of a process to manage power in a computer system.
- the process is performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, etc.), software (such as is run on a general purpose computer system or a dedicated machine), or a combination of both.
- processing logic may receive a coherent transaction from a peripheral device (processing block 140 ). Examples of the peripheral device include an external graphic core, an Ethernet controller, etc.
- processing logic consumes a number of credits to reflect the portion of buffer taken up by the coherent transaction received (processing block 142 ).
- processing logic checks whether the total number of consumed credits for the coherent transactions exceeds or equals to an exit threshold (processing block 144 ). If the total number of the consumed credits exceeds or equals to the exit threshold, processing logic causes the CPU to exit from either the C3 or C4 state (processing block 150 ). Processing logic may send a signal to the CPU to instruct the CPU to exit from either the C3 or C4 state. After exiting from the C3 or C4 state, in one embodiment, the CPU enters the C0 state.
- processing logic checks whether a timer has expired (processing block 146 ). If the timer has expired, processing logic causes the CPU to exit from either the C3 or C4 state (processing block 150 ). Otherwise, processing logic queues up the transaction (processing block 148 ) and repeats processing block 140 . Alternatively, processing logic may not check the timer at all and may simply queue up the transaction (processing block 148 ) and repeat processing block 140 upon the determination that the total number of consumed credits is below the exit threshold.
- FIG. 2B illustrates one embodiment of the exit threshold.
- the exit threshold 250 is set to decide when to set the bus mastering indicator to cause an exemplary CPU to exit from either the C3 or C4 state. Transactions may be queued up when the CPU is in the C3 or C4 state to allow the CPU to spend a certain period of time in the C3 or C4 state in order to achieve a certain level of power saving. If the number of consumed credits is below the exit threshold 250 , then the CPU is held off from being notified that an exit condition has occurred. In one embodiment, a timer is used to qualify how long to stall servicing the initial pending transactions if the applications are latency sensitive.
- the exit threshold 250 may be set at 0% in order to meet the performance specifications of such applications.
- the exit threshold 250 is set at different values depending on the remaining battery charge capacity in the system when the battery alone powers the system.
- the entry threshold substantially equals to the exit threshold.
- the entry and exit thresholds may be hardwired to a single value at 0%.
- the entry and exit thresholds are set at different values. For instance, the entry threshold may be higher than the exit threshold. Furthermore, allowing the entry and exit thresholds to be set at different values on the fly enables the CPU to adjust performance based on the remaining battery charge capacity.
- the CPU may modify the entry and exit behavior of the CPU adaptively through threshold modification. Adaptive modification of the entry and exit thresholds allows the CPU to steer away from frequent thrashing of low power states because of certain periodic traffic that may coincide with the timing of the C3 or C4 state entry decision. Another advantage is to provide for asymmetric entry and exit behavior to tune and increase the residency period of the CPU in either the C3 or C4 state.
- the CPU may take hundreds of microseconds to exit the C3 or C4 state, during which a phase lock loop of the CPU may consume twice the power consumed during the initial ten microseconds to spin up. Therefore, if the C3 or C4 residency of the CPU is less than the exit latency, the net effect may be little or negligible power saving, or worse, more power consumption.
- FIGS. 3A-3C illustrate various embodiments of chipset partitions in a computer system.
- FIG. 3A shows a memory controller 310 , an input/output controller 320 , and power management circuitry 330 .
- the power management circuitry 330 is outside of both the memory controller 310 and the input/output controller 320 .
- the memory controller 310 is coupled to the input/output controller 320 via a link 315 .
- the link 315 may include a digital media interface (DMI) link.
- the memory controller 310 is further coupled to one or more peripheral devices (not shown) via one or more buses or interconnects (not shown) that adopt a protocol with a credit-based flow control accounting scheme, such as, for example, PCI Express.
- DMI digital media interface
- the power management circuitry 330 communicates with the memory controller 310 and/or the input/output controller 320 via the sideband signals 322 and 324 .
- the sideband signals 332 and 334 indicate whether there is any bus mastering activity from a peripheral device, such as an advance graphic port (AGP).
- AGP advance graphic port
- the sideband signals 332 and 334 are typically denoted as XX_BUSY.
- the sideband signal corresponding to the AGP is denoted as AGP_BUSY.
- the sideband signals may include one or more shared signals.
- one of the memory controller 310 and the input/output controller 320 acts as a central agent to roll up the bus mastering activity information through one or more message packets sent between the memory controller 310 and the input/output controller 320 .
- the message packets may include DMI message packets 325 .
- the central agent still communicates with the power management circuitry 330 via one of the sideband signals 334 and 332 .
- FIG. 3B shows an alternate embodiment of chipset partition in a computer system.
- the chipset in FIG. 3B includes a memory controller 340 and an input/output controller 350 coupling to each other via a link 345 , which may include a DMI link.
- a link 345 which may include a DMI link.
- the memory controller 340 is further coupled to a peripheral device (not shown) via an interconnect (not shown) adopting a credit-based flow control accounting scheme, such as, for example, PCI Express.
- the peripheral device may include an external graphic core, an Ethernet controller, etc.
- the input/output controller 350 includes power management circuitry 352 to monitor data traffic over the interconnect.
- the memory controller 340 Since the power management circuitry 352 is internal to the input/output controller 350 , the memory controller 340 has to communicate to the input/output controller 350 on whether the peripheral device has any on-going traffic over the interconnect. In one embodiment, the memory controller 340 sets one or more bits in a message packet 347 sent via the link 345 to the input/output controller 350 .
- the message packet 347 may be a DMI packet. Setting the bit(s) in the message packet 347 is also referred to as in-band virtualization of the bus mastering indicator signal, as opposed to the sideband signals (e.g., sideband signals 332 and 334 in FIG. 3A ), because the signal is abstracted to eliminate the pin and connector infrastructure on both of the controllers 340 and 350 .
- the power management circuitry 352 may also monitor the bus mastering activity from other peripheral devices (not shown) coupled to the input/output controller 350 via other interconnects (not shown).
- FIG. 3C shows an alternate embodiment of a chipset partition in a computer system.
- the chipset shown in FIG. 3C includes an integrated memory and input/output controller 360 .
- the integrated memory and input/output controller 360 includes internal power management circuitry 365 . Since the power management circuitry 365 is part of the integrated controller 360 , the bus mastering indications for peripheral devices coupled to the controller 360 may be internally registered through logic circuitry within the controller 360 .
- FIGS. 3A-3C are merely shown to illustrate the technique disclosed. The technique disclosed may be applied to other embodiments of computer chipset partition.
- FIG. 4 shows an exemplary embodiment of a computer system 400 .
- the computer system 400 includes a central processing unit (CPU) 410 , a memory controller (MCH) 420 , a number of dual in-line memory modules (DIMMs) 425 , a number of memory devices 427 , a PCI Express graphic port 430 , an input/output controller (ICH) 440 , a number of Universal Serial Bus (USB) ports 445 , an audio coder-decoder (AUDIO CODEC) 460 , a Super Input/Output (Super I/O) 450 , and a firmware hub (FWH) 470 .
- CPU central processing unit
- MCH memory controller
- DIMMs dual in-line memory modules
- ICH input/output controller
- USB Universal Serial Bus
- AUDIO CODEC audio coder-decoder
- Super I/O Super I/O
- FWH firmware hub
- the CPU 410 , the PCI Express graphic port 430 , the DIMMs 425 , and the ICH 440 are coupled to the MCH 420 .
- the link 435 between the MCH 420 and the ICH 440 may include a DMI link.
- the MCH 420 routes data to and from the memory devices 427 via the DIMMs 425 .
- the memory devices 427 may include various types of memories, such as, for example, dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), double data rate (DDR) SDRAM, or flash memory.
- each of the DIMMs 425 is mounted on the same motherboard (not shown) via a DIMM connector (not shown) in order to couple to the MCH 420 .
- the USB ports 445 , the AUDIO CODEC 460 , and the Super I/O 450 are coupled to the ICH 440 .
- the Super I/O 450 may be further coupled to a firmware hub 470 , a floppy disk drive 451 , data input devices 453 , such as, a keyboard, a mouse, etc., a number of serial ports 455 , and a number of parallel ports 457 .
- the ICH 440 includes power management circuitry 442 to monitor data traffic over various interconnects coupling the ICH 440 and the MCH 420 to the peripheral devices, such as, for example, the PCI Express graphic port 430 .
- the power management circuitry 442 may generate a bus mastering indicator to be sent as a virtualized signal within a message packet 437 from the MCH 420 to the ICH 440 via the link 435 .
- the MCH 420 and the ICH 440 may be integrated into a single controller with power management circuitry such that the bus mastering indicator may be internally registered through logic.
- the MCH 420 and the ICH 440 remain as separate devices and the power management circuitry is external to both of the MCH 420 and the ICH 440 .
- Either one of the MCH 420 and the ICH 440 may act as a central agent to roll up information of bus traffic from the peripheral devices in the system 400 from the other controller using message packets sent between the controllers 420 and 440 .
- the central agent may communicate the information to the external power management circuitry via one or more sideband signals.
- any or all of the components and the associated hardware illustrated in FIG. 4 may be used in various embodiments of the computer system 400 .
- other configuration of the computer system may include one or more additional devices not shown in FIG. 4 .
- the technique disclosed is applicable to different types of system environment, such as a multi-drop environment or a point-to-point environment.
- the disclosed technique is applicable to both mobile and desktop computing systems.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Power Sources (AREA)
Abstract
Description
- The present invention relates to computing technology, and more particularly, to power management in a computer system.
- In a typical computer system, a central processing unit (CPU) of the system supports various power states to allow robust power management in the system. For example, a CPU may support five power states, such as the C0, C1, C2, C3, and C4 states. In one system, the C0 state is an active power state, in which the CPU executes instructions, while the remaining states, i.e., the C1, C2, C3, and C4 states, are sleeping states. In the sleeping states, the CPU consumes less power and dissipates less heat than in the C0 state because the CPU does not execute any instruction while in the sleeping states. Furthermore, the power consumption in the C4 state is generally less than the power consumption in the C3 state because the CPU supply voltage is lowered when the CPU enters into the C4 state.
- Each sleeping state has a latency associated with entering and exiting and is related to the power saving in each state. In general, the more circuitry or logic being shutdown to save more power, the more effort and longer exit latency are consumed to re-energize the circuitry and/or logic shutdown. For example, the phase lock loop (PLL) and input/output (IO) of a CPU can be shut down to save more power when the CPU is in the C3 or C4 state because the CPU does not snoop while in the C3 or C4 state. However, it typically takes longer to re-energize the PLL and IO after the CPU exits from the C3 or C4 state.
- In an exemplary system, the CPU can access the memory during the C0 state or snoop bus-master initiated memory traffic while in the C1 or C2 state. The bus master is a peripheral device having control of the bus at a given time, such as, for example, an external graphic core. The data movement from one device to another over a bus is, therefore, referred to as a bus mastering event. In contrast, in the C3 or C4 state, the CPU suspends snooping or memory access as part of the deeper sleep states. In order to snoop the bus-master initiated memory traffic, a CPU in either the C3 or C4 state has to exit the C3 or C4 state. Because of the higher exit latency of the C3 and C4 states, the system has to verify whether there is an on-going bus mastering event from any peripheral device in the system that may require the CPU to snoop before entering either the C3 or C4 state. If there is an on-going bus mastering event, the CPU has to settle for a power state (e.g., C1 or C2) with higher power consumption but lower exit latency than the C3 or C4 state.
- As to the peripheral device, it may be coupled to the CPU through a root complex device via a serial interconnect, such as a PCI Express interconnect. A root complex device includes a host bridge and one or more root ports. Examples of a root complex device include a memory controller or IO controller functional device. An interconnect is an infrastructure that couples one device to another. PCI Express is a high speed, point-to-point serial interconnect standard. For example, the first generation of PCI Express interconnect supports 2.5 Gb/sec per lane data transmission. In one exemplary system, a graphic device is coupled to a chipset of the system (e.g., a memory controller hub) through a 16-lane PCI Express interconnect.
- Furthermore, PCI Express allows flow control by supporting an accounting scheme with credits to keep track of the traffic over a PCI Express interconnect. The credits indicate the available buffering in a device for various types of transactions over an interconnect. For example, a memory controller can report to the software of the capability of a root complex device to transmit data by writing the information in a number of registers. According to PCI Express protocol, there are a number of prescribed credits for various transactions, such as, read request, write request, completion, etc. For example, when a graphic device issues transactions (e.g., read requests) towards the root complex device and these transactions are pending, a credit is consumed to reflect the amount of buffering taken up in the memory controller by the pending transactions. When these transactions are handled or retired by the memory controller, the credit is released or freed up. The number of pending transactions, as reflected by the credits consumed, indicates the likelihood of a bus mastering event that may prohibit entry into the C3 or C4 state.
- A prior art technique to indicate on-going bus mastering traffic uses a sideband signal. For example, a graphic device sends a signal AGP_BUSY to the root complex device of the computer system to indicate on-going bus mastering traffic for the system that attaches the graphic device using Accelerated Graphics Port (AGP). However, the sideband signals are costly because they require one additional pin per sideband signal on each device. Furthermore, permanent connector infrastructure has to be provided for the sideband signals in the system even though future technological innovation may not use such sideband signals at all.
- The present invention will be understood more fully from the detailed description that follows and from the accompanying drawings, which however, should not be taken to limit the appended claims to the specific embodiments shown, but are for explanation and understanding only.
-
FIG. 1A shows a flow diagram of one embodiment of a process to manage power in a computer system. -
FIG. 1B shows a flow diagram of one embodiment of a process to manage power in a computer system. -
FIG. 2A illustrates one embodiment of an entry threshold. -
FIG. 2B illustrates one embodiment of an exit threshold. -
FIGS. 3A-3C illustrate various embodiments of chipset partition. -
FIG. 4 shows an exemplary embodiment of a computer system. - In the following description, numerous specific details are set forth. However, it is understood that embodiments of the invention may be practiced without these specific details. In other instances, well-known circuits, structures, and techniques have not been shown in detail in order not to obscure the understanding of this description.
- Reference in the specification to “one embodiment” or “an embodiment” means that a particular feature, structure, or characteristic described in connection with the embodiment is included in at least one embodiment of the invention. The appearances of the phrase “in one embodiment” in various places in the specification do not necessarily all refer to the same embodiment.
- A method and an apparatus for power management in a computer system are disclosed. In one embodiment, the method includes monitoring transactions over an interconnect coupling a chipset device and a peripheral device in the computer system, the transactions being transmitted between the peripheral device and the chipset device following a flow control protocol that allows the chipset device to keep track of the transactions. The embodiment further includes causing a processor in the computer system to exit from a power state if a number of coherent transactions pending in a buffer of the chipset device exceed a predetermined threshold. In a specific embodiment, the flow control protocol is PCI Express. Other features will be apparent from the accompanying figures and the detailed description that follows.
-
FIG. 1A shows a flow diagram of one embodiment of a process to manage power in a computer system. The process is performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, etc.), software (such as is run on a general purpose computer system or a dedicated machine), or a combination of both. As discussed above, an exemplary CPU may not initiate memory access or snoop bus-master initiated traffic while in the C3 or C4 state. Therefore, in response to a CPU request to enter either the C3 or C4 state (processing block 101), processing logic performs a series of operations to determine whether the peripheral devices in the system are likely to request the CPU to snoop a bus master or accesses directly to system memory without snooping. Examples of the peripheral devices include an external graphics core, an Ethernet controller, etc. Processing logic may receive atransaction 103 from one of the peripheral devices (processing block 104). Thetransaction 103 may be coherent or incoherent. A coherent transaction involves data currently or likely being used or modified in the cache of the CPU. In contrast, an incoherent transaction involves data from the memory and the data is currently not being stored, used, or modified in the cache of the CPU. - Referring to
FIG. 1A , processing logic checks whether thetransaction 103 received is coherent or there is any pending coherent transaction in a memory controller in the computer system (processing block 110). If either is true, then processing logic asserts a bus mastering indicator to prevent the CPU from entering the C3 or C4 state (processing block 130). In one embodiment, the CPU then enters into a default state, which may be the C1 or C2 state. - However, if the
transaction 103 received is incoherent and there is no pending coherent transaction in the root complex device, processing logic consumes a number of credits to reflect the portion of buffer in the memory controller taken up by theincoherent transaction 103 and holds thetransaction 103 as pending (processing block 112). Processing logic may check whether the total number of credits consumed exceeds or equals to an entry threshold (processing block 120). If the total number of credits consumed exceeds or equals to the entry threshold, the portion of the buffer in the root complex device filled by the pending transactions has exceeded a certain level corresponding to the entry threshold. With less available buffering in the memory controller, the peripheral device is less likely to send additional transactions to the memory controller. Thus, the CPU is less likely to be requested to snoop, and hence, the CPU may enter into either the C3 or C4 state. As a result, processing logic de-asserts the bus mastering indicator to allow the CPU to enter into either the C3 or C4 state (processing block 129). - On the other hand, if the total number of credits consumed is less than the entry threshold, processing logic may check whether a timer has expired (processing block 122). If the timer has expired, processing logic de-asserts the bus mastering indicator to allow the CPU to enter into either the C3 or C4 state (processing block 130). Otherwise, processing logic repeats
processing block 110. Alternatively, processing logic may not check the timer at all and may simply repeatprocessing block 110 upon the determination that the total number of consumed credits is below the entry threshold. -
FIG. 2A illustrates one embodiment of the entry threshold. Theentry threshold 210 may be set to modify the bus mastering indicator to cause an exemplary CPU to enter into the C3 or C4 state even when there are pending incoherent transactions in the root complex device. In other words, the transactions may be intentionally held pending in the memory controller with no service attempted until the number of credits consumed exceeds or equals to theentry threshold 210 in order to defer asserting the bus mastering indicator to the CPU. As a result, the CPU has more opportunities to enter into either the C3 or C4 state to reduce average CPU power consumption. Theentry threshold 210 may be set at 0% for highly performance sensitive applications, such as graphic applications. - However, in a mobile system, such as a laptop computer, the entry threshold may be set at different values depending on the amount of charge remaining in one or more batteries of the system when the system is running solely on such batteries. It is noted that the tradeoff for lower CPU power consumption may be degraded CPU performance state. Furthermore, in one embodiment, a timer is used to qualify how long to stall servicing the initial pending transaction in order to mitigate the impact of the tradeoff on some latency sensitive applications. If the timer expires before the
entry threshold 210 is reached, then the bus mastering indicator may be reset to allow the CPU to enter the C3 or C4 state for light traffic or idle cases. -
FIG. 1B shows a flow diagram of one embodiment of a process to manage power in a computer system. The process is performed by processing logic that may comprise hardware (e.g., circuitry, dedicated logic, etc.), software (such as is run on a general purpose computer system or a dedicated machine), or a combination of both. When the CPU is in either the C3 or C4 state (processing block 105), processing logic may receive a coherent transaction from a peripheral device (processing block 140). Examples of the peripheral device include an external graphic core, an Ethernet controller, etc. Upon receipt of the coherent transaction, processing logic consumes a number of credits to reflect the portion of buffer taken up by the coherent transaction received (processing block 142). Then processing logic checks whether the total number of consumed credits for the coherent transactions exceeds or equals to an exit threshold (processing block 144). If the total number of the consumed credits exceeds or equals to the exit threshold, processing logic causes the CPU to exit from either the C3 or C4 state (processing block 150). Processing logic may send a signal to the CPU to instruct the CPU to exit from either the C3 or C4 state. After exiting from the C3 or C4 state, in one embodiment, the CPU enters the C0 state. - However, if the total number of the consumed credits does not exceed or equal to the exit threshold, processing logic checks whether a timer has expired (processing block 146). If the timer has expired, processing logic causes the CPU to exit from either the C3 or C4 state (processing block 150). Otherwise, processing logic queues up the transaction (processing block 148) and repeats
processing block 140. Alternatively, processing logic may not check the timer at all and may simply queue up the transaction (processing block 148) andrepeat processing block 140 upon the determination that the total number of consumed credits is below the exit threshold. -
FIG. 2B illustrates one embodiment of the exit threshold. Referring toFIG. 2B , theexit threshold 250 is set to decide when to set the bus mastering indicator to cause an exemplary CPU to exit from either the C3 or C4 state. Transactions may be queued up when the CPU is in the C3 or C4 state to allow the CPU to spend a certain period of time in the C3 or C4 state in order to achieve a certain level of power saving. If the number of consumed credits is below theexit threshold 250, then the CPU is held off from being notified that an exit condition has occurred. In one embodiment, a timer is used to qualify how long to stall servicing the initial pending transactions if the applications are latency sensitive. Once the timer expires, a signal is sent to cause the CPU to exit from the C3 or C4 state even if the total number of consumed credits corresponding to the pending coherent transactions is less than theexit threshold 250. Likewise, for some highly performance sensitive applications, theexit threshold 250 may be set at 0% in order to meet the performance specifications of such applications. Furthermore, in some embodiments, theexit threshold 250 is set at different values depending on the remaining battery charge capacity in the system when the battery alone powers the system. - One should appreciate that there are multiple ways to define the entry and exit thresholds. In one embodiment, the entry threshold substantially equals to the exit threshold. For instance, to run a performance-oriented application, the entry and exit thresholds may be hardwired to a single value at 0%.
- In an alternate embodiment, the entry and exit thresholds are set at different values. For instance, the entry threshold may be higher than the exit threshold. Furthermore, allowing the entry and exit thresholds to be set at different values on the fly enables the CPU to adjust performance based on the remaining battery charge capacity. In addition, the CPU may modify the entry and exit behavior of the CPU adaptively through threshold modification. Adaptive modification of the entry and exit thresholds allows the CPU to steer away from frequent thrashing of low power states because of certain periodic traffic that may coincide with the timing of the C3 or C4 state entry decision. Another advantage is to provide for asymmetric entry and exit behavior to tune and increase the residency period of the CPU in either the C3 or C4 state. For example, the CPU may take hundreds of microseconds to exit the C3 or C4 state, during which a phase lock loop of the CPU may consume twice the power consumed during the initial ten microseconds to spin up. Therefore, if the C3 or C4 residency of the CPU is less than the exit latency, the net effect may be little or negligible power saving, or worse, more power consumption.
-
FIGS. 3A-3C illustrate various embodiments of chipset partitions in a computer system.FIG. 3A shows amemory controller 310, an input/output controller 320, andpower management circuitry 330. Thepower management circuitry 330 is outside of both thememory controller 310 and the input/output controller 320. Thememory controller 310 is coupled to the input/output controller 320 via alink 315. Thelink 315 may include a digital media interface (DMI) link. Thememory controller 310 is further coupled to one or more peripheral devices (not shown) via one or more buses or interconnects (not shown) that adopt a protocol with a credit-based flow control accounting scheme, such as, for example, PCI Express. - In one embodiment, the
power management circuitry 330 communicates with thememory controller 310 and/or the input/output controller 320 via the sideband signals 322 and 324. The sideband signals 332 and 334 indicate whether there is any bus mastering activity from a peripheral device, such as an advance graphic port (AGP). The sideband signals 332 and 334 are typically denoted as XX_BUSY. For example, the sideband signal corresponding to the AGP is denoted as AGP_BUSY. One should appreciate that the sideband signals may include one or more shared signals. - In one embodiment, one of the
memory controller 310 and the input/output controller 320 acts as a central agent to roll up the bus mastering activity information through one or more message packets sent between thememory controller 310 and the input/output controller 320. The message packets may includeDMI message packets 325. However, the central agent still communicates with thepower management circuitry 330 via one of the sideband signals 334 and 332. -
FIG. 3B shows an alternate embodiment of chipset partition in a computer system. The chipset inFIG. 3B includes amemory controller 340 and an input/output controller 350 coupling to each other via alink 345, which may include a DMI link. However, one should appreciate that some embodiments of the chipset include additional devices not shown. Thememory controller 340 is further coupled to a peripheral device (not shown) via an interconnect (not shown) adopting a credit-based flow control accounting scheme, such as, for example, PCI Express. The peripheral device may include an external graphic core, an Ethernet controller, etc. The input/output controller 350 includespower management circuitry 352 to monitor data traffic over the interconnect. Since thepower management circuitry 352 is internal to the input/output controller 350, thememory controller 340 has to communicate to the input/output controller 350 on whether the peripheral device has any on-going traffic over the interconnect. In one embodiment, thememory controller 340 sets one or more bits in amessage packet 347 sent via thelink 345 to the input/output controller 350. Themessage packet 347 may be a DMI packet. Setting the bit(s) in themessage packet 347 is also referred to as in-band virtualization of the bus mastering indicator signal, as opposed to the sideband signals (e.g., sideband signals 332 and 334 inFIG. 3A ), because the signal is abstracted to eliminate the pin and connector infrastructure on both of thecontrollers power management circuitry 352 may also monitor the bus mastering activity from other peripheral devices (not shown) coupled to the input/output controller 350 via other interconnects (not shown). -
FIG. 3C shows an alternate embodiment of a chipset partition in a computer system. The chipset shown inFIG. 3C includes an integrated memory and input/output controller 360. The integrated memory and input/output controller 360 includes internalpower management circuitry 365. Since thepower management circuitry 365 is part of theintegrated controller 360, the bus mastering indications for peripheral devices coupled to thecontroller 360 may be internally registered through logic circuitry within thecontroller 360. - One should appreciate that the various embodiments of chipset partition in
FIGS. 3A-3C are merely shown to illustrate the technique disclosed. The technique disclosed may be applied to other embodiments of computer chipset partition. -
FIG. 4 shows an exemplary embodiment of acomputer system 400. Thecomputer system 400 includes a central processing unit (CPU) 410, a memory controller (MCH) 420, a number of dual in-line memory modules (DIMMs) 425, a number ofmemory devices 427, a PCI Expressgraphic port 430, an input/output controller (ICH) 440, a number of Universal Serial Bus (USB)ports 445, an audio coder-decoder (AUDIO CODEC) 460, a Super Input/Output (Super I/O) 450, and a firmware hub (FWH) 470. - In one embodiment, the
CPU 410, the PCI Expressgraphic port 430, theDIMMs 425, and theICH 440 are coupled to theMCH 420. Thelink 435 between theMCH 420 and theICH 440 may include a DMI link. TheMCH 420 routes data to and from thememory devices 427 via theDIMMs 425. Thememory devices 427 may include various types of memories, such as, for example, dynamic random access memory (DRAM), synchronous dynamic random access memory (SDRAM), double data rate (DDR) SDRAM, or flash memory. In one embodiment, each of theDIMMs 425 is mounted on the same motherboard (not shown) via a DIMM connector (not shown) in order to couple to theMCH 420. In one embodiment, theUSB ports 445, theAUDIO CODEC 460, and the Super I/O 450 are coupled to theICH 440. The Super I/O 450 may be further coupled to afirmware hub 470, afloppy disk drive 451,data input devices 453, such as, a keyboard, a mouse, etc., a number ofserial ports 455, and a number ofparallel ports 457. - In one embodiment, the
ICH 440 includespower management circuitry 442 to monitor data traffic over various interconnects coupling theICH 440 and theMCH 420 to the peripheral devices, such as, for example, the PCI Expressgraphic port 430. Thepower management circuitry 442 may generate a bus mastering indicator to be sent as a virtualized signal within amessage packet 437 from theMCH 420 to theICH 440 via thelink 435. Alternatively, theMCH 420 and theICH 440 may be integrated into a single controller with power management circuitry such that the bus mastering indicator may be internally registered through logic. - In an alternate embodiment, the
MCH 420 and theICH 440 remain as separate devices and the power management circuitry is external to both of theMCH 420 and theICH 440. Either one of theMCH 420 and theICH 440 may act as a central agent to roll up information of bus traffic from the peripheral devices in thesystem 400 from the other controller using message packets sent between thecontrollers - Note that any or all of the components and the associated hardware illustrated in
FIG. 4 may be used in various embodiments of thecomputer system 400. However, it should be appreciated that other configuration of the computer system may include one or more additional devices not shown inFIG. 4 . Furthermore, one should appreciate that the technique disclosed is applicable to different types of system environment, such as a multi-drop environment or a point-to-point environment. Likewise, the disclosed technique is applicable to both mobile and desktop computing systems. - The foregoing discussion merely describes some exemplary embodiments of the present invention. One skilled in the art will readily recognize from such discussion, the accompanying drawings and the claims that various modifications can be made without departing from the spirit and scope of the appended claims. The description is thus to be regarded as illustrative instead of limiting.
Claims (28)
Priority Applications (7)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/749,855 US7237131B2 (en) | 2003-12-30 | 2003-12-30 | Transaction-based power management in a computer system |
TW093140273A TWI266183B (en) | 2003-12-30 | 2004-12-23 | Method, apparatus and semiconductor chip to manage power in a computer system, and computer system capable of managing power |
PCT/US2004/043675 WO2005066743A2 (en) | 2003-12-30 | 2004-12-23 | A method and an apparatus for power management in a computer system |
EP04815690.5A EP1702253B1 (en) | 2003-12-30 | 2004-12-23 | A method and an apparatus for power management in a computer system |
JP2006547484A JP4376907B2 (en) | 2003-12-30 | 2004-12-23 | Method and apparatus for power management of computer system |
KR1020067013281A KR100798980B1 (en) | 2003-12-30 | 2004-12-23 | Method and apparatus for power management in computer system |
CNB2004800395405A CN100498652C (en) | 2003-12-30 | 2004-12-23 | Method and an apparatus for power management in a computer system |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/749,855 US7237131B2 (en) | 2003-12-30 | 2003-12-30 | Transaction-based power management in a computer system |
Publications (2)
Publication Number | Publication Date |
---|---|
US20050149768A1 true US20050149768A1 (en) | 2005-07-07 |
US7237131B2 US7237131B2 (en) | 2007-06-26 |
Family
ID=34711148
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/749,855 Expired - Fee Related US7237131B2 (en) | 2003-12-30 | 2003-12-30 | Transaction-based power management in a computer system |
Country Status (7)
Country | Link |
---|---|
US (1) | US7237131B2 (en) |
EP (1) | EP1702253B1 (en) |
JP (1) | JP4376907B2 (en) |
KR (1) | KR100798980B1 (en) |
CN (1) | CN100498652C (en) |
TW (1) | TWI266183B (en) |
WO (1) | WO2005066743A2 (en) |
Cited By (25)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050144487A1 (en) * | 2003-12-30 | 2005-06-30 | Puffer David M. | Optimizing exit latency from an active power management state |
US20050210312A1 (en) * | 2004-02-18 | 2005-09-22 | International Business Machines Corporation | Program, recording medium, method, and information processing apparatus for controlling an execution mode of a CPU |
US20060277344A1 (en) * | 2005-06-02 | 2006-12-07 | Kabushiki Kaisha Toshiba | Information processing apparatus and controlling method thereof |
US20060277126A1 (en) * | 2005-06-06 | 2006-12-07 | Intel Corporation | Ring credit management |
US20070260780A1 (en) * | 2006-04-11 | 2007-11-08 | Nokia Corporation | Media subsystem, method and computer program product for adaptive media buffering |
US20070288782A1 (en) * | 2006-06-13 | 2007-12-13 | Via Technologies, Inc. | Method for reducing power consumption of a computer system in the working state |
US20070288769A1 (en) * | 2006-06-13 | 2007-12-13 | Via Technologies, Inc. | Method for increasing the data processing capability of a computer system |
US20080114998A1 (en) * | 2006-11-12 | 2008-05-15 | Microsemi Corp. - Analog Mixed Signal Group Ltd. | Reduced Guard Band for Power Over Ethernet |
US20080162964A1 (en) * | 2006-12-28 | 2008-07-03 | Eric Dahlen | Enabling idle states for a component associated with an interconnect |
US20080244285A1 (en) * | 2007-03-29 | 2008-10-02 | Fleming Bruce L | Method to control core duty cycles using low power modes |
US20090077394A1 (en) * | 2007-09-17 | 2009-03-19 | Jr-Shian Tsai | Techniques for communications based power management |
US20090158071A1 (en) * | 2007-12-17 | 2009-06-18 | Giap Yong Ooi | Integrated power management logic |
US7752473B1 (en) | 2006-03-20 | 2010-07-06 | Intel Corporation | Providing a deterministic idle time window for an idle state of a device |
US20130117492A1 (en) * | 2008-09-30 | 2013-05-09 | Seh W. Kwa | Platform communication protocol |
US20140052938A1 (en) * | 2012-08-14 | 2014-02-20 | Korea Advanced Institute Of Science And Technology | Clumsy Flow Control Method and Apparatus for Improving Performance and Energy Efficiency in On-Chip Network |
US20140095801A1 (en) * | 2012-09-28 | 2014-04-03 | Devadatta V. Bodas | System and method for retaining coherent cache contents during deep power-down operations |
US8782456B2 (en) | 2010-06-01 | 2014-07-15 | Intel Corporation | Dynamic and idle power reduction sequence using recombinant clock and power gating |
US8850250B2 (en) | 2010-06-01 | 2014-09-30 | Intel Corporation | Integration of processor and input/output hub |
TWI463301B (en) * | 2011-04-01 | 2014-12-01 | Intel Corp | Control of platform power consumption using selective updating of a display image |
US9106662B2 (en) | 2013-01-07 | 2015-08-11 | Electronics And Telecommunications Research Institute | Method and apparatus for controlling load allocation in cluster system |
US9146610B2 (en) | 2010-09-25 | 2015-09-29 | Intel Corporation | Throttling integrated link |
US9829949B2 (en) | 2013-06-28 | 2017-11-28 | Intel Corporation | Adaptive interrupt coalescing for energy efficient mobile platforms |
US10509455B2 (en) | 2014-12-24 | 2019-12-17 | Intel Corporation | Method and apparatus to control a link power state |
US20200150738A1 (en) * | 2018-11-09 | 2020-05-14 | Monolithic Power Systems, Inc. | System and method for standby mode operation of power management system |
WO2021126690A1 (en) * | 2019-12-20 | 2021-06-24 | Advanced Micro Devices, Inc. | Arbitration scheme for coherent and non-coherent memory requests |
Families Citing this family (15)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JP4189882B2 (en) * | 2004-05-11 | 2008-12-03 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Recording medium, information processing apparatus, control method, and program |
US7353414B2 (en) * | 2005-03-30 | 2008-04-01 | Intel Corporation | Credit-based activity regulation within a microprocessor based on an allowable activity level |
US7924708B2 (en) * | 2005-12-13 | 2011-04-12 | Intel Corporation | Method and apparatus for flow control initialization |
US8527709B2 (en) * | 2007-07-20 | 2013-09-03 | Intel Corporation | Technique for preserving cached information during a low power mode |
US8019920B2 (en) * | 2008-10-01 | 2011-09-13 | Hewlett-Packard Development Company, L.P. | Method to improve operating performance of a computing device |
US8799582B2 (en) * | 2008-12-30 | 2014-08-05 | Intel Corporation | Extending cache coherency protocols to support locally buffered data |
US8627014B2 (en) * | 2008-12-30 | 2014-01-07 | Intel Corporation | Memory model for hardware attributes within a transactional memory system |
US9785462B2 (en) | 2008-12-30 | 2017-10-10 | Intel Corporation | Registering a user-handler in hardware for transactional memory event handling |
US8156275B2 (en) | 2009-05-13 | 2012-04-10 | Apple Inc. | Power managed lock optimization |
KR101282199B1 (en) * | 2009-11-19 | 2013-07-04 | 한국전자통신연구원 | Method and apparatus for controlling power in cluster system |
CN103348303B (en) * | 2011-02-08 | 2016-08-17 | 飞思卡尔半导体公司 | Integrated circuit device, power management module and method for providing power management |
JP5791397B2 (en) * | 2011-07-07 | 2015-10-07 | ルネサスエレクトロニクス株式会社 | Device controller, USB device controller, and power control method |
US9116694B2 (en) * | 2012-09-26 | 2015-08-25 | Intel Corporation | Efficient low power exit sequence for peripheral devices |
US9541987B2 (en) * | 2013-06-28 | 2017-01-10 | Intel Corporation | Generic host-based controller latency method and appartus |
CN110990332A (en) * | 2019-12-04 | 2020-04-10 | 合肥市卓怡恒通信息安全有限公司 | Server mainboard based on explain majestic treaters |
Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5721935A (en) * | 1995-12-20 | 1998-02-24 | Compaq Computer Corporation | Apparatus and method for entering low power mode in a computer system |
US6085330A (en) * | 1998-04-07 | 2000-07-04 | Advanced Micro Devices, Inc. | Control circuit for switching a processor between multiple low power states to allow cache snoops |
US6128745A (en) * | 1998-05-28 | 2000-10-03 | Phoenix Technologies Ltd. | Power management inactivity monitoring using software threads |
US6357013B1 (en) * | 1995-12-20 | 2002-03-12 | Compaq Computer Corporation | Circuit for setting computer system bus signals to predetermined states in low power mode |
US20030137945A1 (en) * | 2002-01-24 | 2003-07-24 | Intel Corporation | Method and apparatus for managing energy usage of processors while executing protocol state machines |
US20040212678A1 (en) * | 2003-04-25 | 2004-10-28 | Cooper Peter David | Low power motion detection system |
US6820169B2 (en) * | 2001-09-25 | 2004-11-16 | Intel Corporation | Memory control with lookahead power management |
US20050025119A1 (en) * | 2003-01-21 | 2005-02-03 | Nextio Inc. | Switching apparatus and method for providing shared I/O within a load-store fabric |
US20050044448A1 (en) * | 2003-08-20 | 2005-02-24 | Dell Products L.P. | System and method for managing power consumption and data integrity in a computer system |
US20050088445A1 (en) * | 2003-10-22 | 2005-04-28 | Alienware Labs Corporation | Motherboard for supporting multiple graphics cards |
US20060018342A1 (en) * | 2003-01-21 | 2006-01-26 | Nextio Inc. | Method and apparatus for shared I/O in a load/store fabric |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
EP1338948A1 (en) | 2002-02-25 | 2003-08-27 | Hewlett Packard Company, a Delaware Corporation | Clock control arrangement for a computing system |
-
2003
- 2003-12-30 US US10/749,855 patent/US7237131B2/en not_active Expired - Fee Related
-
2004
- 2004-12-23 EP EP04815690.5A patent/EP1702253B1/en not_active Expired - Lifetime
- 2004-12-23 KR KR1020067013281A patent/KR100798980B1/en not_active Expired - Fee Related
- 2004-12-23 WO PCT/US2004/043675 patent/WO2005066743A2/en active Application Filing
- 2004-12-23 JP JP2006547484A patent/JP4376907B2/en not_active Expired - Fee Related
- 2004-12-23 TW TW093140273A patent/TWI266183B/en not_active IP Right Cessation
- 2004-12-23 CN CNB2004800395405A patent/CN100498652C/en not_active Expired - Fee Related
Patent Citations (11)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5721935A (en) * | 1995-12-20 | 1998-02-24 | Compaq Computer Corporation | Apparatus and method for entering low power mode in a computer system |
US6357013B1 (en) * | 1995-12-20 | 2002-03-12 | Compaq Computer Corporation | Circuit for setting computer system bus signals to predetermined states in low power mode |
US6085330A (en) * | 1998-04-07 | 2000-07-04 | Advanced Micro Devices, Inc. | Control circuit for switching a processor between multiple low power states to allow cache snoops |
US6128745A (en) * | 1998-05-28 | 2000-10-03 | Phoenix Technologies Ltd. | Power management inactivity monitoring using software threads |
US6820169B2 (en) * | 2001-09-25 | 2004-11-16 | Intel Corporation | Memory control with lookahead power management |
US20030137945A1 (en) * | 2002-01-24 | 2003-07-24 | Intel Corporation | Method and apparatus for managing energy usage of processors while executing protocol state machines |
US20050025119A1 (en) * | 2003-01-21 | 2005-02-03 | Nextio Inc. | Switching apparatus and method for providing shared I/O within a load-store fabric |
US20060018342A1 (en) * | 2003-01-21 | 2006-01-26 | Nextio Inc. | Method and apparatus for shared I/O in a load/store fabric |
US20040212678A1 (en) * | 2003-04-25 | 2004-10-28 | Cooper Peter David | Low power motion detection system |
US20050044448A1 (en) * | 2003-08-20 | 2005-02-24 | Dell Products L.P. | System and method for managing power consumption and data integrity in a computer system |
US20050088445A1 (en) * | 2003-10-22 | 2005-04-28 | Alienware Labs Corporation | Motherboard for supporting multiple graphics cards |
Cited By (46)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20050144487A1 (en) * | 2003-12-30 | 2005-06-30 | Puffer David M. | Optimizing exit latency from an active power management state |
US7178045B2 (en) * | 2003-12-30 | 2007-02-13 | Intel Corporation | Optimizing exit latency from an active power management state |
US20050210312A1 (en) * | 2004-02-18 | 2005-09-22 | International Business Machines Corporation | Program, recording medium, method, and information processing apparatus for controlling an execution mode of a CPU |
US7325151B2 (en) * | 2004-02-18 | 2008-01-29 | Lenovo (Singapore) Pte. Ltd. | Program, recording medium, method, and information processing apparatus for controlling an execution mode of a CPU |
US20060277344A1 (en) * | 2005-06-02 | 2006-12-07 | Kabushiki Kaisha Toshiba | Information processing apparatus and controlling method thereof |
US20060277126A1 (en) * | 2005-06-06 | 2006-12-07 | Intel Corporation | Ring credit management |
US7752473B1 (en) | 2006-03-20 | 2010-07-06 | Intel Corporation | Providing a deterministic idle time window for an idle state of a device |
US20070260780A1 (en) * | 2006-04-11 | 2007-11-08 | Nokia Corporation | Media subsystem, method and computer program product for adaptive media buffering |
EP1860555A3 (en) * | 2006-04-11 | 2009-01-07 | Nokia Corporation | Media subsystem, method and computer program product for adaptive media buffering |
US7689847B2 (en) * | 2006-06-13 | 2010-03-30 | Via Technologies, Inc. | Method for increasing the data processing capability of a computer system |
US20070288769A1 (en) * | 2006-06-13 | 2007-12-13 | Via Technologies, Inc. | Method for increasing the data processing capability of a computer system |
US8335941B2 (en) | 2006-06-13 | 2012-12-18 | Via Technologies, Inc. | Method for reducing power consumption of a computer system in the working state |
US7783905B2 (en) | 2006-06-13 | 2010-08-24 | Via Technologies Inc. | Method for reducing power consumption of a computer system in the working state |
US20070288782A1 (en) * | 2006-06-13 | 2007-12-13 | Via Technologies, Inc. | Method for reducing power consumption of a computer system in the working state |
US20100191988A1 (en) * | 2006-06-13 | 2010-07-29 | Via Technologies, Inc. | Method for reducing power consumption of a computer system in the working state |
US20080114998A1 (en) * | 2006-11-12 | 2008-05-15 | Microsemi Corp. - Analog Mixed Signal Group Ltd. | Reduced Guard Band for Power Over Ethernet |
US7895456B2 (en) * | 2006-11-12 | 2011-02-22 | Microsemi Corp. - Analog Mixed Signal Group Ltd | Reduced guard band for power over Ethernet |
US20080162964A1 (en) * | 2006-12-28 | 2008-07-03 | Eric Dahlen | Enabling idle states for a component associated with an interconnect |
US8850249B2 (en) | 2006-12-28 | 2014-09-30 | Intel Corporation | Enabling idle states for a component associated with an interconnect |
US7734942B2 (en) | 2006-12-28 | 2010-06-08 | Intel Corporation | Enabling idle states for a component associated with an interconnect |
US20100205503A1 (en) * | 2006-12-28 | 2010-08-12 | Eric Dahlen | Enabling Idle States For A Component Associated With An Interconnect |
US20080244285A1 (en) * | 2007-03-29 | 2008-10-02 | Fleming Bruce L | Method to control core duty cycles using low power modes |
DE112008000603B4 (en) * | 2007-03-29 | 2013-03-14 | Intel Corporation | A method of controlling core work files using low power modes |
US7774626B2 (en) * | 2007-03-29 | 2010-08-10 | Intel Corporation | Method to control core duty cycles using low power modes |
US8479028B2 (en) * | 2007-09-17 | 2013-07-02 | Intel Corporation | Techniques for communications based power management |
US20090077394A1 (en) * | 2007-09-17 | 2009-03-19 | Jr-Shian Tsai | Techniques for communications based power management |
US20090158071A1 (en) * | 2007-12-17 | 2009-06-18 | Giap Yong Ooi | Integrated power management logic |
US8386806B2 (en) * | 2007-12-17 | 2013-02-26 | Intel Corporation | Integrated power management logic |
US20150127874A1 (en) * | 2008-09-30 | 2015-05-07 | Intel Corporation | Platform communication protocol |
US20130117492A1 (en) * | 2008-09-30 | 2013-05-09 | Seh W. Kwa | Platform communication protocol |
US10146290B2 (en) * | 2008-09-30 | 2018-12-04 | Intel Corporation | Platform communication protocol |
US9715269B2 (en) * | 2008-09-30 | 2017-07-25 | Intel Corporation | Platform communication protocol |
US8782456B2 (en) | 2010-06-01 | 2014-07-15 | Intel Corporation | Dynamic and idle power reduction sequence using recombinant clock and power gating |
US8850250B2 (en) | 2010-06-01 | 2014-09-30 | Intel Corporation | Integration of processor and input/output hub |
US10241952B2 (en) | 2010-09-25 | 2019-03-26 | Intel Corporation | Throttling integrated link |
US9146610B2 (en) | 2010-09-25 | 2015-09-29 | Intel Corporation | Throttling integrated link |
TWI463301B (en) * | 2011-04-01 | 2014-12-01 | Intel Corp | Control of platform power consumption using selective updating of a display image |
US20140052938A1 (en) * | 2012-08-14 | 2014-02-20 | Korea Advanced Institute Of Science And Technology | Clumsy Flow Control Method and Apparatus for Improving Performance and Energy Efficiency in On-Chip Network |
US20140095801A1 (en) * | 2012-09-28 | 2014-04-03 | Devadatta V. Bodas | System and method for retaining coherent cache contents during deep power-down operations |
US9106662B2 (en) | 2013-01-07 | 2015-08-11 | Electronics And Telecommunications Research Institute | Method and apparatus for controlling load allocation in cluster system |
US9829949B2 (en) | 2013-06-28 | 2017-11-28 | Intel Corporation | Adaptive interrupt coalescing for energy efficient mobile platforms |
US10509455B2 (en) | 2014-12-24 | 2019-12-17 | Intel Corporation | Method and apparatus to control a link power state |
US20200150738A1 (en) * | 2018-11-09 | 2020-05-14 | Monolithic Power Systems, Inc. | System and method for standby mode operation of power management system |
US10754410B2 (en) * | 2018-11-09 | 2020-08-25 | Monolithic Power Systems, Inc. | System and method for standby mode operation of power management system |
WO2021126690A1 (en) * | 2019-12-20 | 2021-06-24 | Advanced Micro Devices, Inc. | Arbitration scheme for coherent and non-coherent memory requests |
US11513973B2 (en) | 2019-12-20 | 2022-11-29 | Advanced Micro Devices, Inc. | Arbitration scheme for coherent and non-coherent memory requests |
Also Published As
Publication number | Publication date |
---|---|
WO2005066743A3 (en) | 2005-12-08 |
CN100498652C (en) | 2009-06-10 |
TWI266183B (en) | 2006-11-11 |
KR100798980B1 (en) | 2008-01-28 |
JP2007517332A (en) | 2007-06-28 |
US7237131B2 (en) | 2007-06-26 |
EP1702253A2 (en) | 2006-09-20 |
TW200530806A (en) | 2005-09-16 |
WO2005066743A2 (en) | 2005-07-21 |
EP1702253B1 (en) | 2016-06-29 |
JP4376907B2 (en) | 2009-12-02 |
KR20060111658A (en) | 2006-10-27 |
CN1902566A (en) | 2007-01-24 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US7237131B2 (en) | Transaction-based power management in a computer system | |
US8656198B2 (en) | Method and apparatus for memory power management | |
US7496777B2 (en) | Power throttling in a memory system | |
US6971033B2 (en) | Method and apparatus for improving bus master performance | |
US7966506B2 (en) | Saving power in a computer system | |
US7930470B2 (en) | System to enable a memory hub device to manage thermal conditions at a memory device level transparent to a memory controller | |
US6820209B1 (en) | Power managed graphics controller | |
US5692202A (en) | System, apparatus, and method for managing power in a computer system | |
CN102646446B (en) | Hardware dynamic cache power management | |
US7603504B2 (en) | Reducing core wake-up latency in a computer system | |
JP2006309757A (en) | Selection method for command sent to memory, memory controller, and computer system | |
WO2010101835A1 (en) | Decoupled memory modules: building high-bandwidth memory systems from low-speed dynamic random access memory devices | |
US10409357B1 (en) | Command-oriented low power control method of high-bandwidth-memory system | |
US7529955B2 (en) | Dynamic bus parking | |
US8719606B2 (en) | Optimizing performance and power consumption during memory power down state | |
US7523282B1 (en) | Clock enable throttling for power savings in a memory subsystem | |
US7958380B2 (en) | Coarsely controlling memory power states | |
EP1570335B1 (en) | An apparatus and method for address bus power control | |
HK1075949B (en) | An apparatus and method for address bus power control |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTEL CORPORATION, CALIFORNIA Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:KWA, SEH W.;SRITANYARATANA, SIRIPONG;REEL/FRAME:014868/0337 Effective date: 20031229 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
CC | Certificate of correction | ||
FPAY | Fee payment |
Year of fee payment: 4 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20190626 |