throbber
US00827 1812B2
`
`(12) United States Patent
`de Cesare et al.
`
`(10) Patent No.:
`(45) Date of Patent:
`
`US 8,271,812 B2
`Sep. 18, 2012
`
`(54) HARDWARE AUTOMATIC PERFORMANCE
`STATE TRANSTIONS IN SYSTEM ON
`PROCESSOR SLEEP AND WAKE EVENTS
`(75) Inventors: Josh P. de Cesare, Campbell, CA (US);
`Jung Wook Cho, Cupertino, CA (US);
`Toshi Takayanagi, San Jose, CA (US);
`Timothy J. Millet, Mountain View, CA
`(US)
`
`6,510,525 B1* 1/2003 Nookala et al. ............... T13,324
`6,535,798 B1
`3/2003 Bhatia et al.
`6,665,802 B1* 12/2003 Ober ............................. T13,320
`6,823,516 B1
`1 1/2004 Cooper
`(Continued)
`FOREIGN PATENT DOCUMENTS
`O855718
`7, 1998
`(Continued)
`
`EP
`
`(73) Assignee: Apple Inc., Cupertino, CA (US)
`
`OTHER PUBLICATIONS
`
`(*) Notice:
`
`Subject to any disclaimer, the term of this
`patent is extended or adjusted under 35
`U.S.C. 154(b) by 262 days.
`
`(21) Appl. No.: 12/756,006
`
`(22) Filed:
`
`Apr. 7, 2010
`
`(65)
`
`O
`O
`Prior Publication Data
`US 2011 FO2.52251A1
`Oct. 13, 2011
`
`(51) Int. Cl.
`(2006.01)
`G06F I/00
`(2006.01)
`G06F L/26
`(2006.01)
`G06F 3/038
`(2006.01)
`G06F 3/00
`(2006.01)
`G09G 3/18
`(2006.01)
`GI IC5/14
`(2006.01)
`H04M I/00
`(52) U.S. Cl. ........ 713/300; 713/320; 713/323; 713/324;
`345/52; 34.5/211: 365/227; 455/574; 719/321
`(58) Field of Classification Search .................. 713/300,
`713/320, 323,324; 34.5/52, 211: 365/227;
`455/574; 719/321
`See application file for complete search history.
`
`(56)
`
`References Cited
`
`U.S. PATENT DOCUMENTS
`5,813,022 A
`9/1998 Ramsey
`6,128,747 A * 10/2000 Thoulon ....................... T13,330
`
`Combined Search and Examination Report in Application No.
`GB1105852.6 issued Aug. 1, 2011
`k
`(Continued)
`
`Primary Examiner — Stefan Stoynov
`(74) Attorney, Agent, or Firm — Lawrence J. Merkel:
`Meyertons, Hood, Kivlin, Kowert & Goetzel, P.C.
`
`(57)
`
`ABSTRACT
`
`In an embodiment, a power management unit (PMU) may
`automatically transition (in hardware) the performance states
`of one or more performance domains in a system. The target
`performance states to which the performance domains are to
`transition may be programmable in the PMU by software, and
`software may signal the PMU that a processor in the system is
`to enter the sleep state. The PMU may control the transition of
`the performance domains to the target performance states,
`and may cause the processor to enter the sleep state. In an
`embodiment, the PMU may be programmable with a second
`set of target performance states to which the performance
`domains are to transition when the processor exits the sleep
`state. The PMU may control the transition of the performance
`domains to the second targeted performance states and cause
`the processor to exit the sleep state.
`
`11 Claims, 5 Drawing Sheets
`
`Power Supply 12
`
`Performance Domain :
`14A
`
`Processor 16A
`
`:
`
`- - - - - - - - - - - -
`Component 18
`
`Clk/Voltage
`Control 32
`
`14B
`
`
`
`PMU28
`Perf configk
`
`.
`
`:
`
`r---
`Performance Domain
`
`Performance Domain
`
`Memory
`Control.26
`
`KH)
`
`erformance Domain
`14E.
`
`
`
`Network, Other
`Peripherals 24
`
`Qualcomm, Ex. 1018, Page 1
`
`

