US20140095908A1 - Downstream device service latency reporting for power management - Google Patents
Downstream device service latency reporting for power management Download PDFInfo
- Publication number
- US20140095908A1 US20140095908A1 US14/095,982 US201314095982A US2014095908A1 US 20140095908 A1 US20140095908 A1 US 20140095908A1 US 201314095982 A US201314095982 A US 201314095982A US 2014095908 A1 US2014095908 A1 US 2014095908A1
- Authority
- US
- United States
- Prior art keywords
- state
- service latency
- transition
- downstream device
- logic
- 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.)
- Abandoned
Links
Images
Classifications
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W52/00—Power management, e.g. TPC [Transmission Power Control], power saving or power classes
- H04W52/02—Power saving arrangements
- H04W52/0209—Power saving arrangements in terminal devices
- H04W52/0225—Power saving arrangements in terminal devices using monitoring of external events, e.g. the presence of a signal
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F1/00—Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
- G06F1/16—Constructional details or arrangements
- G06F1/20—Cooling means
- G06F1/206—Cooling means comprising thermal management
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR 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
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR 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/3234—Power saving characterised by the action undertaken
- G06F1/3296—Power saving characterised by the action undertaken by lowering the supply or operating voltage
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F13/00—Interconnection of, or transfer of information or other signals between, memories, input/output devices or central processing units
- G06F13/38—Information transfer, e.g. on bus
- G06F13/42—Bus transfer protocol, e.g. handshake; Synchronisation
- G06F13/4282—Bus transfer protocol, e.g. handshake; Synchronisation on a serial bus, e.g. I2C bus, SPI bus
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F15/00—Digital computers in general; Data processing equipment in general
- G06F15/16—Combinations of two or more digital computers each having at least an arithmetic unit, a program unit and a register, e.g. for a simultaneous processing of several programs
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F9/00—Arrangements for program control, e.g. control units
- G06F9/06—Arrangements for program control, e.g. control units using stored programs, i.e. using an internal store of processing equipment to receive or retain programs
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04L—TRANSMISSION OF DIGITAL INFORMATION, e.g. TELEGRAPHIC COMMUNICATION
- H04L43/00—Arrangements for monitoring or testing data switching networks
- H04L43/08—Monitoring or testing based on specific metrics, e.g. QoS, energy consumption or environmental parameters
- H04L43/0852—Delays
- H04L43/0858—One way delays
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE 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/00—Energy efficient computing, e.g. low power processors, power management or thermal management
-
- Y—GENERAL 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
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02D—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN INFORMATION AND COMMUNICATION TECHNOLOGIES [ICT], I.E. INFORMATION AND COMMUNICATION TECHNOLOGIES AIMING AT THE REDUCTION OF THEIR OWN ENERGY USE
- Y02D30/00—Reducing energy consumption in communication networks
- Y02D30/70—Reducing energy consumption in communication networks in wireless communication networks
Definitions
- Embodiments described herein generally relate to power management.
- Power management is used in many devices and systems to improve power efficiency, helping to reduce power consumption and/or heat dissipation.
- power management can help extend operation.
- Some platform-level power management has been based on some heuristics collected on the platform and some guidance given by an operating system. Processor utilization can be used as a rough estimate of platform activity. When there is heavy input/output (I/O) activity and light processor utilization, however, the platform will be put into lower power states, impacting I/O performance. Indeed, as a platform goes into deeper power states, its response latency to break events like direct memory access (DMA) accesses and interrupts increases. Although many I/O devices are designed to tolerate some fixed minimum response latency from the platform, this can effectively limit the depth of power states which the platform may enter. The platform would compromise functionality and/or performance if the platform entered a deeper power state that increased its response latency beyond the fixed minimum an I/O device could tolerate.
- I/O input/output
- DMA direct memory access
- FIG. 1 illustrates, for one embodiment, a block diagram of an example system to perform power management based at least in part on service latency reporting from one or more downstream devices;
- FIG. 2 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device
- FIG. 3 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device
- FIG. 4 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a first technique
- FIG. 5 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the first technique
- FIG. 6 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a second technique
- FIG. 7 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the second technique
- FIG. 8 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the second technique
- FIG. 9 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a third technique
- FIG. 10 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the third technique
- FIG. 11 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the third technique
- FIG. 12 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with a fourth technique
- FIG. 13 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a fifth technique
- FIG. 14 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the fifth technique
- FIG. 15 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a sixth technique
- FIG. 16 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the sixth technique
- FIG. 17 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the sixth technique.
- FIG. 1 illustrates an example system 100 comprising one or more processors 110 and platform control logic 120 coupled to processor(s) 110 .
- Processor(s) 110 for one embodiment may have one or more processor power management controllers (PPMCs) 112 to help improve power efficiency for processor(s) 110 .
- Platform control logic 120 for one embodiment may have a platform controller power management controller (PCPMC) 122 to help improve power efficiency for system 100 .
- PCPMC 122 for one embodiment may, for example, manage one or more components of system 100 to enter into one of a plurality of lower power or sleep states when the component is less active or idle.
- PCPMC 122 for one embodiment may help coordinate power management for components of system 100 to help improve power efficiency.
- PCPMC 122 for one embodiment may, for example, coordinate with one or more PPMCs 112 for such PPMC(s) 112 and PCPMC 122 to better identify the depth of lower power states which one or more components may enter yet still be responsive to one or more other components with reduced concern for lost functionality and/or performance.
- PCPMC 122 for one embodiment may receive from one or more downstream devices, such as device 132 for example, data corresponding to a service latency for that device.
- PCPMC 122 for one embodiment may manage power based at least in part on the received data and therefore based at least in part on the corresponding service latency.
- the service latency for one embodiment may be a service latency tolerance for the device.
- the service latency for one embodiment may be based at least in part on the maximum latency the device may tolerate without adversely affecting functionality or performance of the device.
- the service latency for one embodiment may correspond to a level relating to activity for at least a portion of the device.
- PCPMC 122 for one embodiment may therefore receive over time different service latencies from the device depending at least in part on the activity level for at least a portion of the device.
- PCPMC 122 for one embodiment may better identify the depth of lower power states which one or more components of system 100 may enter and still be responsive to the device with reduced concern for lost functionality and/or performance.
- One or more PPMCs 112 for one embodiment may coordinate with PCPMC 122 and also manage power based at least in part on a service latency for a downstream device.
- PCPMC 122 for one embodiment may transmit received data corresponding to a service latency for a device to one or more PPMCs 112 for such PPMC(s) 112 to manage power based at least in part on that service latency.
- One or more PPMCs 112 for one embodiment may indirectly manage power based at least in part on a service latency for a device based at least in part on how PCPMC 122 manages power based at least in part on that service latency.
- Platform control logic 120 for one embodiment may comprise one or more interface controllers 124 to communicate with one or more devices, such as devices 132 and 134 .
- Such interface controller(s) 124 may comprise any suitable logic to interface with one or more devices in any suitable manner.
- One or more interface controllers 124 for one embodiment may be compatible with any suitable one or more standard specifications such as, for example and without limitation, any suitable Universal Serial Bus (USB) specification (e.g., USB Specification Revision 2.0, Apr. 27, 2000; USB 2.0 Link Power Management Addendum Engineering Change Notice, Jul. 16, 2007; USB 3.0 Specification Revision 1.0, Nov.
- USB Universal Serial Bus
- PCI Peripheral Component Interface
- PCIe PCI Express
- One or more interface controllers 124 for one embodiment may receive from one or more downstream devices data corresponding to a service latency for the device and transmit such data to PCPMC 122 .
- One or more interface controllers 124 for one embodiment may include an interface controller power management controller (ICPMC) 126 to help improve power efficiency for the interface controller 124 and/or for the connection or link to one or more devices.
- ICPMCs 126 for one embodiment may receive from one or more devices data corresponding to a service latency for the device and manage power based at least in part on the received data and therefore based at least in part on the corresponding service latency.
- PCPMC 122 for one embodiment may indirectly manage power based at least in part on a service latency for a device based at least in part on how one or more ICPMCs 126 manage power based at least in part on that service latency.
- Interface controller(s) 124 for one embodiment may receive data corresponding to a service latency for a device, such as device 136 for example, downstream from another device, such as device 134 for example.
- Device 134 for one embodiment may receive from device 136 data corresponding to a service latency for device 136 and transmit such data to interface controller(s) 124 .
- Device 134 for one embodiment may receive from device 136 data corresponding to a service latency for device 136 and manage power for device 134 based at least in part on the received data and therefore based at least in part on the corresponding service latency.
- a corresponding ICPMC 126 for one embodiment may indirectly manage power based at least in part on a service latency for device 136 based at least in part on how device 134 manages power based at least in part on that service latency.
- power may be managed in system 100 based at least in part on a service latency for a device as described in U.S. patent application Ser. No. 12/006,251, entitled LATENCY BASED PLATFORM COORDINATION, and filed Dec. 31, 2007; U.S. patent application Ser. No. 12/059,992, entitled PLATFORM POWER MANAGEMENT BASED ON LATENCY GUIDANCE, and filed Mar. 31, 2008; and/or U.S. patent application Ser. No. 12/146,873, entitled COORDINATED LINK POWER MANAGEMENT, and filed Jun. 26, 2008.
- system 100 may also have one or more input devices 140 , one or more displays 150 , volatile memory 160 , one or more non-volatile memory and/or storage devices 170 , and one or more communications interfaces 180 .
- Processor(s) 110 for one embodiment may include one or more memory controllers to provide an interface to volatile memory 160 .
- Volatile memory 160 may be used to load and store data and/or instructions, for example, for system 100 .
- Volatile memory 160 may include any suitable volatile memory, such as suitable dynamic random access memory (DRAM) for example.
- DRAM dynamic random access memory
- Processor(s) 110 for one embodiment may use PPMC(s) 112 to help manage power for volatile memory 160 .
- one or more memory controllers may reside with platform control logic 120 , allowing platform control logic 120 to communicate with volatile memory 160 directly.
- Platform control logic 120 may include any suitable interface controllers, including interface controller(s) 124 , to provide for any suitable communications link to processor(s) 110 and/or to any suitable device or component in communication with platform control logic 120 .
- Platform control logic 120 for one embodiment may use PCPMC 122 to help manage power for any suitable one or more devices and/or components in communication with platform control logic 120 .
- Platform control logic 120 may include one or more graphics controllers to provide an interface to display(s) 150 .
- Display(s) 150 may include any suitable display, such as a cathode ray tube (CRT) or a liquid crystal display (LCD) for example.
- CTR cathode ray tube
- LCD liquid crystal display
- One or more graphics controllers for one embodiment may alternatively be external to platform control logic 120 .
- Platform control logic 120 may include one or more input/output (I/O) controllers to provide an interface to input device(s) 140 , non-volatile memory and/or storage device(s) 170 , and communications interface(s) 180 .
- I/O input/output
- Input device(s) 140 may include any suitable input device(s), such as a keyboard, a mouse, and/or any other suitable cursor control device.
- Non-volatile memory and/or storage device(s) 170 may be used to store data and/or instructions, for example.
- Non-volatile memory and/or storage device(s) 170 may include any suitable non-volatile memory, such as flash memory for example, and/or may include any suitable non-volatile storage device(s), such as one or more hard disk drives (HDDs), one or more compact disc (CD) drives, and/or one or more digital versatile disc (DVD) drives for example.
- HDDs hard disk drives
- CD compact disc
- DVD digital versatile disc
- Communications interface(s) 180 may provide an interface for system 100 to communicate over one or more networks and/or with any other suitable device. Communications interface(s) 180 may include any suitable hardware and/or firmware. Communications interface(s) 180 for one embodiment may include, for example, a network adapter, a wireless network adapter, a telephone modem, and/or a wireless modem. For wireless communications, communications interface(s) 180 for one embodiment may use one or more antennas 182 .
- Downstream devices 132 , 134 , and 136 for one embodiment may be any suitable device that may be coupled to platform control logic 120 such as, for example and without limitation, a suitable input device 140 , a suitable non-volatile memory or storage device 170 , a suitable communications interface 180 , or any other suitable I/O device.
- Examples of a downstream device may include, without limitation, a cursor control device, a storage drive, a storage device, a hub device, a network router or switch, a battery charging device, a printer, a scanner, a camcorder, a camera, a media player, a cellular telephone, a smart phone, a mobile internet device, and a computer system such as a desktop, notebook, netbook, or other computer system.
- one or more controllers of platform control logic 120 may reside with one or more processors 110 , allowing a processor 110 to communicate with one or more devices or components directly.
- One or more controllers of platform control logic 120 including one or more interface controllers 124 , for one embodiment may be integrated on a single die with at least a portion of one or more processors 110 .
- One or more controllers of platform control logic 120 including one or more interface controllers 124 , for one embodiment may be packaged with one or more processors 110 .
- FIG. 2 illustrates, for one embodiment, a device 200 that may report service latency for one or more upstream devices to manage power based at least in part on the service latency.
- Device 200 for one embodiment may correspond, for example, to downstream device 132 or 134 of FIG. 1 and report service latency for system 100 to manage power based at least in part on the service latency.
- Device 200 for one embodiment may correspond, for example, to downstream device 136 of FIG. 1 and report service latency for device 134 and/or system 100 to manage power based at least in part on the service latency.
- device 200 for one embodiment may comprise device control logic 202 , interface control logic 204 , transition identification logic 206 , and service latency reporting logic 208 .
- Device control logic 202 , interface control logic 204 , transition identification logic 206 , and service latency reporting logic 208 may each be implemented in any suitable manner using, for example, any suitable hardware, any suitable hardware performing any suitable firmware, any suitable hardware performing any suitable software, or any suitable combination of such implementations.
- any such firmware and/or software may be stored in any suitable computer readable storage medium or media of device 200 .
- Device 200 for one embodiment may also comprise other suitable logic, circuitry, and/or one or more components to implement any suitable functionality for device 200 .
- Device control logic 202 may help control the functionality of device 200 and may communicate with one or more upstream devices using interface control logic 204 to provide functionality to one or more components of such device(s).
- Interface control logic 204 may be coupled to device control logic 202 to transmit and/or receive data for device 200 in any suitable manner.
- Interface control logic 204 for one embodiment may be compatible with any suitable one or more standard specifications such as, for example and without limitation, any suitable Universal Serial Bus (USB) specification and/or any suitable Peripheral Component Interface (PCI) or PCI Express (PCIe) specification.
- USB Universal Serial Bus
- PCI Peripheral Component Interface
- PCIe PCI Express
- Transition identification logic 206 for one embodiment may identify a transition for at least a portion of device 200 from one state to another, different state in any suitable manner. Such states for one embodiment may correspond to different levels relating to activity for at least a portion of device 200 . Transition identification logic 206 for one embodiment may identify a transition for at least a portion of device control logic 202 from one state to another, different state. Transition identification logic 206 for one embodiment may identify that at least a portion of device 200 is about to transition from one state to another, different state. Transition identification logic 206 for one embodiment may identify that at least a portion of device 200 has already transitioned from one state to another, different state.
- Service latency reporting logic 208 for one embodiment may transmit to an upstream device data corresponding to a service latency in response to identification of a transition by transition identification logic 206 .
- Service latency reporting logic 208 for one embodiment may be coupled to receive identification of a state transition from transition identification logic 206 in any suitable manner.
- Service latency reporting logic 208 for one embodiment may be coupled to transmit data corresponding to a service latency in any suitable manner using interface control logic 204 .
- Service latency reporting logic 208 for one embodiment may identify a service latency in any suitable manner.
- the service latency for one embodiment may be a service latency tolerance for device 200 .
- the service latency for one embodiment may be based at least in part on the maximum latency device 200 may tolerate without adversely affecting functionality or performance of device 200 .
- the service latency for one embodiment may correspond to a new state for at least a portion of device 200 .
- Service latency reporting logic 208 for one embodiment may identify a new service latency based at least in part on a prior or current service latency and identification of a state transition.
- Service latency reporting logic 208 for one embodiment may identify a new service latency based at least in part on a new state.
- Service latency reporting logic 208 for one embodiment may identify the new state based at least in part on a prior or current state.
- Service latency reporting logic 208 for one embodiment may receive identification of a new state from transition identification logic 206 in any suitable manner.
- service latency reporting logic 208 for one embodiment may continue to identify new service latencies and transmit data corresponding to such service latencies.
- Service latency reporting logic 208 for one embodiment may optionally not transmit data corresponding to a new service latency, for example if the new service latency is the same as a prior or current service latency.
- Service latency reporting logic 208 for one embodiment may transmit data corresponding to a new service latency in response to one or more but not all transitions between states.
- FIG. 3 illustrates an example flow diagram 300 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a first state for block 302 .
- Service latency reporting logic 208 for block 304 may transmit data corresponding to a first service latency that corresponds to the first state.
- Transition identification logic 206 may identify for block 306 whether at least a portion of device 200 has transitioned to or is about to transition to a second, different state. If so, service latency reporting logic 208 for block 308 may transmit data corresponding to a second service latency that corresponds to the second state.
- Transition identification logic 206 may identify for block 310 whether at least a portion of device 200 has transitioned to or is about to transition to the first state. If so, service latency reporting logic 208 for block 304 may transmit data corresponding to the first service latency. Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 304 - 310 in this manner.
- service latency reporting logic 208 may transmit data for service latencies corresponding to more than two states.
- Transition identification logic 206 for one embodiment may identify a transition for at least a portion of device 200 between states corresponding to different activity levels.
- Service latency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a state corresponding to a higher activity level and may transmit data corresponding to a higher service latency for a transition to a state corresponding to a lower activity level.
- Transition identification logic 206 for one embodiment may identify a transition for at least a portion of device 200 between an active state where device 200 has data communications with an upstream device and an idle state where device 200 does not have data communications with an upstream device.
- At least a portion of device 200 for one embodiment may at some times frequently transition between different states. As one example, at least a portion of device 200 for one embodiment may have bursts of activity and therefore at some times frequently transition into and out from a low activity or idle state.
- Service latency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a state transition before transmitting data corresponding to a service latency to help identify whether at least a portion of device 200 is more likely to remain in a new state. In this manner, service latency reporting logic 208 for one embodiment may avoid frequently transmitting data corresponding to different service latencies that could otherwise reduce the effectiveness of power management for one or more upstream devices.
- Service latency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a transition to a state corresponding to a service latency higher than a current service latency but not after identification of a transition to a state corresponding to a service latency lower than a current service latency.
- service latency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a transition to a low activity or idle state but not after identification of a transition to a higher activity state.
- service latency reporting logic 208 for one embodiment may have a timer 402 to identify a wait time after identification of a new state transition.
- Service latency reporting logic 208 for one embodiment may compare the wait time with a predetermined threshold and wait until the wait time equals or exceeds the predetermined threshold before transmitting data corresponding to a service latency for the new state transition. If transition identification logic 206 identifies a newer state transition before the predetermined threshold has been reached, service latency reporting logic 208 for one embodiment may restart timer 402 for the newer transition.
- Service latency reporting logic 208 for one embodiment may instead, depending for example at least in part on the state for the newer transition, reset timer 402 and transmit data corresponding to a service latency for the newer transition.
- FIG. 5 illustrates an example flow diagram 500 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a low activity or idle state for block 502 .
- Service latency reporting logic 208 for block 504 may transmit data corresponding to a first service latency.
- Transition identification logic 206 may identify for block 506 whether at least a portion of device 200 has transitioned to or is about to transition to a higher activity state. If so, service latency reporting logic 208 for block 508 may transmit data corresponding to a second service latency.
- Transition identification logic 206 may identify for block 510 whether at least a portion of device 200 has transitioned to or is about to transition to the low activity or idle state.
- service latency reporting logic 208 for block 512 may wait a predetermined period of time. If at least a portion of device 200 is still in the low activity or idle state for block 514 , service latency reporting logic 208 for block 504 may transmit data corresponding to the first service latency. Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 504 - 514 in this manner.
- service latency reporting logic 208 may transmit data for service latencies corresponding to one or more additional states, such as one or more states corresponding to different levels of activity.
- Device 200 for one embodiment may receive data from another device for transmission to an upstream device.
- device control logic 202 for one embodiment may include a buffer 602 to receive data from another device over any suitable communications link, including any suitable wireless link, for subsequent transmission from buffer 602 to an upstream device using interface control logic 204 .
- Device 200 for one embodiment may be, for example, an Ethernet Network Interface Controller (NIC).
- NIC Ethernet Network Interface Controller
- device 200 may transmit data corresponding to a service latency based at least in part on an available capacity of buffer 602 for device 200 to receive data.
- an upstream device for one embodiment can remain able to respond within the service latency period to start receiving data from buffer 602 before the available capacity of buffer 602 fills. If the service latency were otherwise higher, an upstream device might possibly enter a deeper, lower power state and not respond in time, allowing buffer 602 to overflow and incurring performance loss to have lost data retransmitted.
- Transition identification logic 206 may identify a transition from the low activity or idle state to an active state to receive data in and retransmit data from buffer 602 .
- Service latency reporting logic 208 for one embodiment may then transmit data corresponding to a lower service latency to the upstream device.
- Service latency reporting logic 208 for one embodiment may transmit data corresponding to a service latency based at least in part on a reserve capacity of buffer 602 for device 200 to receive data. In this manner, device 200 may continue to receive data in buffer 602 as data starts to be transmitted from buffer 602 to the upstream device.
- FIG. 7 illustrates an example flow diagram 700 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a low activity or idle state for block 702 .
- Service latency reporting logic 208 for block 704 may transmit data corresponding to a service latency based at least in part on an available buffer capacity.
- Transition identification logic 206 may identify for block 706 whether at least a portion of device 200 has transitioned to or is about to transition to an active state to receive and retransmit data from another device. If so, service latency reporting logic 208 for block 708 may transmit data corresponding to a service latency based at least in part on a reserve buffer capacity.
- Transition identification logic 206 may identify for block 710 whether at least a portion of device 200 has transitioned to or is about to transition to the low activity or idle state. If so, service latency reporting logic 208 for block 704 may transmit data corresponding to the service latency based at least in part on an available buffer capacity. Service latency reporting logic 208 for one embodiment may optionally wait a predetermined period of time after identification of a state transition for block 710 before transmitting data for block 704 . Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 704 - 710 in this manner.
- Service latency reporting logic 208 may account for data rate and/or performance requirements for the upstream device in receiving data to identify a service latency for blocks 704 and 708 .
- service latency reporting logic 208 may transmit data for service latencies corresponding to one or more additional states.
- service latency reporting logic 208 may transmit data for service latencies corresponding to states that correspond to different ranges of data rates at which device 200 may receive data from another device.
- service latency reporting logic 208 may transmit data for service latencies corresponding to states that correspond to different performance requirements for the upstream device in receiving data.
- FIG. 8 illustrates an example diagram for one embodiment of device 200 to report service latency to an upstream device.
- buffer 602 receives network data at 802 .
- device 200 Prior to receiving network data, device 200 was in an idle state and transmitted to upstream platform components data corresponding to a latency tolerance report (LTR) of 500 microseconds ( ⁇ s) which is based at least in part on an available capacity of buffer 602 and the rate at which network data is received into buffer 602 .
- LTR latency tolerance report
- ⁇ s microseconds
- the 100 ⁇ s LTR is based at least in part on a reserve capacity of buffer 602 and the rate at which network data is received into buffer 602 .
- the 100 ⁇ s LTR takes effect within the prior 500 ⁇ s LTR period while buffer 602 receives network data.
- Upstream platform components respond within the 100 ⁇ s LTR at 804 , 806 , and 808 to receive data from buffer 602 .
- device 200 no longer receives network data at 810
- device 200 transitions to an idle state, waits a predetermined amount of time illustrated as Timeout, and transmits data corresponding to the 500 ⁇ s LTR at 812 to upstream platform components.
- upstream platform components enter various power states based at least in part on the LTRs and responses to receive data from buffer 602 .
- Transition identification logic 206 for one embodiment may identify a transition for at least a portion of device 200 between states corresponding to different power levels.
- Service latency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a higher power state and may transmit data corresponding to a higher service latency for a transition to a lower power state.
- device control logic 202 may include a device power management controller (DPMC) 902 to help improve power efficiency for device 200 .
- DPMC 902 for one embodiment may, for example, manage at least a portion of device 200 to enter into one or more lower power or sleep states when less active or idle.
- FIG. 10 illustrates an example flow diagram 1000 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a lower power state for block 1002 .
- Service latency reporting logic 208 for block 1004 may transmit data corresponding to a first service latency that corresponds to the lower power state.
- Transition identification logic 206 may identify for block 1006 whether at least a portion of device 200 has transitioned to or is about to transition to a higher power state. If so, service latency reporting logic 208 for block 1008 may transmit data corresponding to a second service latency that corresponds to the higher power state.
- Transition identification logic 206 may identify for block 1010 whether at least a portion of device 200 has transitioned to or is about to transition to the lower power state. If so, service latency reporting logic 208 for block 1004 may transmit data corresponding to the first service latency. Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 1004 - 1010 in this manner.
- service latency reporting logic 208 may transmit data for service latencies corresponding to more than two power states.
- FIG. 11 illustrates an example diagram for one embodiment of device 200 to report service latency to an upstream device.
- Device 200 for FIG. 11 may be, for example, a wireless local area network (WLAN) device.
- WLAN wireless local area network
- DPMC 902 may power manage a radio of device 200 and enter into a lower power or sleep state at 1102 .
- Device 200 for FIG. 11 for one embodiment may use a wireless protocol that supports power management features to allow device 200 to indicate to an access point or base station, for example, that device 200 is entering a lower power state. No data would then be transmitted to device 200 when in the lower power state.
- WLAN wireless local area network
- device 200 Prior to entering the lower power state, device 200 was in a higher power state and transmitted to an upstream device data corresponding to a latency of 100 microseconds ( ⁇ s) at 1104 . When device 200 is to transition to a lower power state, device 200 transmits to the upstream device data corresponding to a latency of 1 millisecond (ms) at 1106 . When device 200 is ready to move data and is to transition to a higher power state, device 200 transmits to the upstream device data corresponding to a latency of 100 ⁇ s at 1108 .
- ⁇ s microseconds
- Transition identification logic 206 may identify a transition for at least a portion of device 200 between states corresponding to different task performance levels.
- Service latency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a higher task performance state and may transmit data corresponding to a higher service latency for a transition to a lower task performance state.
- a higher task performance state for one embodiment may correspond, for example, to a state with one or more pending tasks.
- a lower task performance state for one embodiment may correspond, for example, to a state with no pending tasks or completion of one or more tasks.
- Device control logic 202 for one embodiment may perform one or more tasks for device 200 .
- Device control logic 202 for one embodiment may initiate performance of one or more tasks on its own.
- Device control logic 202 for one embodiment may perform one or more tasks at the request of another device.
- Device control logic 202 for one embodiment may perform one or more tasks at the request of an upstream device.
- FIG. 12 illustrates an example flow diagram 1200 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a lower task performance state for block 1202 .
- Service latency reporting logic 208 for block 1204 may transmit data corresponding to a first service latency that corresponds to the lower task performance state.
- Transition identification logic 206 may identify for block 1206 whether at least a portion of device 200 has transitioned to or is about to transition to a higher task performance state. If so, service latency reporting logic 208 for block 1208 may transmit data corresponding to a second service latency that corresponds to the higher task performance state.
- Transition identification logic 206 may identify for block 1210 whether at least a portion of device 200 has transitioned to or is about to transition to the lower task performance state. If so, service latency reporting logic 208 for block 1204 may transmit data corresponding to the first service latency. Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 1204 - 1210 in this manner.
- service latency reporting logic 208 may transmit data for service latencies corresponding to more than two states corresponding to different task performance levels.
- Service latency reporting logic 208 for one embodiment may transmit to an upstream device data corresponding to a service latency identified by the upstream device.
- Device 200 for one embodiment may have a service latency that may be identified by an upstream device, for example, if device 200 does not have a stringent service latency or has service latencies that vary infrequently.
- Device 200 for one embodiment may have a service latency that may be identified by an upstream device, for example, if device 200 is to perform one or more tasks scheduled by an upstream device.
- the upstream device for one embodiment may identify a lower service latency for device 200 before tasks are scheduled and a higher service latency for device 200 when all scheduled tasks are completed.
- the upstream device for one embodiment may transmit to device 200 data corresponding to a service latency identified by the upstream device.
- the upstream device for one embodiment may perform software to identify a service latency for device 200 .
- Such software for one embodiment may be, for example, driver software for device 200 .
- service latency reporting logic 208 may include memory 1302 to receive data corresponding to a service latency from an upstream device. For one embodiment, at least a portion of memory 1302 may be mapped into memory space of an upstream device.
- Memory 1302 for one embodiment may include one or more registers. Memory 1302 for one embodiment may be a memory mapped input/output (MMIO) register.
- MMIO memory mapped input/output
- FIG. 14 illustrates an example flow diagram 1400 for one embodiment of device 200 to report service latency to an upstream device.
- service latency reporting logic 208 for block 1402 may receive from an upstream device data corresponding to a service latency identified by the upstream device.
- the upstream device for one embodiment may transmit such data in performing software.
- Service latency reporting logic 208 for block 1404 may transmit to the upstream device data corresponding to a service latency based at least in part on the data received for block 1402 .
- Service latency reporting logic 208 for one embodiment may transmit data for block 1404 to a power management controller of the upstream device.
- At least a portion of device 200 for one embodiment may transition from a first state to a second, different state at substantially fixed time intervals. At least a portion of device 200 for one embodiment may transition from a low activity or idle state to a higher activity state at substantially fixed time intervals, returning to the low activity or idle state prior to expiration of the next time interval. As one example, device 200 may communicate with an upstream device at substantially fixed time intervals.
- transition identification logic 206 for one embodiment may have a timer 1502 to identify the expiration of a fixed time interval after identification of a transition for at least a portion of device 200 from a first state to a second, different state to identify another transition for at least a portion of device 200 from the first state to the second state.
- device control logic 202 may have a timer to control transition of at least a portion of device 200 from the first state to the second state, and transition identification logic 206 for one embodiment may identify such a transition for at least a portion of device 200 in any suitable manner.
- FIG. 16 illustrates an example flow diagram 1600 for one embodiment of device 200 to report service latency to an upstream device.
- at least a portion of device 200 may be in a first state for block 1602 .
- Service latency reporting logic 208 for block 1604 may transmit data corresponding to a first service latency that corresponds to the first state.
- Transition identification logic 206 may identify for block 1606 whether at least a portion of device 200 has transitioned to or is about to transition to a second state. If so, service latency reporting logic 208 for block 1608 may transmit data corresponding to a second service latency that corresponds to the second state.
- Transition identification logic 206 may identify for block 1610 whether at least a portion of device 200 has transitioned to or is about to transition to the first state.
- service latency reporting logic 208 for block 1612 may transmit data corresponding to the first service latency.
- Transition identification logic 206 may identify for block 1614 whether at least a portion of device 200 has transitioned to or is about to transition to the second state. For one embodiment, such identification may be made based at least in part on expiration of a fixed time interval after a prior identification of a transition from the first state to the second state. If so for block 1614 , service latency reporting logic 208 for block 1608 may transmit data corresponding to the second service latency. Service latency reporting logic 208 and transition identification logic 206 for one embodiment may continue to perform operations for blocks 1608 - 1614 in this manner.
- FIG. 17 illustrates an example diagram for one embodiment of device 200 to report service latency to an upstream device.
- Device 200 for FIG. 17 may transition from an idle state to a higher activity state at substantially fixed time intervals, returning to the idle state prior to expiration of the next time interval.
- Device 200 for FIG. 17 may be, for example, a voice over internet protocol (VOIP) device.
- VOIP voice over internet protocol
- device 200 at 1702 may transition from a higher activity state, represented by a transfer of data between device 200 and an upstream device, to an idle state and transmit to the upstream device data corresponding to a 1 millisecond (ms) service latency.
- Device 200 at 1704 may transmit to the upstream device data corresponding to a 20 microsecond ( ⁇ s) service latency when device 200 is about to again enter the higher activity state.
- device 200 may transmit to the upstream device data corresponding to a 20 microsecond ( ⁇ s) service latency at substantially 20 ms time intervals.
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Software Systems (AREA)
- Computer Hardware Design (AREA)
- Environmental & Geological Engineering (AREA)
- Human Computer Interaction (AREA)
- Power Sources (AREA)
- Mobile Radio Communication Systems (AREA)
- Data Exchanges In Wide-Area Networks (AREA)
Abstract
For one disclosed embodiment, a transition from a first state to a second, different state for at least a portion of a downstream device may be identified. The first and second states may correspond to different levels relating to activity for at least a portion of the downstream device. Data corresponding to a service latency may be transmitted to an upstream device in response to the identified transition for one or more upstream devices to manage power based at least in part on the service latency. Other embodiments are also disclosed.
Description
- Embodiments described herein generally relate to power management.
- Power management is used in many devices and systems to improve power efficiency, helping to reduce power consumption and/or heat dissipation. For battery-powered mobile devices and systems, power management can help extend operation.
- Some platform-level power management has been based on some heuristics collected on the platform and some guidance given by an operating system. Processor utilization can be used as a rough estimate of platform activity. When there is heavy input/output (I/O) activity and light processor utilization, however, the platform will be put into lower power states, impacting I/O performance. Indeed, as a platform goes into deeper power states, its response latency to break events like direct memory access (DMA) accesses and interrupts increases. Although many I/O devices are designed to tolerate some fixed minimum response latency from the platform, this can effectively limit the depth of power states which the platform may enter. The platform would compromise functionality and/or performance if the platform entered a deeper power state that increased its response latency beyond the fixed minimum an I/O device could tolerate.
- Embodiments are illustrated by way of example and not limitation in the figures of the accompanying drawings, in which like references indicate similar elements and in which:
-
FIG. 1 illustrates, for one embodiment, a block diagram of an example system to perform power management based at least in part on service latency reporting from one or more downstream devices; -
FIG. 2 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device; -
FIG. 3 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device; -
FIG. 4 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a first technique; -
FIG. 5 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the first technique; -
FIG. 6 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a second technique; -
FIG. 7 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the second technique; -
FIG. 8 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the second technique; -
FIG. 9 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a third technique; -
FIG. 10 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the third technique; -
FIG. 11 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the third technique; -
FIG. 12 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with a fourth technique; -
FIG. 13 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a fifth technique; -
FIG. 14 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the fifth technique; -
FIG. 15 illustrates, for one embodiment, a block diagram of a downstream device to report service latency to an upstream device in accordance with a sixth technique; -
FIG. 16 illustrates, for one embodiment, an example flow diagram for a downstream device to report service latency to an upstream device in accordance with the sixth technique; and -
FIG. 17 illustrates, for one embodiment, an example diagram for a downstream device to report service latency to an upstream device in accordance with the sixth technique. - The figures of the drawings are not necessarily drawn to scale.
- The following detailed description sets forth example embodiments of apparatuses, methods, and systems relating to downstream device service latency reporting for power management. Features, such as structure(s), function(s), and/or characteristic(s) for example, are described with reference to one embodiment as a matter of convenience; various embodiments may be implemented with any suitable one or more described features.
-
FIG. 1 illustrates anexample system 100 comprising one ormore processors 110 andplatform control logic 120 coupled to processor(s) 110. Processor(s) 110 for one embodiment may have one or more processor power management controllers (PPMCs) 112 to help improve power efficiency for processor(s) 110.Platform control logic 120 for one embodiment may have a platform controller power management controller (PCPMC) 122 to help improve power efficiency forsystem 100. PCPMC 122 for one embodiment may, for example, manage one or more components ofsystem 100 to enter into one of a plurality of lower power or sleep states when the component is less active or idle. - PCPMC 122 for one embodiment may help coordinate power management for components of
system 100 to help improve power efficiency. PCPMC 122 for one embodiment may, for example, coordinate with one ormore PPMCs 112 for such PPMC(s) 112 and PCPMC 122 to better identify the depth of lower power states which one or more components may enter yet still be responsive to one or more other components with reduced concern for lost functionality and/or performance. - PCPMC 122 for one embodiment may receive from one or more downstream devices, such as
device 132 for example, data corresponding to a service latency for that device. PCPMC 122 for one embodiment may manage power based at least in part on the received data and therefore based at least in part on the corresponding service latency. The service latency for one embodiment may be a service latency tolerance for the device. The service latency for one embodiment may be based at least in part on the maximum latency the device may tolerate without adversely affecting functionality or performance of the device. The service latency for one embodiment may correspond to a level relating to activity for at least a portion of the device. PCPMC 122 for one embodiment may therefore receive over time different service latencies from the device depending at least in part on the activity level for at least a portion of the device. PCPMC 122 for one embodiment may better identify the depth of lower power states which one or more components ofsystem 100 may enter and still be responsive to the device with reduced concern for lost functionality and/or performance. - One or more PPMCs 112 for one embodiment may coordinate with PCPMC 122 and also manage power based at least in part on a service latency for a downstream device. PCPMC 122 for one embodiment may transmit received data corresponding to a service latency for a device to one or
more PPMCs 112 for such PPMC(s) 112 to manage power based at least in part on that service latency. One or more PPMCs 112 for one embodiment may indirectly manage power based at least in part on a service latency for a device based at least in part on how PCPMC 122 manages power based at least in part on that service latency. -
Platform control logic 120 for one embodiment may comprise one ormore interface controllers 124 to communicate with one or more devices, such asdevices more interface controllers 124 for one embodiment may be compatible with any suitable one or more standard specifications such as, for example and without limitation, any suitable Universal Serial Bus (USB) specification (e.g., USB Specification Revision 2.0, Apr. 27, 2000; USB 2.0 Link Power Management Addendum Engineering Change Notice, Jul. 16, 2007; USB 3.0 Specification Revision 1.0, Nov. 12, 2008) and/or any suitable Peripheral Component Interface (PCI) or PCI Express (PCIe) specification (e.g., PCI Express Base Specification Revision 1.0, Jul. 22, 2002; PCI Express Base Specification Revision 2.0, Jan. 15, 2007). - One or
more interface controllers 124 for one embodiment may receive from one or more downstream devices data corresponding to a service latency for the device and transmit such data to PCPMC 122. One ormore interface controllers 124 for one embodiment may include an interface controller power management controller (ICPMC) 126 to help improve power efficiency for theinterface controller 124 and/or for the connection or link to one or more devices. One or more ICPMCs 126 for one embodiment may receive from one or more devices data corresponding to a service latency for the device and manage power based at least in part on the received data and therefore based at least in part on the corresponding service latency. PCPMC 122 for one embodiment may indirectly manage power based at least in part on a service latency for a device based at least in part on how one or more ICPMCs 126 manage power based at least in part on that service latency. - Interface controller(s) 124 for one embodiment may receive data corresponding to a service latency for a device, such as
device 136 for example, downstream from another device, such asdevice 134 for example.Device 134 for one embodiment may receive fromdevice 136 data corresponding to a service latency fordevice 136 and transmit such data to interface controller(s) 124.Device 134 for one embodiment may receive fromdevice 136 data corresponding to a service latency fordevice 136 and manage power fordevice 134 based at least in part on the received data and therefore based at least in part on the corresponding service latency. A corresponding ICPMC 126 for one embodiment may indirectly manage power based at least in part on a service latency fordevice 136 based at least in part on howdevice 134 manages power based at least in part on that service latency. - For one embodiment, power may be managed in
system 100 based at least in part on a service latency for a device as described in U.S. patent application Ser. No. 12/006,251, entitled LATENCY BASED PLATFORM COORDINATION, and filed Dec. 31, 2007; U.S. patent application Ser. No. 12/059,992, entitled PLATFORM POWER MANAGEMENT BASED ON LATENCY GUIDANCE, and filed Mar. 31, 2008; and/or U.S. patent application Ser. No. 12/146,873, entitled COORDINATED LINK POWER MANAGEMENT, and filed Jun. 26, 2008. - As illustrated in
FIG. 1 ,system 100 for one embodiment may also have one ormore input devices 140, one ormore displays 150,volatile memory 160, one or more non-volatile memory and/orstorage devices 170, and one or more communications interfaces 180. - Processor(s) 110 for one embodiment may include one or more memory controllers to provide an interface to
volatile memory 160.Volatile memory 160 may be used to load and store data and/or instructions, for example, forsystem 100.Volatile memory 160 may include any suitable volatile memory, such as suitable dynamic random access memory (DRAM) for example. Processor(s) 110 for one embodiment may use PPMC(s) 112 to help manage power forvolatile memory 160. - Although described as residing with processor(s) 110, one or more memory controllers for one embodiment may reside with
platform control logic 120, allowingplatform control logic 120 to communicate withvolatile memory 160 directly. -
Platform control logic 120 for one embodiment may include any suitable interface controllers, including interface controller(s) 124, to provide for any suitable communications link to processor(s) 110 and/or to any suitable device or component in communication withplatform control logic 120.Platform control logic 120 for one embodiment may usePCPMC 122 to help manage power for any suitable one or more devices and/or components in communication withplatform control logic 120. -
Platform control logic 120 for one embodiment may include one or more graphics controllers to provide an interface to display(s) 150. Display(s) 150 may include any suitable display, such as a cathode ray tube (CRT) or a liquid crystal display (LCD) for example. One or more graphics controllers for one embodiment may alternatively be external toplatform control logic 120. -
Platform control logic 120 for one embodiment may include one or more input/output (I/O) controllers to provide an interface to input device(s) 140, non-volatile memory and/or storage device(s) 170, and communications interface(s) 180. - Input device(s) 140 may include any suitable input device(s), such as a keyboard, a mouse, and/or any other suitable cursor control device.
- Non-volatile memory and/or storage device(s) 170 may be used to store data and/or instructions, for example. Non-volatile memory and/or storage device(s) 170 may include any suitable non-volatile memory, such as flash memory for example, and/or may include any suitable non-volatile storage device(s), such as one or more hard disk drives (HDDs), one or more compact disc (CD) drives, and/or one or more digital versatile disc (DVD) drives for example.
- Communications interface(s) 180 may provide an interface for
system 100 to communicate over one or more networks and/or with any other suitable device. Communications interface(s) 180 may include any suitable hardware and/or firmware. Communications interface(s) 180 for one embodiment may include, for example, a network adapter, a wireless network adapter, a telephone modem, and/or a wireless modem. For wireless communications, communications interface(s) 180 for one embodiment may use one ormore antennas 182. -
Downstream devices platform control logic 120 such as, for example and without limitation, asuitable input device 140, a suitable non-volatile memory orstorage device 170, asuitable communications interface 180, or any other suitable I/O device. Examples of a downstream device may include, without limitation, a cursor control device, a storage drive, a storage device, a hub device, a network router or switch, a battery charging device, a printer, a scanner, a camcorder, a camera, a media player, a cellular telephone, a smart phone, a mobile internet device, and a computer system such as a desktop, notebook, netbook, or other computer system. - Although described as residing with
platform control logic 120, one or more controllers ofplatform control logic 120, including one ormore interface controllers 124, for one embodiment may reside with one ormore processors 110, allowing aprocessor 110 to communicate with one or more devices or components directly. One or more controllers ofplatform control logic 120, including one ormore interface controllers 124, for one embodiment may be integrated on a single die with at least a portion of one ormore processors 110. One or more controllers ofplatform control logic 120, including one ormore interface controllers 124, for one embodiment may be packaged with one ormore processors 110. - Service Latency Reporting
-
FIG. 2 illustrates, for one embodiment, adevice 200 that may report service latency for one or more upstream devices to manage power based at least in part on the service latency.Device 200 for one embodiment may correspond, for example, todownstream device FIG. 1 and report service latency forsystem 100 to manage power based at least in part on the service latency.Device 200 for one embodiment may correspond, for example, todownstream device 136 ofFIG. 1 and report service latency fordevice 134 and/orsystem 100 to manage power based at least in part on the service latency. - As illustrated in
FIG. 2 ,device 200 for one embodiment may comprisedevice control logic 202,interface control logic 204,transition identification logic 206, and servicelatency reporting logic 208.Device control logic 202,interface control logic 204,transition identification logic 206, and servicelatency reporting logic 208 may each be implemented in any suitable manner using, for example, any suitable hardware, any suitable hardware performing any suitable firmware, any suitable hardware performing any suitable software, or any suitable combination of such implementations. For one embodiment, any such firmware and/or software may be stored in any suitable computer readable storage medium or media ofdevice 200.Device 200 for one embodiment may also comprise other suitable logic, circuitry, and/or one or more components to implement any suitable functionality fordevice 200. -
Device control logic 202 for one embodiment may help control the functionality ofdevice 200 and may communicate with one or more upstream devices usinginterface control logic 204 to provide functionality to one or more components of such device(s). -
Interface control logic 204 may be coupled todevice control logic 202 to transmit and/or receive data fordevice 200 in any suitable manner.Interface control logic 204 for one embodiment may be compatible with any suitable one or more standard specifications such as, for example and without limitation, any suitable Universal Serial Bus (USB) specification and/or any suitable Peripheral Component Interface (PCI) or PCI Express (PCIe) specification. -
Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice 200 from one state to another, different state in any suitable manner. Such states for one embodiment may correspond to different levels relating to activity for at least a portion ofdevice 200.Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice control logic 202 from one state to another, different state.Transition identification logic 206 for one embodiment may identify that at least a portion ofdevice 200 is about to transition from one state to another, different state.Transition identification logic 206 for one embodiment may identify that at least a portion ofdevice 200 has already transitioned from one state to another, different state. - Service
latency reporting logic 208 for one embodiment may transmit to an upstream device data corresponding to a service latency in response to identification of a transition bytransition identification logic 206. Servicelatency reporting logic 208 for one embodiment may be coupled to receive identification of a state transition fromtransition identification logic 206 in any suitable manner. Servicelatency reporting logic 208 for one embodiment may be coupled to transmit data corresponding to a service latency in any suitable manner usinginterface control logic 204. - Service
latency reporting logic 208 for one embodiment may identify a service latency in any suitable manner. The service latency for one embodiment may be a service latency tolerance fordevice 200. The service latency for one embodiment may be based at least in part on themaximum latency device 200 may tolerate without adversely affecting functionality or performance ofdevice 200. The service latency for one embodiment may correspond to a new state for at least a portion ofdevice 200. - Service
latency reporting logic 208 for one embodiment may identify a new service latency based at least in part on a prior or current service latency and identification of a state transition. Servicelatency reporting logic 208 for one embodiment may identify a new service latency based at least in part on a new state. Servicelatency reporting logic 208 for one embodiment may identify the new state based at least in part on a prior or current state. Servicelatency reporting logic 208 for one embodiment may receive identification of a new state fromtransition identification logic 206 in any suitable manner. - As at least a portion of
device 200 may continue to transition between states, servicelatency reporting logic 208 for one embodiment may continue to identify new service latencies and transmit data corresponding to such service latencies. Servicelatency reporting logic 208 for one embodiment may optionally not transmit data corresponding to a new service latency, for example if the new service latency is the same as a prior or current service latency. Servicelatency reporting logic 208 for one embodiment may transmit data corresponding to a new service latency in response to one or more but not all transitions between states. -
FIG. 3 illustrates an example flow diagram 300 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 3 , at least a portion ofdevice 200 may be in a first state forblock 302. Servicelatency reporting logic 208 forblock 304 may transmit data corresponding to a first service latency that corresponds to the first state.Transition identification logic 206 may identify forblock 306 whether at least a portion ofdevice 200 has transitioned to or is about to transition to a second, different state. If so, servicelatency reporting logic 208 forblock 308 may transmit data corresponding to a second service latency that corresponds to the second state.Transition identification logic 206 may identify forblock 310 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the first state. If so, servicelatency reporting logic 208 forblock 304 may transmit data corresponding to the first service latency. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 304-310 in this manner. - Although described in connection with first and second service latencies corresponding to first and second states, service
latency reporting logic 208 for one embodiment may transmit data for service latencies corresponding to more than two states. - Service Latency Based at Least in Part on Activity Level
-
Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice 200 between states corresponding to different activity levels. Servicelatency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a state corresponding to a higher activity level and may transmit data corresponding to a higher service latency for a transition to a state corresponding to a lower activity level.Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice 200 between an active state wheredevice 200 has data communications with an upstream device and an idle state wheredevice 200 does not have data communications with an upstream device. - At least a portion of
device 200 for one embodiment may at some times frequently transition between different states. As one example, at least a portion ofdevice 200 for one embodiment may have bursts of activity and therefore at some times frequently transition into and out from a low activity or idle state. Servicelatency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a state transition before transmitting data corresponding to a service latency to help identify whether at least a portion ofdevice 200 is more likely to remain in a new state. In this manner, servicelatency reporting logic 208 for one embodiment may avoid frequently transmitting data corresponding to different service latencies that could otherwise reduce the effectiveness of power management for one or more upstream devices. - Service
latency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a transition to a state corresponding to a service latency higher than a current service latency but not after identification of a transition to a state corresponding to a service latency lower than a current service latency. As one example, servicelatency reporting logic 208 for one embodiment may wait a predetermined period of time after identification of a transition to a low activity or idle state but not after identification of a transition to a higher activity state. - As illustrated in
FIG. 4 , servicelatency reporting logic 208 for one embodiment may have atimer 402 to identify a wait time after identification of a new state transition. Servicelatency reporting logic 208 for one embodiment may compare the wait time with a predetermined threshold and wait until the wait time equals or exceeds the predetermined threshold before transmitting data corresponding to a service latency for the new state transition. Iftransition identification logic 206 identifies a newer state transition before the predetermined threshold has been reached, servicelatency reporting logic 208 for one embodiment may restarttimer 402 for the newer transition. Servicelatency reporting logic 208 for one embodiment may instead, depending for example at least in part on the state for the newer transition, resettimer 402 and transmit data corresponding to a service latency for the newer transition. -
FIG. 5 illustrates an example flow diagram 500 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 5 , at least a portion ofdevice 200 may be in a low activity or idle state forblock 502. Servicelatency reporting logic 208 forblock 504 may transmit data corresponding to a first service latency.Transition identification logic 206 may identify forblock 506 whether at least a portion ofdevice 200 has transitioned to or is about to transition to a higher activity state. If so, servicelatency reporting logic 208 forblock 508 may transmit data corresponding to a second service latency.Transition identification logic 206 may identify forblock 510 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the low activity or idle state. If so, servicelatency reporting logic 208 forblock 512 may wait a predetermined period of time. If at least a portion ofdevice 200 is still in the low activity or idle state forblock 514, servicelatency reporting logic 208 forblock 504 may transmit data corresponding to the first service latency. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 504-514 in this manner. - Although described in connection with idle and active service latencies corresponding to low activity/idle and active states, service
latency reporting logic 208 for one embodiment may transmit data for service latencies corresponding to one or more additional states, such as one or more states corresponding to different levels of activity. - Service Latency Based at Least in Part on Device Buffering
-
Device 200 for one embodiment may receive data from another device for transmission to an upstream device. As illustrated inFIG. 6 ,device control logic 202 for one embodiment may include abuffer 602 to receive data from another device over any suitable communications link, including any suitable wireless link, for subsequent transmission frombuffer 602 to an upstream device usinginterface control logic 204.Device 200 for one embodiment may be, for example, an Ethernet Network Interface Controller (NIC). - For one embodiment when at least a portion of
device 200 is in a low activity or idle state,device 200 may transmit data corresponding to a service latency based at least in part on an available capacity ofbuffer 602 fordevice 200 to receive data. In this manner, an upstream device for one embodiment can remain able to respond within the service latency period to start receiving data frombuffer 602 before the available capacity ofbuffer 602 fills. If the service latency were otherwise higher, an upstream device might possibly enter a deeper, lower power state and not respond in time, allowingbuffer 602 to overflow and incurring performance loss to have lost data retransmitted. -
Transition identification logic 206 for one embodiment may identify a transition from the low activity or idle state to an active state to receive data in and retransmit data frombuffer 602. Servicelatency reporting logic 208 for one embodiment may then transmit data corresponding to a lower service latency to the upstream device. Servicelatency reporting logic 208 for one embodiment may transmit data corresponding to a service latency based at least in part on a reserve capacity ofbuffer 602 fordevice 200 to receive data. In this manner,device 200 may continue to receive data inbuffer 602 as data starts to be transmitted frombuffer 602 to the upstream device. -
FIG. 7 illustrates an example flow diagram 700 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 7 , at least a portion ofdevice 200 may be in a low activity or idle state forblock 702. Servicelatency reporting logic 208 forblock 704 may transmit data corresponding to a service latency based at least in part on an available buffer capacity.Transition identification logic 206 may identify forblock 706 whether at least a portion ofdevice 200 has transitioned to or is about to transition to an active state to receive and retransmit data from another device. If so, servicelatency reporting logic 208 forblock 708 may transmit data corresponding to a service latency based at least in part on a reserve buffer capacity.Transition identification logic 206 may identify forblock 710 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the low activity or idle state. If so, servicelatency reporting logic 208 forblock 704 may transmit data corresponding to the service latency based at least in part on an available buffer capacity. Servicelatency reporting logic 208 for one embodiment may optionally wait a predetermined period of time after identification of a state transition forblock 710 before transmitting data forblock 704. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 704-710 in this manner. - Service
latency reporting logic 208 for one embodiment may account for data rate and/or performance requirements for the upstream device in receiving data to identify a service latency forblocks - Although described in connection with service latencies corresponding to low activity/idle and active states, service
latency reporting logic 208 for one embodiment may transmit data for service latencies corresponding to one or more additional states. For one embodiment, servicelatency reporting logic 208 may transmit data for service latencies corresponding to states that correspond to different ranges of data rates at whichdevice 200 may receive data from another device. For one embodiment, servicelatency reporting logic 208 may transmit data for service latencies corresponding to states that correspond to different performance requirements for the upstream device in receiving data. -
FIG. 8 illustrates an example diagram for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 8 ,buffer 602 receives network data at 802. Prior to receiving network data,device 200 was in an idle state and transmitted to upstream platform components data corresponding to a latency tolerance report (LTR) of 500 microseconds (μs) which is based at least in part on an available capacity ofbuffer 602 and the rate at which network data is received intobuffer 602. Whendevice 200 initially receives network data,device 200 transitions to, or is about to transition to, an active state and transmits data corresponding to an LTR of 100 μs at 802 to upstream platform components. The 100 μs LTR is based at least in part on a reserve capacity ofbuffer 602 and the rate at which network data is received intobuffer 602. The 100 μs LTR takes effect within the prior 500 μs LTR period whilebuffer 602 receives network data. - Upstream platform components respond within the 100 μs LTR at 804, 806, and 808 to receive data from
buffer 602. Whendevice 200 no longer receives network data at 810,device 200 transitions to an idle state, waits a predetermined amount of time illustrated as Timeout, and transmits data corresponding to the 500 μs LTR at 812 to upstream platform components. As illustrated inFIG. 8 , upstream platform components enter various power states based at least in part on the LTRs and responses to receive data frombuffer 602. - Service Latency Based at Least in Part on Power State
-
Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice 200 between states corresponding to different power levels. Servicelatency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a higher power state and may transmit data corresponding to a higher service latency for a transition to a lower power state. - As illustrated in
FIG. 9 ,device control logic 202 for one embodiment may include a device power management controller (DPMC) 902 to help improve power efficiency fordevice 200.DPMC 902 for one embodiment may, for example, manage at least a portion ofdevice 200 to enter into one or more lower power or sleep states when less active or idle. -
FIG. 10 illustrates an example flow diagram 1000 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 10 , at least a portion ofdevice 200 may be in a lower power state forblock 1002. Servicelatency reporting logic 208 forblock 1004 may transmit data corresponding to a first service latency that corresponds to the lower power state.Transition identification logic 206 may identify forblock 1006 whether at least a portion ofdevice 200 has transitioned to or is about to transition to a higher power state. If so, servicelatency reporting logic 208 forblock 1008 may transmit data corresponding to a second service latency that corresponds to the higher power state.Transition identification logic 206 may identify forblock 1010 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the lower power state. If so, servicelatency reporting logic 208 forblock 1004 may transmit data corresponding to the first service latency. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 1004-1010 in this manner. - Although described in connection with first and second service latencies corresponding to lower and higher power states, service
latency reporting logic 208 for one embodiment may transmit data for service latencies corresponding to more than two power states. -
FIG. 11 illustrates an example diagram for one embodiment ofdevice 200 to report service latency to an upstream device.Device 200 forFIG. 11 may be, for example, a wireless local area network (WLAN) device. As illustrated inFIG. 11 ,DPMC 902 may power manage a radio ofdevice 200 and enter into a lower power or sleep state at 1102.Device 200 forFIG. 11 for one embodiment may use a wireless protocol that supports power management features to allowdevice 200 to indicate to an access point or base station, for example, thatdevice 200 is entering a lower power state. No data would then be transmitted todevice 200 when in the lower power state. - Prior to entering the lower power state,
device 200 was in a higher power state and transmitted to an upstream device data corresponding to a latency of 100 microseconds (μs) at 1104. Whendevice 200 is to transition to a lower power state,device 200 transmits to the upstream device data corresponding to a latency of 1 millisecond (ms) at 1106. Whendevice 200 is ready to move data and is to transition to a higher power state,device 200 transmits to the upstream device data corresponding to a latency of 100 μs at 1108. - Service Latency Based at Least in Part on Task Performance
-
Transition identification logic 206 for one embodiment may identify a transition for at least a portion ofdevice 200 between states corresponding to different task performance levels. Servicelatency reporting logic 208 for one embodiment may transmit data corresponding to a lower service latency for a transition to a higher task performance state and may transmit data corresponding to a higher service latency for a transition to a lower task performance state. A higher task performance state for one embodiment may correspond, for example, to a state with one or more pending tasks. A lower task performance state for one embodiment may correspond, for example, to a state with no pending tasks or completion of one or more tasks. -
Device control logic 202 for one embodiment may perform one or more tasks fordevice 200.Device control logic 202 for one embodiment may initiate performance of one or more tasks on its own.Device control logic 202 for one embodiment may perform one or more tasks at the request of another device.Device control logic 202 for one embodiment may perform one or more tasks at the request of an upstream device. -
FIG. 12 illustrates an example flow diagram 1200 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 12 , at least a portion ofdevice 200 may be in a lower task performance state forblock 1202. Servicelatency reporting logic 208 forblock 1204 may transmit data corresponding to a first service latency that corresponds to the lower task performance state.Transition identification logic 206 may identify forblock 1206 whether at least a portion ofdevice 200 has transitioned to or is about to transition to a higher task performance state. If so, servicelatency reporting logic 208 forblock 1208 may transmit data corresponding to a second service latency that corresponds to the higher task performance state.Transition identification logic 206 may identify forblock 1210 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the lower task performance state. If so, servicelatency reporting logic 208 forblock 1204 may transmit data corresponding to the first service latency. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 1204-1210 in this manner. - Although described in connection with first and second service latencies corresponding to lower and higher task performance states, service
latency reporting logic 208 for one embodiment may transmit data for service latencies corresponding to more than two states corresponding to different task performance levels. - Externally Controlled Service Latency
- Service
latency reporting logic 208 for one embodiment may transmit to an upstream device data corresponding to a service latency identified by the upstream device.Device 200 for one embodiment may have a service latency that may be identified by an upstream device, for example, ifdevice 200 does not have a stringent service latency or has service latencies that vary infrequently.Device 200 for one embodiment may have a service latency that may be identified by an upstream device, for example, ifdevice 200 is to perform one or more tasks scheduled by an upstream device. The upstream device for one embodiment may identify a lower service latency fordevice 200 before tasks are scheduled and a higher service latency fordevice 200 when all scheduled tasks are completed. - The upstream device for one embodiment may transmit to
device 200 data corresponding to a service latency identified by the upstream device. The upstream device for one embodiment may perform software to identify a service latency fordevice 200. Such software for one embodiment may be, for example, driver software fordevice 200. - As illustrated in
FIG. 13 , servicelatency reporting logic 208 for one embodiment may includememory 1302 to receive data corresponding to a service latency from an upstream device. For one embodiment, at least a portion ofmemory 1302 may be mapped into memory space of an upstream device.Memory 1302 for one embodiment may include one or more registers.Memory 1302 for one embodiment may be a memory mapped input/output (MMIO) register. -
FIG. 14 illustrates an example flow diagram 1400 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 14 , servicelatency reporting logic 208 forblock 1402 may receive from an upstream device data corresponding to a service latency identified by the upstream device. The upstream device for one embodiment may transmit such data in performing software. Servicelatency reporting logic 208 forblock 1404 may transmit to the upstream device data corresponding to a service latency based at least in part on the data received forblock 1402. Servicelatency reporting logic 208 for one embodiment may transmit data forblock 1404 to a power management controller of the upstream device. - Service Latency Based at Least in Part on Periodic Transitions
- At least a portion of
device 200 for one embodiment may transition from a first state to a second, different state at substantially fixed time intervals. At least a portion ofdevice 200 for one embodiment may transition from a low activity or idle state to a higher activity state at substantially fixed time intervals, returning to the low activity or idle state prior to expiration of the next time interval. As one example,device 200 may communicate with an upstream device at substantially fixed time intervals. - As illustrated in
FIG. 15 ,transition identification logic 206 for one embodiment may have atimer 1502 to identify the expiration of a fixed time interval after identification of a transition for at least a portion ofdevice 200 from a first state to a second, different state to identify another transition for at least a portion ofdevice 200 from the first state to the second state. For another embodiment,device control logic 202 may have a timer to control transition of at least a portion ofdevice 200 from the first state to the second state, andtransition identification logic 206 for one embodiment may identify such a transition for at least a portion ofdevice 200 in any suitable manner. -
FIG. 16 illustrates an example flow diagram 1600 for one embodiment ofdevice 200 to report service latency to an upstream device. As illustrated inFIG. 16 , at least a portion ofdevice 200 may be in a first state forblock 1602. Servicelatency reporting logic 208 forblock 1604 may transmit data corresponding to a first service latency that corresponds to the first state.Transition identification logic 206 may identify forblock 1606 whether at least a portion ofdevice 200 has transitioned to or is about to transition to a second state. If so, servicelatency reporting logic 208 forblock 1608 may transmit data corresponding to a second service latency that corresponds to the second state.Transition identification logic 206 may identify forblock 1610 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the first state. If so, servicelatency reporting logic 208 forblock 1612 may transmit data corresponding to the first service latency.Transition identification logic 206 may identify forblock 1614 whether at least a portion ofdevice 200 has transitioned to or is about to transition to the second state. For one embodiment, such identification may be made based at least in part on expiration of a fixed time interval after a prior identification of a transition from the first state to the second state. If so forblock 1614, servicelatency reporting logic 208 forblock 1608 may transmit data corresponding to the second service latency. Servicelatency reporting logic 208 andtransition identification logic 206 for one embodiment may continue to perform operations for blocks 1608-1614 in this manner. -
FIG. 17 illustrates an example diagram for one embodiment ofdevice 200 to report service latency to an upstream device.Device 200 forFIG. 17 may transition from an idle state to a higher activity state at substantially fixed time intervals, returning to the idle state prior to expiration of the next time interval.Device 200 forFIG. 17 may be, for example, a voice over internet protocol (VOIP) device. - As illustrated in
FIG. 17 ,device 200 at 1702 may transition from a higher activity state, represented by a transfer of data betweendevice 200 and an upstream device, to an idle state and transmit to the upstream device data corresponding to a 1 millisecond (ms) service latency.Device 200 at 1704 may transmit to the upstream device data corresponding to a 20 microsecond (μs) service latency whendevice 200 is about to again enter the higher activity state. Asdevice 200 is to enter the higher activity state at substantially 20 ms time intervals,device 200 may transmit to the upstream device data corresponding to a 20 microsecond (μs) service latency at substantially 20 ms time intervals. - In the foregoing description, example embodiments have been described. Various modifications and changes may be made to such embodiments without departing from the scope of the appended claims. The description and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Claims (25)
1. An apparatus comprising:
first logic to identify a transition for at least a portion of a downstream device from a first state to a second, different state, wherein the first and second states correspond to different levels relating to activity for at least a portion of the downstream device; and
second logic to transmit to an upstream device data corresponding to a service latency in response to the identified transition for one or more upstream devices to manage power based at least in part on the service latency.
2. The apparatus of claim 1 , wherein the second logic is to wait a predetermined period of time after identification of the transition before transmitting the data.
3. The apparatus of claim 2 , wherein the second state is an idle state.
4. The apparatus of claim 1 , wherein the second state is an idle state and the service latency is based at least in part on an available capacity of a buffer for the downstream device to receive data.
5. The apparatus of claim 1 , wherein the second state is an active state and the service latency is based at least in part on a reserve capacity of a buffer for the downstream device to receive data.
6. The apparatus of claim 1 , wherein the second state is a lower power state relative to the first state.
7. The apparatus of claim 1 , wherein the first state corresponds to the performance of one or more tasks by the downstream device and the second state corresponds to completion of one or more tasks by the downstream device.
8. The apparatus of claim 1 , wherein the second logic is to transmit to an upstream device data corresponding to a service latency identified by the upstream device.
9. The apparatus of claim 1 , wherein at least a portion of the downstream device is to transition from the first state to the second state at substantially fixed time intervals.
10. The apparatus of claim 1 , wherein the first logic is to identify that at least a portion of the downstream device is about to transition from the first state to the second state.
11. The apparatus of claim 1 , wherein the first logic is to identify that at least a portion of the downstream device has transitioned from the first state to the second state.
12. A method comprising:
identifying a transition for at least a portion of a downstream device from a first state to a second, different state, wherein the first and second states correspond to different levels relating to activity for at least a portion of the downstream device; and
transmitting to an upstream device data corresponding to a service latency in response to the identified transition for one or more upstream devices to manage power based at least in part on the service latency.
13. The method of claim 12 , comprising waiting a predetermined period of time after identification of the transition before transmitting the data.
14. The method of claim 12 , wherein the second state is an idle state and the service latency is based at least in part on an available capacity of a buffer for the downstream device to receive data.
15. The method of claim 12 , wherein the second state is a lower power state relative to the first state.
16. The method of claim 12 , wherein the first state corresponds to the performance of one or more tasks by the downstream device and the second state corresponds to completion of one or more tasks by the downstream device.
17. The method of claim 12 , wherein the transmitting includes transmitting to an upstream device data corresponding to a service latency identified by the upstream device.
18. The method of claim 12 , comprising transitioning by at least a portion of the downstream device from the first state to the second state at substantially fixed time intervals.
19. A downstream device comprising:
first logic to identify a transition for at least a portion of the downstream device from a first state to a second, different state, wherein the first and second states correspond to different levels relating to activity for at least a portion of the downstream device;
second logic to transmit to an upstream device data corresponding to a service latency in response to the identified transition for one or more upstream devices to manage power based at least in part on the service latency; and
third logic to help control functionality of the downstream device.
20. The downstream device of claim 19 , wherein the second logic is to wait a predetermined period of time after identification of the transition before transmitting the data.
21. The downstream device of claim 19 , wherein the second state is an idle state and the service latency is based at least in part on an available capacity of a buffer for the downstream device to receive data.
22. The downstream device of claim 19 , wherein the second state is a lower power state relative to the first state.
23. The downstream device of claim 19 , wherein the first state corresponds to the performance of one or more tasks by the downstream device and the second state corresponds to completion of one or more tasks by the downstream device.
24. The downstream device of claim 19 , wherein the second logic is to transmit to an upstream device data corresponding to a service latency identified by the upstream device.
25. The downstream device of claim 19 , wherein at least a portion of the downstream device is to transition from the first state to the second state at substantially fixed time intervals.
Priority Applications (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US14/095,982 US20140095908A1 (en) | 2008-12-31 | 2013-12-03 | Downstream device service latency reporting for power management |
US14/595,085 US9838967B2 (en) | 2008-12-31 | 2015-01-12 | Downstream device service latency reporting for power management |
US15/453,208 US10182398B2 (en) | 2008-12-31 | 2017-03-08 | Downstream device service latency reporting for power management |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/346,853 US8601296B2 (en) | 2008-12-31 | 2008-12-31 | Downstream device service latency reporting for power management |
US14/095,982 US20140095908A1 (en) | 2008-12-31 | 2013-12-03 | Downstream device service latency reporting for power management |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/346,853 Continuation US8601296B2 (en) | 2008-12-31 | 2008-12-31 | Downstream device service latency reporting for power management |
Related Child Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/595,085 Continuation US9838967B2 (en) | 2008-12-31 | 2015-01-12 | Downstream device service latency reporting for power management |
Publications (1)
Publication Number | Publication Date |
---|---|
US20140095908A1 true US20140095908A1 (en) | 2014-04-03 |
Family
ID=42221144
Family Applications (4)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/346,853 Active 2030-03-02 US8601296B2 (en) | 2008-12-31 | 2008-12-31 | Downstream device service latency reporting for power management |
US14/095,982 Abandoned US20140095908A1 (en) | 2008-12-31 | 2013-12-03 | Downstream device service latency reporting for power management |
US14/595,085 Active 2029-02-16 US9838967B2 (en) | 2008-12-31 | 2015-01-12 | Downstream device service latency reporting for power management |
US15/453,208 Active 2029-05-01 US10182398B2 (en) | 2008-12-31 | 2017-03-08 | Downstream device service latency reporting for power management |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/346,853 Active 2030-03-02 US8601296B2 (en) | 2008-12-31 | 2008-12-31 | Downstream device service latency reporting for power management |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US14/595,085 Active 2029-02-16 US9838967B2 (en) | 2008-12-31 | 2015-01-12 | Downstream device service latency reporting for power management |
US15/453,208 Active 2029-05-01 US10182398B2 (en) | 2008-12-31 | 2017-03-08 | Downstream device service latency reporting for power management |
Country Status (6)
Country | Link |
---|---|
US (4) | US8601296B2 (en) |
JP (1) | JP5385124B2 (en) |
KR (1) | KR101162156B1 (en) |
CN (1) | CN101853065B (en) |
DE (1) | DE102009060269B4 (en) |
TW (1) | TWI439863B (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9838967B2 (en) | 2008-12-31 | 2017-12-05 | Intel Corporation | Downstream device service latency reporting for power management |
Families Citing this family (28)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8176341B2 (en) * | 2008-03-31 | 2012-05-08 | Intel Corporation | Platform power management based on latency guidance |
US8255713B2 (en) | 2008-06-26 | 2012-08-28 | Intel Corporation | Management of link states using plateform and device latencies |
US8612998B2 (en) | 2010-09-23 | 2013-12-17 | Intel Corporation | Coordinating device and application break events for platform power saving |
US8607075B2 (en) | 2008-12-31 | 2013-12-10 | Intel Corporation | Idle duration reporting for power management |
US8504855B2 (en) * | 2010-01-11 | 2013-08-06 | Qualcomm Incorporated | Domain specific language, compiler and JIT for dynamic power management |
US9235251B2 (en) | 2010-01-11 | 2016-01-12 | Qualcomm Incorporated | Dynamic low power mode implementation for computing devices |
US8689028B2 (en) * | 2011-07-01 | 2014-04-01 | Intel Corporation | Method and apparatus to reduce idle link power in a platform |
WO2013077889A1 (en) | 2011-11-22 | 2013-05-30 | Intel Corporation | Collaborative processor and system performance and power management |
TWI493332B (en) * | 2011-11-29 | 2015-07-21 | Intel Corp | Method and apparatus with power management and a platform and computer readable storage medium thereof |
CN103218032B (en) | 2011-11-29 | 2017-07-14 | 英特尔公司 | Utilize the power management of relative energy break-even time |
US9264986B2 (en) * | 2012-06-25 | 2016-02-16 | Qualcomm Incorporated | System and method for reducing power consumption in a wireless communication system |
US9015510B2 (en) * | 2012-06-29 | 2015-04-21 | Intel Corporation | Optimizing energy efficiency using device idle duration information and latency tolerance based on a pre-wake configuration of a platform associated to the device |
US20140006826A1 (en) * | 2012-06-30 | 2014-01-02 | Mahesh Wagh | Low power low frequency squelch break protocol |
US20140181563A1 (en) * | 2012-12-24 | 2014-06-26 | Neil Songer | System and method for determination of latency tolerance |
US9244521B2 (en) | 2012-12-26 | 2016-01-26 | Intel Corporation | Supporting runtime D3 and buffer flush and fill for a peripheral component interconnect device |
US9158357B2 (en) | 2012-12-28 | 2015-10-13 | Intel Corporation | System and method for conveying service latency requirements for devices connected to low power input/output sub-systems |
US9176570B2 (en) | 2012-12-29 | 2015-11-03 | Intel Corporation | System and method for providing universal serial bus link power management policies in a processor environment |
US9229525B2 (en) | 2013-06-17 | 2016-01-05 | Apple Inc. | Adaptive latency tolerance for power management of memory bus interfaces |
US9195292B2 (en) | 2013-06-26 | 2015-11-24 | Intel Corporation | Controlling reduced power states using platform latency tolerance |
US9501128B2 (en) * | 2013-10-30 | 2016-11-22 | Globalfoundries Inc. | Cooperative reduced power mode suspension for high input/output (‘I/O’) workloads |
JP6455382B2 (en) * | 2015-09-24 | 2019-01-23 | 富士通株式会社 | Control device and control program |
JP7163002B2 (en) * | 2016-05-25 | 2022-10-31 | キヤノン株式会社 | Information processing apparatus and processor power saving method for determining power saving level of processor according to recovery time notified from device connected to processor |
US10705591B2 (en) * | 2016-10-31 | 2020-07-07 | Microsoft Technology Licensing, Llc | Aggregated electronic device power management |
KR20180109142A (en) * | 2017-03-27 | 2018-10-08 | 에스케이하이닉스 주식회사 | Memory system and operating method of memory system |
DE102017117876A1 (en) * | 2017-08-07 | 2019-02-07 | Festo Ag & Co. Kg | Production module for a production plant |
US11552892B2 (en) * | 2019-08-30 | 2023-01-10 | Ati Technologies Ulc | Dynamic control of latency tolerance reporting values |
US11086384B2 (en) | 2019-11-19 | 2021-08-10 | Intel Corporation | System, apparatus and method for latency monitoring and response |
US20220200881A1 (en) * | 2020-12-21 | 2022-06-23 | Intel Corporation | Methods and devices for adaptive rate based latency tolerance reporting |
Family Cites Families (32)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5555383A (en) * | 1994-11-07 | 1996-09-10 | International Business Machines Corporation | Peripheral component interconnect bus system having latency and shadow timers |
JP2001318742A (en) | 2000-05-08 | 2001-11-16 | Mitsubishi Electric Corp | Computer system and computer readable recording medium |
JP2002082743A (en) | 2000-09-06 | 2002-03-22 | Casio Comput Co Ltd | Electronic equipment and storage medium stored with electronic equipment control program |
US8375415B2 (en) | 2001-03-19 | 2013-02-12 | General Instrument Corporation | Dynamic upstream amplifier power management |
US20030065497A1 (en) | 2001-09-28 | 2003-04-03 | Rhoads Monte J. | Power management system to select a power state for a network computer system based on load |
US7564810B2 (en) * | 2002-05-08 | 2009-07-21 | Microsoft Corporation | Method and system for managing power consumption of a network interface module in a wireless computing device |
US7372814B1 (en) * | 2003-02-27 | 2008-05-13 | Alcatel-Lucent | Network system with color-aware upstream switch transmission rate control in response to downstream switch traffic buffering |
JP2004320153A (en) * | 2003-04-11 | 2004-11-11 | Sony Corp | Radio communication system and power control method thereof |
US7188263B1 (en) * | 2003-05-07 | 2007-03-06 | Nvidia Corporation | Method and apparatus for controlling power state of a multi-lane serial bus link having a plurality of state transition detectors wherein powering down all the state transition detectors except one |
JP4316399B2 (en) | 2004-02-18 | 2009-08-19 | インターナショナル・ビジネス・マシーンズ・コーポレーション | Program, recording medium, control method, and information processing apparatus |
TWI311705B (en) * | 2005-05-23 | 2009-07-01 | Via Tech Inc | Peripheral component interconnect express and changing method of link power states thereof |
US7493228B2 (en) * | 2005-06-23 | 2009-02-17 | Intel Corporation | Method and system for deterministic throttling for thermal management |
US7430673B2 (en) * | 2005-06-30 | 2008-09-30 | Intel Corporation | Power management system for computing platform |
US7447824B2 (en) * | 2005-10-26 | 2008-11-04 | Hewlett-Packard Development Company, L.P. | Dynamic lane management system and method |
WO2007098411A2 (en) | 2006-02-17 | 2007-08-30 | Standard Microsystems Corporation | Transmission network having an optical receiver that utilizes dual power pins and a single status pin to lower power consumption, lower manufacturing cost, and increase transmission efficiency |
US7734853B2 (en) * | 2006-02-28 | 2010-06-08 | Arm Limited | Latency dependent data bus transmission |
US7752473B1 (en) * | 2006-03-20 | 2010-07-06 | Intel Corporation | Providing a deterministic idle time window for an idle state of a device |
US7406365B2 (en) * | 2006-03-31 | 2008-07-29 | Intel Corporation | Power manager with selective load reduction |
US7480753B2 (en) | 2006-04-27 | 2009-01-20 | Standard Microsystems Corporation | Switching upstream and downstream logic between ports in a universal serial bus hub |
TWI312927B (en) | 2006-06-06 | 2009-08-01 | Via Tech Inc | Method for setting power management status of device and power-saving method of the same |
US8291244B2 (en) | 2006-07-28 | 2012-10-16 | Arm Limited | Power management in a data processing device having masters and slaves |
US7716506B1 (en) * | 2006-12-14 | 2010-05-11 | Nvidia Corporation | Apparatus, method, and system for dynamically selecting power down level |
JP2008238033A (en) | 2007-03-27 | 2008-10-09 | Kubota Corp | Calcium removing method and calcium removing apparatus |
US7984314B2 (en) * | 2007-05-14 | 2011-07-19 | Intel Corporation | Power management of low power link states |
US7864720B2 (en) * | 2007-06-01 | 2011-01-04 | Intel Corporation | Power management for wireless devices |
GB2452778A (en) * | 2007-09-17 | 2009-03-18 | Toshiba Res Europ Ltd | Linking dynamic voltage scaling in master and slave modules |
US20090172434A1 (en) * | 2007-12-31 | 2009-07-02 | Kwa Seh W | Latency based platform coordination |
US8176341B2 (en) * | 2008-03-31 | 2012-05-08 | Intel Corporation | Platform power management based on latency guidance |
US8255713B2 (en) * | 2008-06-26 | 2012-08-28 | Intel Corporation | Management of link states using plateform and device latencies |
JP5109935B2 (en) | 2008-11-10 | 2012-12-26 | 富士通株式会社 | Processor system operating method and processor system |
US8607075B2 (en) * | 2008-12-31 | 2013-12-10 | Intel Corporation | Idle duration reporting for power management |
US8601296B2 (en) | 2008-12-31 | 2013-12-03 | Intel Corporation | Downstream device service latency reporting for power management |
-
2008
- 2008-12-31 US US12/346,853 patent/US8601296B2/en active Active
-
2009
- 2009-12-23 DE DE102009060269.0A patent/DE102009060269B4/en active Active
- 2009-12-23 TW TW098144512A patent/TWI439863B/en active
- 2009-12-24 KR KR1020090130939A patent/KR101162156B1/en active IP Right Grant
- 2009-12-24 JP JP2009293551A patent/JP5385124B2/en active Active
- 2009-12-26 CN CN2009110001033A patent/CN101853065B/en active Active
-
2013
- 2013-12-03 US US14/095,982 patent/US20140095908A1/en not_active Abandoned
-
2015
- 2015-01-12 US US14/595,085 patent/US9838967B2/en active Active
-
2017
- 2017-03-08 US US15/453,208 patent/US10182398B2/en active Active
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9838967B2 (en) | 2008-12-31 | 2017-12-05 | Intel Corporation | Downstream device service latency reporting for power management |
US10182398B2 (en) | 2008-12-31 | 2019-01-15 | Intel Corporation | Downstream device service latency reporting for power management |
Also Published As
Publication number | Publication date |
---|---|
CN101853065A (en) | 2010-10-06 |
JP2010165350A (en) | 2010-07-29 |
KR20100080395A (en) | 2010-07-08 |
KR101162156B1 (en) | 2012-07-05 |
US10182398B2 (en) | 2019-01-15 |
US20100169684A1 (en) | 2010-07-01 |
US9838967B2 (en) | 2017-12-05 |
TW201040729A (en) | 2010-11-16 |
TWI439863B (en) | 2014-06-01 |
CN101853065B (en) | 2012-11-28 |
DE102009060269B4 (en) | 2014-10-16 |
DE102009060269A1 (en) | 2010-07-01 |
US8601296B2 (en) | 2013-12-03 |
JP5385124B2 (en) | 2014-01-08 |
US20170177539A1 (en) | 2017-06-22 |
US20150257101A1 (en) | 2015-09-10 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US10182398B2 (en) | Downstream device service latency reporting for power management | |
US9459684B2 (en) | Idle duration reporting for power management | |
US11176068B2 (en) | Methods and apparatus for synchronizing uplink and downlink transactions on an inter-device communication link | |
US9740645B2 (en) | Reducing latency in a peripheral component interconnect express link | |
US8560749B2 (en) | Techniques for managing power consumption state of a processor involving use of latency tolerance report value | |
US10394309B2 (en) | Power gated communication controller | |
CN103076868B (en) | The electronic system of method for managing power supply and application the method | |
US8650427B2 (en) | Activity alignment algorithm by masking traffic flows | |
KR20180049340A (en) | Storage device and link state control method thereof | |
JP2017520052A (en) | Universal serial bus (USB) communication system and method | |
TW202215202A (en) | Power-saving techniques in computing devices through communication bus control | |
CN114265494A (en) | Working mode switching method and device, and data transmission method and device |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |