Embodiments relate to power control in an integrated circuit.
In modern systems on chip (SoCs) and processors, it is common for several intellectual property (IP) agents to share a power rail. While each of these IP agents can be individually power controlled, typically at least portions of such IP agents remain powered on even when not busy, due to the possibility of an access from software. Even when an individual IP agent is power gated, power loss occurs due to leakage.
Advances in semiconductor processing and logic design have permitted an increase in the amount of logic that may be present on integrated circuit devices. As a result, computer system configurations have evolved from a single or multiple integrated circuits in a system to multiple hardware threads, multiple cores, multiple devices, and/or complete systems on individual integrated circuits. Additionally, as the density of integrated circuits has grown, the power requirements for computing systems (from embedded systems to servers) have also escalated. Furthermore, software inefficiencies, and its requirements of hardware, have also caused an increase in computing device energy consumption. In fact, some studies indicate that computing devices consume a sizeable percentage of the entire electricity supply for a country, such as the United States of America. As a result, there is a vital need for energy efficiency and conservation associated with integrated circuits. These needs will increase as servers, desktop computers, notebooks, Ultrabooks™, tablets, mobile phones, processors, embedded systems, etc. become even more prevalent (from inclusion in the typical computer, automobiles, and televisions to biotechnology).
In various embodiments, a SoC or other processor having one or more processing units (e.g., one or more general-purpose processor cores) may further include a plurality of intellectual property (IP) agents. Many different types of IP agents may be present in different embodiments. Although the scope of the present invention is not limited in this regard, example IP agents include various on-chip dedicated processing units, interface circuits and so forth. For example, IP agents may include media processors, fixed function processors, sensors of many different varieties, interface circuits, and so forth.
With an SoC as described herein, multiple IP agents may be coupled to a shared power rail. Embodiments provide techniques to enable such multiple IP agents to be power controlled collectively as a group, in addition to being independently power controlled. In this way, greater power savings may be realized by powering down both the IP agents coupled to the shared power rail, and the shared power rail itself, and potentially its power source also. Embodiments may enable such collective power control and powering down of IP agents and shared power rail even when additional portions of the SoC remain in an active, operating state. For example, when the SoC is in a so-called package C0 state, and it is determined that all IP agents coupled to a particular shared power rail are in at least a given low power state, these IP agents and shared power rail may be powered down. And optionally, any allocated power budget for these components can be re-allocated to operating components of the SoC, such as one or more general-purpose processor cores.
In embodiments, a power controller may be configured to perform such group IP agent/power rail powering down when it is determined that all IP agents coupled to a particular shared power rail are in an idle state. To this end, the power controller may cause each IP agent, when idle, to be transitioned into a power gated state in which the IP agent is decoupled by a power gate circuit from receiving an operating voltage from the shared power rail. Then, when the power controller determines that all IP agents coupled to a shared power rail are in at least a particular low power states (e.g., a so-called device low power state such as a device D3 low power state), all access to the IP agents via any shared bus may be blocked. Still further, the power controller may cause both the IP agents and the shared power rail to be powered down. Once in this state, should a software agent seek access to any of the IP agents in the powered down state, the power controller may perform a low power state exit protocol to cause the shared power rail and at least one of the IP agents to exit the idle state and be powered on.
In embodiments, this collective idle state in which both a shared power rail and multiple IP agents are in a low power state can be made visible to system software, e.g., via the power controller. In a particular embodiment, the power controller may communicate an acknowledgment message to an operating system or other system software when this state has been entered, where this state may be identified to the OS as a TC Cold state. With this indication, the operating system or other system software can prevent requesters from accessing such IP agents, at least until a power on protocol completes.
Referring now to
Of particular interest herein, note IP agents 130 are coupled to a common or shared power rail 127. More specifically, shared power rail 127 is to provide an operating voltage to IP agents 130. In the embodiment shown, this operating voltage is a regulated voltage received from an integrated voltage regulator (IVR) 125. In turn, IVR 125 receives an incoming voltage from an off-chip source such as a power supply, an external voltage regulator or so forth. Although shown with this particular implementation in
In embodiments herein, since IP agents 130 all are coupled to a shared power rail, when all the IP agents are in an idle power state, greater power savings may be realized by powering off shared power rail 127 (and further in some cases powering off IVR 125).
As further illustrated in
To realize the ability to dynamically shut down shared power rail 127 in situations when a remainder of SoC 100 is powered on (e.g., in a package C0 or other active power state), PMU 120 may interact with software, such as an operating system (OS) that executes on CPU 110. To this end, this OS may maintain a table listing the power state of IP agents coupled to the shared power rail. As illustrated in
As further illustrated, SoC 110 also includes a read-only memory 140 which may store firmware, such as BIOS or other firmware code. In embodiments herein, such firmware may provide a declaration 145 to the OS which identifies the IP agents that are present on a given shared power rail, such that the power management operations described herein may proceed.
Of course, SoC 100 may include further components. In the embodiment shown, one or more communication circuits 160 may be present. Such communication circuits 160 may include both wired and wireless communication circuits to enable interaction with other devices using wired or wireless techniques. As also illustrated, an interface circuit 170 may provide an interface to other chip components such as other types of processors, peripheral devices or so forth. Understand while shown at this high level in the embodiment of
Referring now to
Next, control passes to block 220 where the IP agent is caused to enter into an idle state and is power gated. To this end, the PMU may initiate activities to cause the IP agent to enter a low power state. Such activities may include sending a low power state command to the IP agent to cause it to perform a shutdown protocol, which may include storing any state present in the IP agent to another location (e.g., an on-chip storage). In response to completing the power down activities, note that the IP agent may send an acknowledgment back to the PMU to indicate that is ready to be powered down. At this point, to reduce power consumption, the PMU may cause the IP agent to be power gated, e.g., by activating a power gate circuit through which the IP agent receives its operating voltage. While this may reduce power consumption, nevertheless there can be leakage.
As such, embodiments may realize additional power savings when it is determined that all IP agents on a shared power rail are in a low power state. Accordingly as further shown in
Still with reference to
Next at block 250, it is further possible to optionally cause a shared bus to be powered down. For example, when a shared bus only couples to IP agents (or other endpoint agents) that are in an idle state, the shared bus can be powered down. Even though one or more devices, such as a CPU or interface circuit coupled to the shared bus remain in a power on state.
Referring now to
As illustrated, method 300 begins by receiving a request for an IP agent to be powered on from the idle state (block 310). Such request may be received, in one embodiment, from an OS. Next, control passes to block 320 where the PMU may cause the shared power rail (and a shared communication bus, if powered off) to be powered on. Next at block 330, the IP agent is caused to enter an active state.
As illustrated further in
Referring now to
As illustrated, method 400 begins by receiving an indication that a shared power rail is powered down (block 410). This indication may be received in the PMU, e.g., from the OS that reports, via BIOS or other firmware, that all IP agents coupled to a shared power rail are in an idle state such that the shared power rail itself can be power down.
After activities to power down the rail occur, this indication is thus positive such that control next passes to block 420. At block 420, the PMU may update an available power budget for the SoC. That is, an SoC may have a given allocated power budget in which each component of the SoC is provided with a portion of a total power budget. With multiple IP agents on the shared power rail in a power down state, the allocated power budget for these components becomes available for providing to other components. As such, the available power budget may be updated. For example, assume an SoC has an overall power budget of 15 Watts (W) and that a shared power rail with 3 IP agents consumes 2 W of that total power budget. When the shared power rail and the IP agents are powered down, this 2 W becomes additional available power budget for the SoC, in an embodiment. Without an embodiment, assume only 8 W is allocated for the cores, which enables them to run at 2 GHz. Instead, with an embodiment in which the 3 IP agents on the shared power rail are powered down, the cores can receive an additional 2 Watts, and realize a performance boost by running at 2.2 GHz using 10 W, as an example.
As such, at block 430 this additional power can be allocated to, e.g., one or more CPUs of the SoC based on the updated available power budget. With this additional power increase, such one or more CPUs may operate at a higher frequency and/or higher voltage. Of course in different cases, other components of the SoC may be allocated an increased power budget in this situation. Understand further that if a request is made to power on the shared power rail and one or more of the IP agents, a reallocation of the power budget occurs so that available power budget is present to power the shared power rail and the one or more IP agents. Understand while shown at this high level in the embodiment of
Referring now to
An OS may next determine that all IP agents on a given shared power rail are in an idle state. This determination may be with reference to a table that identifies that all agents on a common power rail are in an idle power state. As such, the OS may send a power down message to BIOS or other firmware that in turn initiates a power down enable signal to a power management controller (PMC) to cause appropriate hardware to be powered down. In this instance, PMC may send power down messages to the individual IP agents (if they have not already been appropriately powered down) and the shared power rail and/or IVR that provides the operating voltage to the shared power rail. In response to this activity, the PMC may send an acknowledgment message to the BIOS that the shared power rail has been powered down, and in turn the BIOS may optionally acknowledge to the OS that the shared power rail is powered down. At this point a shared bus optionally also may be powered down. Note that in this instance in which all such IP agents on the shared power rail (and shared communication bus) are powered down, remaining portions of the SoC such as one or more CPUs may continue to operate in an active state (and may receive additional power allocations).
Referring now to
For example note that the PC or other hardware also may initiate a power up of the shared power rail and one or more IP agents, for example, due to a new device connection or for another reason. Or in the case that one of the IP agents is a USB interface, a user moves a USB-based mouse to take it and the whole system out of idleness. In such cases, the power controller can cause a driver for a newly powered IP agent to be woken via an interrupt to the OS, that in turn triggers the driver.
With embodiments, a large number of IP agents or groups of IP agents can be integrated on an SoC without incurring additional leakage or idle power in a package C0 state when it is determined that all of a group of IP agents coupled to a shared power rail are in an appropriate low power state. Still further, with embodiments a power controller can selectively cause IP agents and an associated shared power rail to be powered down while the SoC is in an active state. Stated another way, the power controller need not wait for a full idle condition of the SoC in which the OS and all other general-purpose processor cores and other processing units become idle before causing this group power down. Instead, the power controller can perform the power down activities described herein when it is determined that all IP agents of a group are idle and the OS indicates that this group of IP agents is in an appropriate idle state (e.g., a given device low power state). In an embodiment, a power controller can gate/power down a group so long as the IP agents of the group are idle and the OS informs the power controller that the agents are in the D3 state, and that the operating system will not allow software to access any of these IP agents until an appropriate low power state exit process has been completed.
In contrast, without an embodiment there may be significantly reduced ability for both IP agents and a shared power rail to enter into low power states as described herein. That is, without an embodiment, if an IP agent is enabled at boot time, software agents can potentially access the IP agents at any time such that the IP agent is not power gated when idle when software/cores are active. Instead with embodiments, techniques are provided to power down a group of IP agents and a shared power rail, while other components such as one or more cores and software are in an active state. Embodiments may be applicable to all platforms (e.g., client/devices/servers), and can enable partially powered SoCs even in a package C0 state when software is running, and re-allocating power budget to parts of SoC that are really doing active work.
Embodiments may be used in different system types. Referring now to
As seen, processor 710 may be a single die processor including multiple cores 720a-720n. In addition, each core may be associated with an IVR 725a-725n which receives the primary regulated voltage and generates an operating voltage to be provided to one or more agents of the processor associated with the IVR. Accordingly, an IVR implementation may be provided to allow for fine-grained control of voltage and thus power and performance of each individual core. As such, each core can operate at an independent voltage and frequency, enabling great flexibility and affording wide opportunities for balancing power consumption with performance. In some embodiments, the use of multiple IVRs enables the grouping of components into separate power planes, such that power is regulated and supplied by the IVR to only those components in the group. During power management, a given power plane of one IVR may be powered down or off when the processor is placed into a certain low power state, while another power plane of another IVR remains active, or fully powered. Similarly, cores 720 may include or be associated with independent clock generation circuitry such as one or more phase lock loops (PLLs) to control operating frequency of each core 720 independently.
Still referring to
Also shown is a power control unit (PCU) 738, which may include circuitry including hardware, software and/or firmware to perform power management operations with regard to processor 710. As seen, PCU 738 provides control information to external voltage regulator 760 via a digital interface 762 to cause the voltage regulator to generate the appropriate regulated voltage. PCU 738 also provides control information to IVRs 725 via another digital interface 763 to control the operating voltage generated (or to cause a corresponding IVR to be disabled in a low power mode). And as described herein, this control may include powering down of both shared power rails and IVRs, when components coupled to such power rails are in an idle state. PCU 738 may further in such instances re-allocate any power budget from these powered down components to other active components, such as cores 720, as described herein. In various embodiments, PCU 738 may include a variety of power management logic units or circuits to perform hardware-based power management. Such power management may be wholly processor controlled (e.g., by various processor hardware, and which may be triggered by workload and/or power, thermal or other processor constraints) and/or the power management may be performed responsive to external sources (such as a platform or power management source or system software).
In
Embodiments may be particularly suitable for a multicore processor in which each of multiple cores can operate at an independent voltage and frequency point. As used herein the term “domain” is used to mean a collection of hardware and/or logic that operates at the same voltage and frequency point. In addition, a multicore processor can further include other non-core processing engines such as fixed function units, graphics engines, and so forth. Such processor can include independent domains other than the cores, such as one or more domains associated with a graphics engine (referred to herein as a graphics domain) and one or more domains associated with non-core circuitry, referred to herein as an uncore or a system agent. Although many implementations of a multi-domain processor can be formed on a single semiconductor die, other implementations can be realized by a multi-chip package in which different domains can be present on different semiconductor die of a single package.
While not shown for ease of illustration, understand that additional components may be present within processor 710 such as additional control circuitry, and other components such as internal memories, e.g., one or more levels of a cache memory hierarchy and so forth. Furthermore, while shown in the implementation of
Note that the power management techniques described herein may be independent of and complementary to an operating system (OS)-based power management (OSPM) mechanism. According to one example OSPM technique, a processor can operate at various performance states or levels, so-called P-states, namely from P0 to PN. In general, the P1 performance state may correspond to the highest guaranteed performance state that can be requested by an OS. In addition to this P1 state, the OS can further request a higher performance state, namely a P0 state. This P0 state may thus be an opportunistic, overclocking, or turbo mode state in which, when power and/or thermal budget is available, processor hardware can configure the processor or at least portions thereof to operate at a higher than guaranteed frequency. In many implementations a processor can include multiple so-called bin frequencies above the P1 guaranteed maximum frequency, exceeding to a maximum peak frequency of the particular processor, as fused or otherwise written into the processor during manufacture. In addition, according to one OSPM mechanism, a processor can operate at various power states or levels. With regard to power states, an OSPM mechanism may specify different power consumption states, generally referred to as C-states, C0, C1 to Cn states. When a core is active, it runs at a C0 state, and when the core is idle it may be placed in a core low power state, also called a core non-zero C-state (e.g., C1-C6 states), with each C-state being at a lower power consumption level (such that C6 is a deeper low power state than C1, and so forth).
Understand that many different types of power management techniques may be used individually or in combination in different embodiments. As representative examples, a power controller may control the processor to be power managed by some form of dynamic voltage frequency scaling (DVFS) in which an operating voltage and/or operating frequency of one or more cores or other processor logic may be dynamically controlled to reduce power consumption in certain situations. In an example, DVFS may be performed using Enhanced Intel SpeedStep™ technology available from Intel Corporation, Santa Clara, Calif., to provide optimal performance at a lowest power consumption level. In another example, DVFS may be performed using Intel TurboBoost™ technology to enable one or more cores or other compute engines to operate at a higher than guaranteed operating frequency based on conditions (e.g., workload and availability).
Another power management technique that may be used in certain examples is dynamic swapping of workloads between different compute engines. For example, the processor may include asymmetric cores or other processing engines that operate at different power consumption levels, such that in a power constrained situation, one or more workloads can be dynamically switched to execute on a lower power core or other compute engine. Another exemplary power management technique is hardware duty cycling (HDC), which may cause cores and/or other compute engines to be periodically enabled and disabled according to a duty cycle, such that one or more cores may be made inactive during an inactive period of the duty cycle and made active during an active period of the duty cycle.
Power management techniques also may be used when constraints exist in an operating environment. For example, when a power and/or thermal constraint is encountered, power may be reduced by reducing operating frequency and/or voltage. Other power management techniques include throttling instruction execution rate or limiting scheduling of instructions. Still further, it is possible for instructions of a given instruction set architecture to include express or implicit direction as to power management operations. Although described with these particular examples, understand that many other power management techniques may be used in particular embodiments.
Embodiments can be implemented in processors for various markets including server processors, desktop processors, mobile processors and so forth. Referring now to
In addition, by interfaces 850a-850n, connection can be made to various off-chip components such as peripheral devices, mass storage and so forth. While shown with this particular implementation in the embodiment of
Referring now to
In general, each core 910 may further include low level caches in addition to various execution units and additional processing elements. In turn, the various cores may be coupled to each other and to a shared cache memory formed of a plurality of units of a last level cache (LLC) 940a-940n. In various embodiments, LLC 940 may be shared amongst the cores and the graphics engine, as well as various media processing circuitry. As seen, a ring interconnect 930 thus couples the cores together, and provides interconnection between the cores, graphics domain 920 and system agent circuitry 950. In one embodiment, interconnect 930 can be part of the core domain. However in other embodiments the ring interconnect can be of its own domain.
As further seen, system agent domain 950 may include display controller 952 which may provide control of and an interface to an associated display. As further seen, system agent domain 950 may include a power control unit 955 which can include logic to perform the power management techniques described herein. To this end, PCU 955 may include a shared power rail control circuit 956, which may cause a shared power rail and associated IVR to be powered down in instances in which all IP agents coupled to it are to be powered down when inactive.
As further seen in
Referring now to
In the high level view shown in
Each core unit 1010 may also include an interface such as a bus interface unit to enable interconnection to additional circuitry of the processor. In an embodiment, each core unit 1010 couples to a coherent fabric that may act as a primary cache coherent on-die interconnect that in turn couples to a memory controller 1035. In turn, memory controller 1035 controls communications with a memory such as a DRAM (not shown for ease of illustration in
In addition to core units, additional processing engines are present within the processor, including at least one graphics unit 1020 which may include one or more graphics processing units (GPUs) to perform graphics processing as well as to possibly execute general purpose operations on the graphics processor (so-called GPGPU operation). In addition, at least one image signal processor 1025 may be present. Signal processor 1025 may be configured to process incoming image data received from one or more capture devices, either internal to the SoC or off-chip.
Other accelerators also may be present. In the illustration of
Each of the units may have its power consumption controlled via a power manager 1040, which may include control logic to perform the various power management techniques described herein. To this end, power manager 1040 may include control circuitry to enable a shared power rail and components coupled thereto to be powered down in instances in which all components coupled to that shared power rail are in an idle or other low power state. Power manager 1040 may further in this instance re-allocate available power budget for these components to other components within SoC 1000, including core units 1010 and/or graphics unit 1020.
In some embodiments, SoC 1000 may further include a non-coherent fabric coupled to the coherent fabric to which various peripheral devices may couple. One or more interfaces 1060a-1060d enable communication with one or more off-chip devices. Such communications may be via a variety of communication protocols such as PCIe™, GPIO, USB, I2C, UART, MIPI, SDIO, DDR, SPI, HDMI, among other types of communication protocols. Although shown at this high level in the embodiment of
Referring now to
As seen in
With further reference to
As seen, the various domains couple to a coherent interconnect 1140, which in an embodiment may be a cache coherent interconnect fabric that in turn couples to an integrated memory controller 1150. Coherent interconnect 1140 may include a shared cache memory, such as an L3 cache, in some examples. In an embodiment, memory controller 1150 may be a direct memory controller to provide for multiple channels of communication with an off-chip memory, such as multiple channels of a DRAM (not shown for ease of illustration in
In different examples, the number of the core domains may vary. For example, for a low power SoC suitable for incorporation into a mobile computing device, a limited number of core domains such as shown in
In yet other embodiments, a greater number of core domains, as well as additional optional IP logic may be present, in that an SoC can be scaled to higher performance (and power) levels for incorporation into other computing devices, such as desktops, servers, high performance computing systems, base stations forth. As one such example, 4 core domains each having a given number of out-of-order cores may be provided. Still further, in addition to optional GPU support (which as an example may take the form of a GPGPU), one or more accelerators to provide optimized hardware support for particular functions (e.g. web serving, network processing, switching or so forth) also may be provided. In addition, an input/output interface may be present to couple such accelerators to off-chip components.
Referring now to
In turn, a GPU domain 1220 is provided to perform advanced graphics processing in one or more GPUs to handle graphics and compute APIs. A DSP unit 1230 may provide one or more low power DSPs for handling low-power multimedia applications such as music playback, audio/video and so forth, in addition to advanced calculations that may occur during execution of multimedia instructions. In turn, a communication unit 1240 may include various components to provide connectivity via various wireless protocols, such as cellular communications (including 3G/4G LTE), wireless local area protocols such as Bluetooth™, IEEE 802.11, and so forth.
Still further, a multimedia processor 1250 may be used to perform capture and playback of high definition video and audio content, including processing of user gestures. A sensor unit 1260 may include a plurality of sensors and/or a sensor controller to interface to various off-chip sensors present in a given platform. An image signal processor 1270 may be provided with one or more separate ISPs to perform image processing with regard to captured content from one or more cameras of a platform, including still and video cameras.
A display processor 1280 may provide support for connection to a high definition display of a given pixel density, including the ability to wirelessly communicate content for playback on such display. Still further, a location unit 1290 may include a GPS receiver with support for multiple GPS constellations to provide applications highly accurate positioning information obtained using as such GPS receiver. Understand that while shown with this particular set of components in the example of
Referring now to
In turn, application processor 1310 can couple to a user interface/display 1320, e.g., a touch screen display. In addition, application processor 1310 may couple to a memory system including a non-volatile memory, namely a flash memory 1330 and a system memory, namely a dynamic random access memory (DRAM) 1335. As further seen, application processor 1310 further couples to a capture device 1340 such as one or more image capture devices that can record video and/or still images.
Still referring to
As further illustrated, a near field communication (NFC) contactless interface 1360 is provided that communicates in a NFC near field via an NFC antenna 1365. While separate antennae are shown in
A power management integrated circuit (PMIC) 1315 couples to application processor 1310 to perform platform level power management. To this end, PMIC 1315 may issue power management requests to application processor 1310 to enter certain low power states as desired. Furthermore, based on platform constraints, PMIC 1315 may also control the power level of other components of system 1300.
To enable communications to be transmitted and received, various circuitry may be coupled between baseband processor 1305 and an antenna 1390. Specifically, a radio frequency (RF) transceiver 1370 and a wireless local area network (WLAN) transceiver 1375 may be present. In general, RF transceiver 1370 may be used to receive and transmit wireless data and calls according to a given wireless communication protocol such as 3G or 4G wireless communication protocol such as in accordance with a code division multiple access (CDMA), global system for mobile communication (GSM), long term evolution (LTE) or other protocol. In addition a GPS sensor 1380 may be present. Other wireless communications such as receipt or transmission of radio signals, e.g., AM/FM and other signals may also be provided. In addition, via WLAN transceiver 1375, local wireless communications can also be realized.
Referring now to
A variety of devices may couple to SoC 1410. In the illustration shown, a memory subsystem includes a flash memory 1440 and a DRAM 1445 coupled to SoC 1410. In addition, a touch panel 1420 is coupled to the SoC 1410 to provide display capability and user input via touch, including provision of a virtual keyboard on a display of touch panel 1420. To provide wired network connectivity, SoC 1410 couples to an Ethernet interface 1430. A peripheral hub 1425 is coupled to SoC 1410 to enable interfacing with various peripheral devices, such as may be coupled to system 1400 by any of various ports or other connectors.
In addition to internal power management circuitry and functionality within SoC 1410, a PMIC 1480 is coupled to SoC 1410 to provide platform-based power management, e.g., based on whether the system is powered by a battery 1490 or AC power via an AC adapter 1495. In addition to this power source-based power management, PMIC 1480 may further perform platform power management activities based on environmental and usage conditions. Still further, PMIC 1480 may communicate control and status information to SoC 1410 to cause various power management actions within SoC 1410.
Still referring to
As further illustrated, a plurality of sensors 1460 may couple to SoC 1410. These sensors may include various accelerometer, environmental and other sensors, including user gesture sensors. Finally, an audio codec 1465 is coupled to SoC 1410 to provide an interface to an audio output device 1470. Of course understand that while shown with this particular implementation in
Referring now to
Processor 1510, in one embodiment, communicates with a system memory 1515. As an illustrative example, the system memory 1515 is implemented via multiple memory devices or modules to provide for a given amount of system memory.
To provide for persistent storage of information such as data, applications, one or more operating systems and so forth, a mass storage 1520 may also couple to processor 1510. In various embodiments, to enable a thinner and lighter system design as well as to improve system responsiveness, this mass storage may be implemented via a SSD or the mass storage may primarily be implemented using a hard disk drive (HDD) with a smaller amount of SSD storage to act as a SSD cache to enable non-volatile storage of context state and other such information during power down events so that a fast power up can occur on re-initiation of system activities. Also shown in
Various input/output (I/O) devices may be present within system 1500. Specifically shown in the embodiment of
For perceptual computing and other purposes, various sensors may be present within the system and may be coupled to processor 1510 in different manners. Certain inertial and environmental sensors may couple to processor 1510 through a sensor hub 1540, e.g., via an I2C interconnect. In the embodiment shown in
Also seen in
System 1500 can communicate with external devices in a variety of manners, including wirelessly. In the embodiment shown in
As further seen in
In addition, wireless wide area communications, e.g., according to a cellular or other wireless wide area protocol, can occur via a WWAN unit 1556 which in turn may couple to a subscriber identity module (SIM) 1557. In addition, to enable receipt and use of location information, a GPS module 1555 may also be present. Note that in the embodiment shown in
To provide for audio inputs and outputs, an audio processor can be implemented via a digital signal processor (DSP) 1560, which may couple to processor 1510 via a high definition audio (HDA) link. Similarly, DSP 1560 may communicate with an integrated coder/decoder (CODEC) and amplifier 1562 that in turn may couple to output speakers 1563 which may be implemented within the chassis. Similarly, amplifier and CODEC 1562 can be coupled to receive audio inputs from a microphone 1565 which in an embodiment can be implemented via dual array microphones (such as a digital microphone array) to provide for high quality audio inputs to enable voice-activated control of various operations within the system. Note also that audio outputs can be provided from amplifier/CODEC 1562 to a headphone jack 1564. Although shown with these particular components in the embodiment of
Embodiments may be implemented in many different system types. Referring now to
Still referring to
Furthermore, chipset 1690 includes an interface 1692 to couple chipset 1690 with a high performance graphics engine 1638, by a P-P interconnect 1639. In turn, chipset 1690 may be coupled to a first bus 1616 via an interface 1696. As shown in
One or more aspects of at least one embodiment may be implemented by representative code stored on a machine-readable medium which represents and/or defines logic within an integrated circuit such as a processor. For example, the machine-readable medium may include instructions which represent various logic within the processor. When read by a machine, the instructions may cause the machine to fabricate the logic to perform the techniques described herein. Such representations, known as “IP cores,” are reusable units of logic for an integrated circuit that may be stored on a tangible, machine-readable medium as a hardware model that describes the structure of the integrated circuit. The hardware model may be supplied to various customers or manufacturing facilities, which load the hardware model on fabrication machines that manufacture the integrated circuit. The integrated circuit may be fabricated such that the circuit performs operations described in association with any of the embodiments described herein.
The RTL design 1715 or equivalent may be further synthesized by the design facility into a hardware model 1720, which may be in a hardware description language (HDL), or some other representation of physical design data. The HDL may be further simulated or tested to verify the IP core design. The IP core design can be stored for delivery to a third party fabrication facility 1765 using non-volatile memory 1740 (e.g., hard disk, flash memory, or any non-volatile storage medium). Alternately, the IP core design may be transmitted (e.g., via the Internet) over a wired connection 1750 or wireless connection 1760. The fabrication facility 1765 may then fabricate an integrated circuit that is based at least in part on the IP core design. The fabricated integrated circuit can be configured to perform operations in accordance with at least one embodiment described herein.
The following examples pertain to further embodiments.
In one example, a SoC comprises: at least one core; a plurality of IP agents coupled to the at least one core; a shared power rail to provide an operating voltage to the plurality of IP agents; and a power controller, in response to an indication that the plurality of IP agents are in an idle state and the at least one core is in an active state, to power down the shared power rail while the at least one core remains in the active state.
In an example, a first software agent is to inform an OS that a first IP agent is to enter into the idle state, the OS to maintain a table including a plurality of entries, each associated with one of the plurality of IP agents.
In an example, the OS is to update a first entry of the table to indicate that the first IP agent is to be in the idle state.
In an example, the power controller is to receive a power down message from the OS in response to a determination that at least one of the plurality of IP agents has entered the idle state, the power down message comprising the indication.
In an example, the power controller, in response to a request to power on the first IP agent, is to power on the shared power rail, thereafter cause the first IP agent to be powered on, and thereafter indicate to the OS that the first IP agent is powered on, the OS to thereafter indicate to the first software agent that the first IP agent is powered on.
In an example, the OS is to receive a definition from a BIOS that the plurality of IP agents are associated with the shared power rail, and in response thereto, set up the table.
In an example, the SoC further comprises a shared bus coupled to the plurality of IP agents.
In an example, the power controller is further to block access to the plurality of IP agents and disable the shared bus when the plurality of IP agents are in the idle state.
In an example, the idle state comprises at least a device D3 low power state.
In an example, in response to the indication, the power controller is to maintain the shared power rail powered down for a boot cycle of the SoC.
In another example, a method comprises: receiving, in a power controller of a SoC, an indication that a plurality of IP agents coupled to a common power rail of the SoC are in an idle state; in response to the indication, causing the common power rail to be powered off; and allocating at least a portion of a power budget allocated to the plurality of IP agents to at least one other component of the SoC.
In an example, the method further comprises: receiving a request to wake at least one of the plurality of IP agents; in response to the request, powering on the common power rail; and thereafter causing the at least one IP agent to be powered on.
In an example, the method further comprises: receiving a first power down indication to indicate that a first IP agent of the plurality of agents is to enter the idle state; and updating a table to identify that the first IP agent is in the idle state.
In an example, the method further comprises sending the indication to the power controller in response to the table identifying that the plurality of IP agents are in the idle state.
In an example, the method further comprises: receiving, from a firmware of the SoC, a declaration that the plurality of IP agents are coupled to the common power rail; and setting up the table in response to the declaration.
In an example, the method further comprises sending the indication to the power controller in response to the table identifying that the plurality of agents are in the idle state and further based on the declaration.
In another example, a computer readable medium including instructions is to perform the method of any of the above examples.
In another example, a computer readable medium including data is to be used by at least one machine to fabricate at least one integrated circuit to perform the method of any one of the above examples.
In another example, an apparatus comprises means for performing the method of any one of the above examples.
In another example, a system includes an integrated circuit comprising: at least one core; a plurality of IP agents coupled to the at least one core; a shared power rail to provide an operating voltage to a first subset of the plurality of IP agents; and a power controller, in response to an indication that the first subset of the plurality of IP agents are in an idle state, to power down the shared power rail while the at least one core remains in the active state. The system may further include a non-volatile storage coupled to the integrated circuit to store firmware for the system, the firmware comprising a definition to identify that the first subset of the plurality of IP agents are coupled to the shared power rail, and a volatile memory to store at least a portion of an OS, where the OS is to receive the definition and set up a table in the volatile memory, the table including a plurality of entries each to identify one of the first subset of the plurality of IP agents and a corresponding power state for the IP agent.
In an example, the OS is to update a first entry of the table to indicate that a first IP agent of the first subset of the plurality of IP agents is to be in the idle state, in response to a power down message from a first software agent.
In an example, the power controller is to receive a request to wake the first IP agent, in response to the request, power on the shared power rail, and thereafter cause the first IP agent to be powered on.
In an example, the power controller is to allocate at least a portion of a power budget allocated to the first subset of the plurality of IP agents to the at least one core when the shared power rail is powered down.
Understand that various combinations of the above examples are possible.
Note that the terms “circuit” and “circuitry” are used interchangeably herein. As used herein, these terms and the term “logic” are used to refer to alone or in any combination, analog circuitry, digital circuitry, hard wired circuitry, programmable circuitry, processor circuitry, microcontroller circuitry, hardware logic circuitry, state machine circuitry and/or any other type of physical hardware component. Embodiments may be used in many different types of systems. For example, in one embodiment a communication device can be arranged to perform the various methods and techniques described herein. Of course, the scope of the present invention is not limited to a communication device, and instead other embodiments can be directed to other types of apparatus for processing instructions, or one or more machine readable media including instructions that in response to being executed on a computing device, cause the device to carry out one or more of the methods and techniques described herein.
Embodiments may be implemented in code and may be stored on a non-transitory storage medium having stored thereon instructions which can be used to program a system to perform the instructions. Embodiments also may be implemented in data and may be stored on a non-transitory storage medium, which if used by at least one machine, causes the at least one machine to fabricate at least one integrated circuit to perform one or more operations. Still further embodiments may be implemented in a computer readable storage medium including information that, when manufactured into a SoC or other processor, is to configure the SoC or other processor to perform one or more operations. The storage medium may include, but is not limited to, any type of disk including floppy disks, optical disks, solid state drives (SSDs), compact disk read-only memories (CD-ROMs), compact disk rewritables (CD-RWs), and magneto-optical disks, semiconductor devices such as read-only memories (ROMs), random access memories (RAMs) such as dynamic random access memories (DRAMs), static random access memories (SRAMs), erasable programmable read-only memories (EPROMs), flash memories, electrically erasable programmable read-only memories (EEPROMs), magnetic or optical cards, or any other type of media suitable for storing electronic instructions.
While the present invention has been described with respect to a limited number of embodiments, those skilled in the art will appreciate numerous modifications and variations therefrom. It is intended that the appended claims cover all such modifications and variations as fall within the true spirit and scope of this present invention.
Number | Name | Date | Kind |
---|---|---|---|
5163153 | Cole et al. | Nov 1992 | A |
5522087 | Hsiang | May 1996 | A |
5590341 | Matter | Dec 1996 | A |
5621250 | Kim | Apr 1997 | A |
5931950 | Hsu | Aug 1999 | A |
6748546 | Mirov et al. | Jun 2004 | B1 |
6792392 | Knight | Sep 2004 | B1 |
6823516 | Cooper | Nov 2004 | B1 |
6829713 | Cooper et al. | Dec 2004 | B2 |
6996728 | Singh | Feb 2006 | B2 |
7010708 | Ma | Mar 2006 | B2 |
7043649 | Terrell | May 2006 | B2 |
7093147 | Farkas et al. | Aug 2006 | B2 |
7111179 | Girson et al. | Sep 2006 | B1 |
7194643 | Gonzalez et al. | Mar 2007 | B2 |
7272730 | Acquaviva et al. | Sep 2007 | B1 |
7412615 | Yokota et al. | Aug 2008 | B2 |
7434073 | Magklis | Oct 2008 | B2 |
7437270 | Song et al. | Oct 2008 | B2 |
7454632 | Kardach et al. | Nov 2008 | B2 |
7529956 | Stufflebeam | May 2009 | B2 |
7539885 | Ma | May 2009 | B2 |
7730340 | Hu et al. | Jun 2010 | B2 |
9823719 | Jahagirdar | Nov 2017 | B2 |
20010044909 | Oh et al. | Nov 2001 | A1 |
20020194509 | Plante et al. | Dec 2002 | A1 |
20030061383 | Zilka | Mar 2003 | A1 |
20040064752 | Kazachinsky et al. | Apr 2004 | A1 |
20040098560 | Storvik et al. | May 2004 | A1 |
20040139356 | Ma | Jul 2004 | A1 |
20040268166 | Farkas et al. | Dec 2004 | A1 |
20050022038 | Kaushik et al. | Jan 2005 | A1 |
20050033881 | Yao | Feb 2005 | A1 |
20050132238 | Nanja | Jun 2005 | A1 |
20060050670 | Hillyard et al. | Mar 2006 | A1 |
20060053326 | Naveh | Mar 2006 | A1 |
20060059286 | Bertone et al. | Mar 2006 | A1 |
20060069936 | Lint et al. | Mar 2006 | A1 |
20060117202 | Magklis et al. | Jun 2006 | A1 |
20060149977 | Cooper | Jul 2006 | A1 |
20060184287 | Belady et al. | Aug 2006 | A1 |
20070005995 | Kardach et al. | Jan 2007 | A1 |
20070016817 | Albonesi et al. | Jan 2007 | A1 |
20070079294 | Knight | Apr 2007 | A1 |
20070106827 | Boatright et al. | May 2007 | A1 |
20070156992 | Jahagirdar | Jul 2007 | A1 |
20070214342 | Newburn | Sep 2007 | A1 |
20070239398 | Song et al. | Oct 2007 | A1 |
20070245163 | Lu et al. | Oct 2007 | A1 |
20080028240 | Arai et al. | Jan 2008 | A1 |
20080250260 | Tomita | Oct 2008 | A1 |
20090006871 | Liu et al. | Jan 2009 | A1 |
20090150695 | Song et al. | Jun 2009 | A1 |
20090150696 | Song et al. | Jun 2009 | A1 |
20090158061 | Schmitz et al. | Jun 2009 | A1 |
20090158067 | Bodas et al. | Jun 2009 | A1 |
20090172375 | Rotem et al. | Jul 2009 | A1 |
20090172428 | Lee | Jul 2009 | A1 |
20090235105 | Branover et al. | Sep 2009 | A1 |
20090300395 | Chin | Dec 2009 | A1 |
20100115309 | Carvalho et al. | May 2010 | A1 |
20100146513 | Song | Jun 2010 | A1 |
20100191997 | Dodeja et al. | Jul 2010 | A1 |
20110154090 | Dixon et al. | Jun 2011 | A1 |
20120079290 | Kumar | Mar 2012 | A1 |
20120246506 | Knight | Sep 2012 | A1 |
20130061064 | Ananthakrishnan et al. | Mar 2013 | A1 |
20130080803 | Ananthakrishnan et al. | Mar 2013 | A1 |
20130080804 | Ananthakrishnan et al. | Mar 2013 | A1 |
20130111120 | Ananthakrishnan et al. | May 2013 | A1 |
20130111121 | Ananthakrishnan et al. | May 2013 | A1 |
20130111226 | Ananthakrishnan et al. | May 2013 | A1 |
20130111236 | Ananthakrishnan et al. | May 2013 | A1 |
20130346774 | Bhandaru et al. | Dec 2013 | A1 |
20140068290 | Bhandaru et al. | Mar 2014 | A1 |
20140195829 | Bhandaru et al. | Jul 2014 | A1 |
20140208141 | Bhandaru et al. | Jul 2014 | A1 |
20150067356 | Trichy Ravi | Mar 2015 | A1 |
20170177068 | Cooper et al. | Jun 2017 | A1 |
20170286247 | Pappu et al. | Oct 2017 | A1 |
20180232036 | Varadarajan et al. | Aug 2018 | A1 |
Number | Date | Country |
---|---|---|
1 282 030 | May 2003 | EP |
05324130 | Dec 1993 | JP |
1020160067595 | Jun 2016 | KR |
Entry |
---|
Intel Corporation, “Intel 64 and IA-32 Architectures Software Developer's Manual,” vol. 3B: System Programming Guide, Sep. 2016, Chapter 14 Power and Thermal Management (14.1-14.9.5), 39 pages. |
Microsoft Docs, “Device Low-Power States,” https://docs.microsoft.com/en-us/windows-hardware/drivers/kernel/device-sleeping-states, Jun. 15, 2017, 1 page. |
International Searching Authority, “Notification of Transmittal of the International Search Report and the Written Opinion of the International Searching Authority,” dated Dec. 4, 2019, in International application No. PCT/US2019/047620. |
Number | Date | Country | |
---|---|---|---|
20190041970 A1 | Feb 2019 | US |