`

`US 8,271,812 B2
`Page 2
`
`U.S. PATENT DOCUMENTS
`7,369,815 B2 *
`5/2008 Kang et al. ...................... 455,73
`7,590,473 B2
`9/2009 Wyatt
`2003, OO61383 A1
`3, 2003 Zika
`2005/0064829 A1* 3/2005 Kang et al.................. 455,127.1
`2006/0259800 A1* 1 1/2006 Maejima ....................... T13,300
`2007/O150759 A1
`6, 2007 Srini
`tal.
`2007/0234O78 A1 10, 2007 None
`2008. O168285 A1
`7/2008 de Cesare et al.
`2008/0307245 A1 12/2008 de Cesare et al.
`2009, OO63715 A1
`3/2009 de Cesare et al.
`2009/0204837 A1
`8, 2009 Rawal
`
`8/2010 de Cesare et al.
`2010, 0211700 A1
`FOREIGN PATENT DOCUMENTS
`2472050
`1, 2011
`
`GB
`
`OTHER PUBLICATIONS
`International Search Report and Written Opinion from PCT/US
`1 1/31358, mailed Jun. 13, 2011, Apple Inc., 12 pages.
`
`* cited by examiner
`
`Qualcomm, Ex. 1018, Page 2
`
`

`

`U.S. Patent
`
`Sep. 18, 2012
`
`Sheet 1 of 5
`
`US 8,271,812 B2
`
`Power Supply 12
`
`
`
`Clk/Voltage
`Control 32
`
`PMU 28
`Perf Config K
`Y.
`
`x
`
`F----------------------------. I
`Performance Domain :
`U.
`B O. O. O. O. D.
`:
`;
`:
`
`f
`I Processor 16B
`-------------
`-----------------------------
`Performance Domain:
`
`:
`
`14F
`
`:
`:
`
`f-------------------------------
`Performance Domain
`14A
`
`Processor 1.6A
`
`:
`
`f------------
`Component 18
`---------------------------------
`
`b- H - H. H. H. H. H. H. H. H. H. He
`
`- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
`
`Performance Domain
`
`Performance Domain
`
`Control 26
`
`14C
`
`14D
`
`- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
`
`Graphics 20
`
`Performance Domain :
`14E
`
`Network, Other
`Peripherals 24
`
`|
`
`|
`
`
`
`Qualcomm, Ex. 1018, Page 3
`
`

`

`U.S. Patent
`
`Sep. 18, 2012
`
`Sheet 2 of 5
`
`US 8,271,812 B2
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`30B
`
`Fig. 2
`
`
`
`
`
`Y
`— 42
`eS
`Load Sleep Performance State
`for Each Performance Domain
`— 44
`Transition to New
`Performance States
`
`NO
`
`Load Wake Performance State
`for Each Performance Domain
`
`Transition to New
`Performance States
`
`Record Timestamp
`
`52
`
`-
`
`- 54
`
`Record Timestamp
`
`Fig. 3
`
`Qualcomm, Ex. 1018, Page 4
`
`

`

`U.S. Patent
`
`Sep. 18, 2012
`
`Sheet 3 of 5
`
`US 8,271,812 B2
`
`Apps, OS, Etc. 60
`
`Graphics
`Driver 62
`
`Audio
`Driver 64
`
`Network
`Driver 66
`
`Other
`Peripheral
`Drivers 68
`
`
`
`PMU
`Driver 70
`
`Device
`Activity
`Table 72
`
`Qualcomm, Ex. 1018, Page 5
`
`

`

`U.S. Patent
`
`Sep. 18, 2012
`
`Sheet 4 of 5
`
`US 8,271,812 B2
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`
`80 —
`
`
`
`
`
`Start - PMU Driver
`
`Device Enable/
`Disable Request?
`
`
`
`
`
`
`
`Processor
`to Sleep?
`
`Change in
`Performance
`State?
`
`u-86
`
`u-88
`Yes
`Prepare Hardware for
`Transition
`u-90
`Invoke Transition
`
`Determine Desired
`Sleep and Wake States
`Based on Device
`Activity Table
`
`Update Perf Config
`Regs if Applicable
`98 —s
`Transmit Sleep
`Command
`
`
`
`
`
`End - PMU Driver
`
`Qualcomm, Ex. 1018, Page 6
`
`

`

`U.S. Patent
`
`Sep. 18, 2012
`
`Sheet 5 of 5
`
`US 8,271,812 B2
`
`
`
`Power Supply 156
`
`Integrated Circuit
`10
`
`External Memory
`158
`
`Peripherals
`154
`
`Computer Accessible Storage Medium 200
`
`Apps, OS, Etc. 60
`
`Graphics
`Driver 62
`
`Audio
`Driver 64
`
`Network
`Driver 66
`
`Other
`Peripheral
`Drivers 68
`
`PMU
`Driver 70
`
`Device
`Activity
`Table 72
`
`Qualcomm, Ex. 1018, Page 7
`
`

`

`US 8,271,812 B2
`
`1.
`HARDWARE AUTOMATIC PERFORMANCE
`STATE TRANSTIONS IN SYSTEM ON
`PROCESSOR SLEEP AND WAKE EVENTS
`
`BACKGROUND
`
`2
`signal the power management unit that a processor in the
`system is to enter the sleep state. Alternatively, the power
`management unit may monitor the processor to detect that the
`processor is entering the sleep state or has entered the sleep
`state. The power management unit may be configured to
`control the transition of the performance domains to the target
`performance States, and may also cause the processor to enter
`the sleep state in Some embodiments. In an embodiment, the
`power management unit may be programmable with a second
`set of target performance states to which the performance
`domains are to transition when the processor exits the sleep
`state. The power management unit may be configured to
`control the transition of the performance domains to the sec
`ond targeted performance states and may also cause the pro
`cessor to exit the sleep state in Some embodiments.
`In one embodiment, the transition of the performance
`domains into different target states may be more rapid when
`controlled by the power management unit than may be pos
`sible with software control. Accordingly, the power conser
`Vation may be more efficient than a purely software-con
`trolled implementation, and the performance of applications
`executing in the system may also be positively affected. Addi
`tionally, the configureability of the performance states may
`permit more fine-grained control of the performance level in
`the system and thus may permit additional power savings. In
`Some cases, the performance states may be reduced further
`than would be possible in the software-controlled implemen
`tation, because the time required for the software to execute
`while the system is in the lower performance states is a
`reduced factor (or may even be eliminated).
`Each component of the system may be included in a per
`formance domain, and each performance domain may
`include at least one component but may include multiple
`components, in various embodiments. The power manage
`ment unit may be programmable with performance state iden
`tifiers for each performance domain, and for each hardware
`managed transition (e.g. into the sleep state, out of the sleep
`state, or both into and out of the sleep state, in various embodi
`ments). The sleep state of the processor may also be a perfor
`mance state, as may various other performance states that the
`processor may be programmed to in various embodiments.
`
`10
`
`15
`
`25
`
`30
`
`35
`
`40
`
`45
`
`1. Field of the Invention
`This invention is related to the field of systems including
`processors and peripheral devices, and managing power con
`Sumption in Such systems.
`2. Description of the Related Art
`As the number of transistors included on an integrated
`circuit “chip' continues to increase, power management in
`the integrated circuits continues to increase in importance.
`Power management can be critical to integrated circuits that
`are included in mobile devices such as personal digital assis
`tants (PDAs), cell phones, Smartphones, laptop computers,
`net top computers, etc. These mobile devices often rely on
`battery power, and reducing power consumption in the inte
`grated circuits can increase the life of the battery. Addition
`ally, reducing power consumption can reduce the heat gener
`ated by the integrated circuit, which can reduce cooling
`requirements in the device that includes the integrated circuit
`(whether or not it is relying on battery power).
`Clock gating is often used to reduce dynamic power con
`Sumption in an integrated circuit, disabling the clock to idle
`circuitry and thus preventing Switching in the idle circuitry.
`Additionally, some integrated circuits have implemented
`power gating to reduce static power consumption (e.g. con
`Sumption due to leakage currents). With power gating, the
`power to ground path of the idle circuitry is interrupted,
`reducing the leakage current to near Zero.
`Clock gating and power gating can be effective power
`conservation mechanisms. However, in Some cases, these
`mechanisms are not as effective as desired. For example,
`systems that include processors can cause the processors to
`enter a sleep state to conserve power. While the processor is in
`the sleep state, other components in the system are still active,
`and often are operating at performance levels that Support the
`active processors. When the processors are in the sleep state,
`these other components need not be operating at Such a high
`performance level. Similarly, when the processors are awak
`ened from the sleep state, the performance level at which the
`processors and other components need to operate to Support
`the activities being performed by the system may be different
`than the performance level prior to the processor entering the
`sleep state.
`The sleep/wake transitions of the processors and other
`components are changed under Software control. The Soft
`ware executes on the processors, and thus changing the per
`formance levels of the processors and other components can
`affect the amount of time required to execute the software.
`These effects impact the efficiency of the transition, impact
`ing the power conserved and the performance of the applica
`tion. Furthermore, the software execution time can affect how
`often the processor is transitioned to the sleep state, and the
`amount of reduced performance that can be tolerated in the
`rest of the system.
`
`SUMMARY
`
`In an embodiment, a power management unit may be con
`figured to automatically transition (in hardware) the perfor
`mance states of one or more performance domains in a sys
`tem. The target performance states to which the performance
`domains are to transition may be programmable in the power
`management unit by Software. Additionally, the Software may
`
`BRIEF DESCRIPTION OF THE DRAWINGS
`
`The following detailed description makes reference to the
`accompanying drawings, which are now briefly described.
`FIG. 1 is a block diagram of one embodiment of a system.
`FIG. 2 is a block diagram of one embodiment of perfor
`mance configuration registers illustrated in FIG. 1.
`FIG. 3 is a flowchart illustrating operation of one embodi
`ment of a power management unit to automatically change
`power States.
`FIG. 4 is a block diagram illustrating one embodiment of
`driver components.
`FIG. 5 is a flowchart illustrating operation of one embodi
`ment of a power management unit driver component.
`FIG. 6 is a block diagram illustrating another embodiment
`of a system.
`FIG. 7 is a block diagram of one embodimentofa computer
`accessible storage medium.
`While the invention is susceptible to various modifications
`and alternative forms, specific embodiments thereof are
`shown by way of example in the drawings and will herein be
`described in detail. It should be understood, however, that the
`drawings and detailed description thereto are not intended to
`limit the invention to the particular form disclosed, but on the
`contrary, the intention is to cover all modifications, equiva
`
`50
`
`55
`
`60
`
`65
`
`Qualcomm, Ex. 1018, Page 8
`
`

`

`3
`lents and alternatives falling within the spirit and scope of the
`present invention as defined by the appended claims. The
`headings used herein are for organizational purposes only and
`are not meant to be used to limit the scope of the description.
`As used throughout this application, the word “may is used
`in a permissive sense (i.e., meaning having the potential to),
`rather than the mandatory sense (i.e., meaning must). Simi
`larly, the words “include”, “including, and “includes” mean
`including, but not limited to.
`Various units, circuits, or other components may be
`described as "configured to perform a task or tasks. In Such
`contexts, “configured to' is a broad recitation of structure
`generally meaning "having circuitry that performs the task
`or tasks during operation. As such, the unit/circuit/component
`can be configured to perform the task even when the unit/
`circuit/component is not currently on. In general, the circuitry
`that forms the structure corresponding to “configured to may
`include hardware circuits. Similarly, various units/circuits/
`components may be described as performing a task or tasks,
`for convenience in the description. Such descriptions should
`be interpreted as including the phrase “configured to.” Recit
`ing a unit/circuit/component that is configured to perform one
`or more tasks is expressly intended not to invoke 35 U.S.C.
`S112, paragraph six interpretation for that unit/circuit/com
`ponent.
`
`DETAILED DESCRIPTION OF EMBODIMENTS
`
`Turning now to FIG.1, a block diagram of one embodiment
`ofa system is shown. In the embodiment of FIG.1, the system
`includes an integrated circuit (IC) 10 forming a system on a
`chip, and a power supply 12. The integrated circuit 10
`includes a set of performance domains 14A-14F. Each per
`formance domain 14A-14F includes at least one component
`of the integrated circuit 10, and a given performance domain
`may include more than one component. For example, the
`performance domain 14A in FIG. 1 includes two compo
`nents, a processor 16A and another component 18; and the
`performance domain 14E may include two or more peripher
`als 24. In the illustrated embodiment, the performance
`domain 14B includes an optional second processor 16B; the
`performance domain 14C includes a graphics unit 20; the
`performance domain 14D includes an audio unit 22; the per
`formance domain 14E includes networking peripherals and/
`or other peripherals and/or peripheral interface units 24; and
`the performance domain 14F includes a memory controller
`26. The integrated circuit 10 also includes a power manage
`ment unit (PMU) 28 (which includes one or more perfor
`mance configuration registers 30) and a clock/voltage control
`unit 32. The various components shown in FIG. 1 may be
`coupled in any desired fashion. For example, there may one or
`more buses or other interfaces between the components. The
`PMU 28 and the clock/voltage control unit 32 may also be
`coupled to the various components in addition to being
`coupled to the interfaces. For example, the clock/voltage
`control unit 32 may supply clock signals to the components
`(not shown in FIG. 1). The clock/voltage control unit 32 may
`be configured to communicate with the power Supply 12 to
`request one or more Supply Voltages from the power Supply
`12. The power Supply 12 may generate the requested Voltage
`or Voltages, and may supply the integrated circuit with the
`Voltages.
`The PMU 28 may be configured to control transitions
`between performance states for the various performance
`domains 14A-14F. Particularly, the PMU 28 may be config
`ured to automatically transition one or more of the perfor
`mance domains 14A-14F in response to one or more proces
`
`4
`sors 16A-16B entering a sleep state (or in response to
`determining that the processor is to enter the sleep state). The
`PMU 28 may also be configured to automatically transition
`one or more of the performance domains 14A-14F in
`response to the processor exiting the sleep state (or in
`response to determining that the processor is to exit the sleep
`state). Exiting the sleep state may also be referred to as
`“waking the processor. The sleep state and other states of the
`processors may be performance States of the performance
`domains that include the processors. Alternatively, the sleep
`state and other processor states may be performance charac
`teristics in a performance state for the performance domains
`including the processors.
`A performance domain may be one or more components
`that may be controlled by the PMU 28 as a unit for perfor
`mance configuration purposes. That is, the PMU 28 may be
`configured to establish a corresponding performance state for
`each performance domain, and may be configured to control
`transitions between performance states in each performance
`domain. The components that form a performance domain
`may transition together from one performance state to
`another performance state. On the other hand, components in
`different performance domains may be independent of each
`other, at least from the standpoint of hardware, and may have
`independently-determined performance states. Some perfor
`mance domains may be logically linked at a higher level (e.g.
`in software). For example, the performance domains 14C
`14D may be logically linked if a user is watching a video that
`includes sound (thus using the graphics unit 20 to display the
`Video images and the audio unit 22 to transmit the Sound).
`The performance state may include any combination of
`performance characteristics for the components in a corre
`sponding performance domain. A performance characteristic
`may be any configurable setting for a component that affects
`the performance of that component. For example, the operat
`ing frequency of the clock signal provided to a component
`may affect its performance. A lower operating frequency may
`result in lower performance. A corresponding Supply Voltage
`may also be a performance characteristic. Some performance
`characteristics may be component-specific. For example,
`cache sizes in various caches may be a performance charac
`teristic. A data width or other data transfer rate parameter of
`an interface may be a performance characteristic. A compo
`nent that includes a number of symmetrical units that may
`operate in parallel (e.g. execution units in a processor, pixel
`pipelines or other image processing pipelines in a graphics
`unit, etc.) may be configurable as to the number of symmetri
`cal units that are active. A number of instructions (processor),
`operations (graphics or audio), communications (network or
`other peripheral interface), or memory request (memory con
`trol unit) processed per unit of time may be a performance
`characteristic. A graphics resolution or size of the color pal
`ette (e.g. bits per pixel) may be a performance characteristic.
`Audio resolution and sample rates may be a performance
`characteristic. Memory bandwidth may be a performance
`characteristic. The sleep/wake State of the processor may be a
`performance characteristic. If components orportions thereof
`can be power-gated and/or clock-gated, the power and/or
`clock enables may be performance characteristics. Any
`parameter that may be changed and that may affect perfor
`mance may be a performance characteristic in various
`embodiments.
`Changing the performance state in a performance domain
`may affect the power consumption of the performance
`domain. Reducing operating frequency and Supply Voltage
`have direct effects on power consumption. Reducing cache
`size may reduce power consumption because a portion of the
`
`US 8,271,812 B2
`
`10
`
`15
`
`25
`
`30
`
`35
`
`40
`
`45
`
`50
`
`55
`
`60
`
`65
`
`Qualcomm, Ex. 1018, Page 9
`
`

`

`US 8,271,812 B2
`
`5
`cache may not be accessed, and even more reduction may be
`realized if the unused portion may be turned off. Furthermore,
`reduced cache size may reduce cache hit rates, which may
`increase memory latency to the consumer. Increased memory
`latency may reduce activity in the consumer, reducing power
`consumption. Reduced data transfer widths/rates on inter
`faces may reduce power consumption through reduced
`Switching. Additionally, reducing the rate at which data is
`Supplied to a consumer may reduce activity in the consumer,
`which may reduce power consumption in the consumer.
`Reduced parallel activity in symmetrical units may reduce
`power consumption through reduced activity, as may reduced
`instruction or other operation issue rates. Reducing graphics/
`audio resolution and color palette may reduce the amount of
`data transferred per image or unit of Sound. Reduced memory
`bandwidth may reduce power consumption in accessing the
`memory per unit time, and may reduce activity in the con
`SUC.
`In some embodiments, the performance state may include
`multiple instances of a performance characteristic. For
`example, if the processor is powered offin the sleep state and
`other components are in the same performance domain, the
`Voltage for the processor may be set separately from the
`Voltage for the other components that remain active. Simi
`larly, any other performance characteristics that apply to
`more than one component in a performance domain and that
`may be independent controlled for Such components may be
`represented by multiple instances in the performance state.
`In embodiments in which a processor is in a performance
`domain with other components, the other components may
`remain active during times that the processor is in the sleep
`state. For example, the component 18 in the performance
`domain 14A may remain active during times that the proces
`sor 16A is in the sleep state. The performance characteristics
`of the component may be changed to reflect reduced opera
`tion while the processor is in the sleep state. For example, the
`component 18 may be a level 2 (L2) cache coupled to the
`processor 16A. In Such an embodiment, the L2 cache may not
`be accessed by the sleeping processor 16A but may remain
`active to maintain cache coherence. The L2 cache may oper
`ate at a lower clock frequency (and Voltage) in some embodi
`ments while still providing enough performance to ensure the
`cache coherence.
`The PMU 28 may include circuitry configured to cause the
`performance state transitions to occur in the performance
`domains. In one embodiment, the PMU 28 may detect that the
`processor 16A-16B is entering/exiting the sleep state, and
`may cause corresponding transitions in the performance
`domains. In other embodiments, software may explicitly
`communicate sleep/wake events to the PMU 28. In an
`embodiment, the PMU 28 is programmable with perfor
`mance configurations for each performance domain. For
`example, performance states to be used in the performance
`domains 14A-14F when the processor is in sleep state may be
`specified in the performance configuration registers 30. Per
`formance states to be used when the processor 16A-16B exits
`the sleep state (awakens) may also be specified. When either
`event occurs, the PMU 28 may cause the desired transitions.
`In the case of Voltage and clock frequency changes, the
`PMU 28 may communicate the new settings to the clock/
`voltage control unit 32. The clock/voltage control unit 32 may
`implement the new settings, generating the clocks at the
`requested frequencies and requesting the desired Supply Volt
`ages from the power Supply 12. The clock/voltage control unit
`32 may order the modifications, if necessary, to safely make
`the transitions. For example, if the clock frequency and Sup
`ply Voltage are being increased, it may be safer to increase the
`
`40
`
`45
`
`6
`Voltage first, and then increase the clock frequency because
`the increased clock frequency may lead to incorrect operation
`if circuitry is operating more slowly at the current (lower)
`Supply Voltage. In some embodiments, the amount of time
`that elapses in a Supply Voltage change may be substantially
`greater than the time to change the clock frequency. If the
`clock frequency and Supply Voltage are being decreased, the
`clock frequency may be reduced first (or the frequency and
`Voltage may be reduced in parallel, since the lower clock
`frequency may be reached prior to the lower Supply Voltage in
`this case).
`The clock/voltage control unit 32 may include circuitry to
`communicate with the power Supply 12 to request the desired
`Supply Voltages, and may include clock generation circuitry.
`For example, the clock/voltage control unit 32 may include
`one or more phase lock loops (PLLs), clock dividers/multi
`pliers, etc. to generate clocks for the components.
`The various components included in the integrated circuit
`10 may implement any desired functionality. Generally, a
`component may refer to any circuitry that is defined to per
`form a specified set of operations in the integrated circuit, and
`has a defined interface to communicate with other compo
`nents in the integrated circuit. As illustrated in FIG. 1, exem
`plary components may include the processors 16A-16B, the
`component 18, the graphics unit 20, the audio unit 22, the
`networking peripheral and other peripheral/peripheral inter
`faces 24 (which may be multiple components), and the
`memory controller 26.
`The processors 16A-16B may implement any instruction
`set architecture, and may be configured to execute instruc
`tions defined in that instruction set architecture. Any microar
`chitectural implementation may be used (e.g. in order, out of
`order, speculative, non-speculative, Scalar, SuperScalar, pipe
`lined, Superpipelined, etc.). Microcoding techniques may be
`used in some embodiments, in combination with any of the
`above.
`As mentioned above, the performance state of the proces
`sors 16A-16B may include a sleep state. In the sleep state, the
`processor is idle (not executing instructions). The clock to the
`processor may be stopped. In some embodiments, power may
`also be removed from the processor in the sleep state. Alter
`natively, there may be more than one sleep state. One of the
`sleep states may include powering down the processor, and
`another sleep state may include retaining power to the pro
`cessor. Additionally, the processor may include at least one
`“awake state'. There may be multiple awake states. For
`example, different Supply Voltage/operating frequency com
`binations may be supported, different combinations of
`enabled execution units may be supported, different instruc
`tion issue rates may be supported, etc.
`The graphics unit 20 may include any circuitry involved in
`the display of images on a display device for, e.g., user view
`ing. The images may be static images, or may be part of a
`Video. The graphics unit 20 may include rendering hardware,
`refresh (of the display device) hardware, video encoders and/
`or decoders, video compression and decompression units,
`etc. The audio unit 22 may include any circuitry involved in
`the playing or recording of Sounds in the system. The audio
`unit 22 may include, e.g., audio encoders and/or decoders,
`digital signal processors, etc.
`The networking peripherals and other peripherals 24 may
`include a variety of circuitry. For example, the networking
`peripherals may include a media access controller (MAC)
`unit for the Supported network, as well as physical layer
`circuitry. The other peripherals may include any other desired
`peripherals, and/or peripheral interface controllers config
`ured to control off-chip peripheral interfaces such as Periph
`
`5
`
`10
`
`15
`
`25
`
`30
`
`35
`
`50
`
`55
`
`60
`
`65
`
`Qualcomm, Ex. 1018, Page 10
`
`

`

`US 8,271,812 B2
`
`10
`
`15
`
`7
`eral Component Interconnect (PCI), PCI express (PCIe),
`firewire, Universal Serial Bus (USB), etc.
`The memory controller 26 may be configured to access
`memory devices such as dynamic random access memory
`devices (DRAM), synchronous DRAM (SDRAM), double
`data rate (DDR, DDR2, DDR3, DDR4, etc.) SDRAM, low
`power DDR (LPDDR2, etc.) SDRAM, RAMBUSDRAM
`(RDRAM), etc. In one embodiment, the memory controller
`26 may be configured to interface to one or more memory
`modules (e.g. single inline memory modules (SIMMs), dual
`inline memory modules (DIMMs), etc.) that include one or
`more of the above memories. Accordingly, the memory con
`troller 26 may be configured to communicate on the memory
`interfaces, to queue memory requests from other components
`in the integrated circuit 10, and to communicate with the other
`components to complete the memory operations.
`While the embodiment of the integrated circuit 10 shown in
`FIG. 1 includes numerous performance domains, more or
`fewer performance domains may be supported. For example,
`a single performance domain may be supported, or two per
`formance domains may be Supported (e.g. one domain
`including the processors 16A-16B and another domain
`including the remaining components 18, 20, 22, 24, and 26).
`One or more processors 16A-16B may be included in a per
`formance domain with any subset of the components 18, 20.
`22, 24, and 26. Any combination of performance domains and
`components included in those domains may be implemented
`in various embodiments.
`Other embodiments of the integrated circuit 10 may
`include other combinations of components, including any
`subset of the illustrated components with or without other
`components, supersets with other components, etc. Addition
`ally, while the illustrated embodiment illustrates the compo
`nents 16A-16B, 18, 20, 22, 24, and 26 all included in the
`integrated circuit 10, other embodiments may implement the
`components as two or more integrated circuits. Any level of
`integration or discrete components may be used.
`Turning now to FIG. 2, a block diagram illustrating one
`embodiment of the performance configuration registers 30 is
`shown. In the illustrated embodiment, the registers 30 include
`register set 30A, register set 30B, and register set 30C. The
`register set 30B may include a configuration for each perfor
`mance domain, and for the sleep state and the wake state.
`Accordingly, the illustrated set supports up to “n” perfor
`mance domains, where “n” is a positive integer. The sleep
`state for a given performance domain indicates the perfor
`mance state for the domain in response to the processor enter
`ing the sleep state. The wake state for the given performance
`domain indicates the performance state for the domain in
`response to the processor exiting the sleep state.
`In some embodiments, the registers 30B may directly store
`values defining the performance state to be established in the
`corresponding power domain. In such cases, the Software
`preparing the integrated circuit 10 for a sleep state of the
`processors 16A-16B may program each register 30B for the
`sleep state and the following wake State according to the
`activity in the system.
`In the illustrated embodiment, the registers 30B may store
`pointers to register sets 30A or 30C, where the set of registers
`to which the pointer is referenced is dependent on the perfor
`mance domain corresponding to that register. In some
`embodiments, there may be register sets similar to 30A or
`30C for eac

This document is available on Docket Alarm but you must sign up to view it.


Or .

Accessing this document will incur an additional charge of $.

After purchase, you can access this document again without charge.

Accept $ Charge
throbber

Still Working On It

This document is taking longer than usual to download. This can happen if we need to contact the court directly to obtain the document and their servers are running slowly.

Give it another minute or two to complete, and then try the refresh button.

throbber

A few More Minutes ... Still Working

It can take up to 5 minutes for us to download a document if the court servers are running slowly.

Thank you for your continued patience.

This document could not be displayed.

We could not find this document within its docket. Please go back to the docket page and check the link. If that does not work, go back to the docket and refresh it to pull the newest information.

Your account does not support viewing this document.

You need a Paid Account to view this document. Click here to change your account type.

Your account does not support viewing this document.

Set your membership status to view this document.

With a Docket Alarm membership, you'll get a whole lot more, including:

  • Up-to-date information for this case.
  • Email alerts whenever there is an update.
  • Full text search for other cases.
  • Get email alerts whenever a new case matches your search.

Become a Member

One Moment Please

The filing “” is large (MB) and is being downloaded.

Please refresh this page in a few minutes to see if the filing has been downloaded. The filing will also be emailed to you when the download completes.

Your document is on its way!

If you do not receive the document in five minutes, contact support at support@docketalarm.com.

Sealed Document

We are unable to display this document, it may be under a court ordered seal.

If you have proper credentials to access the file, you may proceed directly to the court's system using your government issued username and password.


Access Government Site

We are redirecting you
to a mobile optimized page.





Document Unreadable or Corrupt

Refresh this Document
Go to the Docket

We are unable to display this document.

Refresh this Document
Go to the Docket