US20030237012A1 - Maintaining processor execution during frequency transitioning - Google Patents

Maintaining processor execution during frequency transitioning Download PDF

Info

Publication number
US20030237012A1
US20030237012A1 US10/180,836 US18083602A US2003237012A1 US 20030237012 A1 US20030237012 A1 US 20030237012A1 US 18083602 A US18083602 A US 18083602A US 2003237012 A1 US2003237012 A1 US 2003237012A1
Authority
US
United States
Prior art keywords
clock
core
standby
circuit
processor
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Granted
Application number
US10/180,836
Other versions
US7210054B2 (en
Inventor
Sanjeev Jahagirdar
Islam Derhalli
Varghese George
Kedar Mangrulkar
Mathew Nazareth
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Intel Corp
Original Assignee
Intel Corp
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Intel Corp filed Critical Intel Corp
Priority to US10/180,836 priority Critical patent/US7210054B2/en
Assigned to INTEL CORPORATION reassignment INTEL CORPORATION ASSIGNMENT OF ASSIGNORS INTEREST (SEE DOCUMENT FOR DETAILS). Assignors: DERHALLI, ISLAM, NAZARETH, MATHEW, MANGRULKAR, KEDAR, JAHAGIRDAR, SANJEEV, GEORGE, VARGHESE
Priority to AU2003241462A priority patent/AU2003241462A1/en
Priority to PCT/US2003/015306 priority patent/WO2004001564A2/en
Priority to TW092117146A priority patent/TWI300891B/en
Publication of US20030237012A1 publication Critical patent/US20030237012A1/en
Application granted granted Critical
Publication of US7210054B2 publication Critical patent/US7210054B2/en
Adjusted expiration legal-status Critical
Expired - Fee Related legal-status Critical Current

Links

Images

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06FELECTRIC DIGITAL DATA PROCESSING
    • G06F1/00Details not covered by groups G06F3/00 - G06F13/00 and G06F21/00
    • G06F1/04Generating or distributing clock signals or signals derived directly therefrom
    • G06F1/08Clock generators with changeable or programmable clock frequency

Definitions

  • Embodiments of the invention relate to the field of microprocessors, and more specifically, to frequency management.
  • FIG. 1 is a diagram illustrating a system in which one embodiment of the invention can be practiced.
  • FIG. 2 is a diagram illustrating a processor circuit according to one embodiment of the invention.
  • FIG. 3 is a diagram illustrating a clock circuit shown in FIG. 2 according to one embodiment of the invention.
  • FIG. 4 is a timing diagram illustrating the clock waveforms according to one embodiment of the invention.
  • FIG. 5 is a flowchart illustrating a process to generate processor clock according to one embodiment of the invention.
  • An embodiment of the present invention includes a standby clock generator and a selector.
  • the standby clock generator generates a standby clock synchronous to a core clock.
  • the core clock is generated by a core clock generator during a normal operation mode.
  • the core clock generator stops the core clock during a frequency transition.
  • the selector generates a processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
  • One embodiment of the invention may be described as a process which is usually depicted as a flowchart, a flow diagram, a structure diagram, or a block diagram. Although a flowchart may describe the operations as a sequential process, many of the operations can be performed in parallel or concurrently. In addition, the order of the operations may be re-arranged. A process is terminated when its operations are completed. A process may correspond to a method, a program, a procedure, etc.
  • FIG. 1 is a diagram illustrating a system 100 in which one embodiment of the invention can be practiced.
  • the system 100 includes a host processor 1 10 , a host bus 120 , a memory control hub (MCH) 130 , a system memory 140 , an input/output control hub (ICH) 150 , a peripheral bus 155 , a mass storage device 170 , and input/output devices 180 1 to 180 K .
  • MCH memory control hub
  • ICH input/output control hub
  • the host processor 110 represents a central processing unit of any type of architecture, such as embedded processors, mobile processors, micro-controllers, digital signal processors, superscalar computers, vector processors, single instruction multiple data (SIMD) computers, complex instruction set computers (CISC), reduced instruction set computers (RISC), very long instruction word (VLIW), or hybrid architecture.
  • the host processor 110 includes a processor circuit 105 .
  • the host bus 120 provides interface signals to allow the processor 110 to communicate with other processors or devices, e.g., the MCH 130 .
  • the host bus 120 may support a uni-processor or multiprocessor configuration.
  • the host bus 120 may be parallel, sequential, pipelined, asynchronous, synchronous, or any combination thereof.
  • the MCH 130 provides control and configuration of memory and input/output devices such as the system memory 140 and the ICH 150 .
  • the MCH 130 may be integrated into a chipset that integrates multiple functionalities such as the isolated execution mode, host-to-peripheral bus interface, memory control.
  • the MCH 130 interfaces to the peripheral bus 155 .
  • peripheral buses such as Peripheral Component Interconnect (PCI), accelerated graphics port (AGP), Industry Standard Architecture (ISA) bus, and Universal Serial Bus (USB), etc.
  • PCI Peripheral Component Interconnect
  • AGP accelerated graphics port
  • ISA Industry Standard Architecture
  • USB Universal Serial Bus
  • the system memory 140 stores system code and data.
  • the system memory 140 is typically implemented with dynamic random access memory (DRAM) or static random access memory (SRAM).
  • the system memory may include an operating system or an advanced configuration and power interface (ACPI) operating system (OS) 145 .
  • the ACPI OS 145 is the OS that is compatible to the power management scheme as specified in the ACPI standard, published by Compaq Computer Corporation, Intel Corporation, Microsoft Corporation, Phoenix Technologies Ltd, and Toshiba Corporation, Revision 2.0, in Jul. 27 2000.
  • the system memory 140 may also include other programs or data which are not shown.
  • the ICH 150 has a number of functionalities that are designed to support I/O functions.
  • the ICH 150 may also be integrated into a chipset together or separate from the MCH 130 to perform I/O functions.
  • the ICH 150 may include a number of interface and I/O functions such as PCI bus interface to interface to the peripheral bus 155 , processor interface, interrupt controller, direct memory access (DMA) controller, power management logic, timer, system management bus (SMBus), universal serial bus (USB) interface, mass storage interface, low pin count (LPC) interface, etc.
  • PCI bus interface to interface to the peripheral bus 155
  • processor interface interrupt controller
  • DMA direct memory access
  • SMB system management bus
  • USB universal serial bus
  • LPC low pin count
  • the mass storage device 170 stores archive information such as code, programs, files, data, applications, and operating systems.
  • the mass storage device 170 may include compact disk (CD) ROM 172 , a digital video/versatile disc (DVD) 173 , floppy drive 174 , and hard drive 176 , and any other magnetic or optic storage devices.
  • CD compact disk
  • DVD digital video/versatile disc
  • the mass storage device 170 provides a mechanism to read machine-accessible media.
  • the I/O devices 180 1 to 180 K may include any I/O devices to perform I/O functions.
  • I/O devices 180 1 to 180 K include controller for input devices (e.g., keyboard, mouse, track ball, pointing device), media card (e.g., audio, video, graphics), network card, and any other peripheral controllers.
  • FIG. 2 is a diagram illustrating a processor circuit 105 according to one embodiment of the invention.
  • the processor circuit 105 includes a clock circuit 210 , a processor core circuit 220 , and a power management circuit 230 .
  • the power management circuit 230 may be optional.
  • the term “clock” refers to a clock signal.
  • the clock circuit 210 generates a processor clock to the processor core circuit 220 .
  • the clock circuit 210 receives a system clock from an external source such as a clock signal from a crystal oscillator, a clock generator on the system board, etc.
  • the system clock provides the basic clock signal in the system from which other clock signals are generated.
  • the system clock is also stable and is a free-running clock.
  • the clock circuit 210 also receives power management control data from a power management circuit 230 .
  • the power management data may be a single bit indicating if a frequency transition is desired due to some thermal throttling or performance switch-over.
  • the processor core circuit 220 contains the core circuitry for the processor 100 . This may include any elements of the processor 100 such as instruction decoder, pipeline registers, execution units (e.g., arithmetic logic unit, floating-point processors), branch prediction logic circuit, etc.
  • the processor core circuit 220 receives the processor clock to clock all the synchronous elements.
  • the power management circuit 230 generates the power management control data based on the configuration information provided by a power management driver such as one from the ACPI OS 145 .
  • the power management circuit 230 may be optional and the power management control data may be provided directly from an external signal to a pin of the processor 110 .
  • the pin may be an interrupt pin, a thermal control pin, or any other suitable pin.
  • the power management circuit 230 may include a configuration register that stores configuration information as provided by the driver from the ACPI OS 145 .
  • a performance state of the processor 110 is typically dictated by the frequency at which the processor operates. The higher the frequency, the faster the processor's speed and the higher the performance.
  • a performance state is also related to power consumption and thermal state. A higher performance state consumes higher power and thus generates more heat.
  • the power management policy is one that adjusts the performance state of the processor according to the system and/or user's requirements. This policy may increase or decrease the processor's clock frequency.
  • a frequency transition period is an interval during which the processor's clock frequency is changed.
  • FIG. 3 is a diagram illustrating the clock circuit 210 shown in FIG. 2 according to one embodiment of the invention.
  • the clock circuit 210 includes a data clock generator 310 , a core clock generator 320 , a processor clock generator 330 , and a control circuit 360 .
  • the data clock generator 310 receives the system clock and generates a data clock.
  • the data clock is used to clock the core clock generator 320 and the processor clock generator 330 .
  • the data clock may also be used by various circuits in the processor core circuit 220 .
  • the data clock generator 310 includes a phase-locked loop (PLL) circuit to synthesize the data clock from the system clock and a data divisor.
  • the PLL circuit includes a locking circuit 312 and a divider 314 .
  • the locking circuit 312 locks a data feedback signal from the divider 314 with the system clock to provide the data clock.
  • the locking circuit 312 contains phase-locked loop elements as known by one of ordinary skill in the art such as phase comparator and loop filter.
  • the divider 314 is a divide-by-m circuit that divides the data clock by the data divisor to provide the data feedback signal to the locking circuit 312 .
  • the data divisor is an integer, typically fixed and selected for a suitable frequency for the data clock.
  • the core clock generator 320 generates a core clock from the data clock.
  • the core clock is selected as the processor clock during a normal operation mode.
  • the core clock generator 320 is a PLL circuit to synthesize the core clock from the data clock and a core divisor.
  • the core PLL circuit includes a locking circuit 322 and a divider 324 .
  • the locking circuit 322 locks a core feedback signal from the divider with the data clock to provide the core clock.
  • the locking circuit 322 contains phase-locked loop elements as known by one of ordinary skill in the art such as phase comparator and loop filter.
  • the divider 324 is a divide-by-n circuit that divides the core clock by the core divisor to provide the core feedback signal to the locking circuit 322 .
  • the core divisor is an integer provided to adjust the frequency of the core clock according to the power management policy.
  • the core divisor may be provided by the power management circuit 230 (FIG. 2) or programmed by the driver in the ACPI OS 145 (FIG. 1).
  • the processor clock is to be changed to a different frequency. This change takes place during a frequency transition from the normal operation mode.
  • the core divisor is changed to a suitable value.
  • the core clock generator 320 stops the core clock during the frequency transition in order to lock on the data clock with the new core divisor. After the frequency transition period, the core clock generator 320 resumes generation of the core clock with the new frequency.
  • the core clock generator 320 may also include a redundant clock generator 336 to generate a redundant clock from the data clock.
  • the redundant clock generator 336 may be any suitable clock synthesizer such as a PLL circuit with a fixed divisor or a divide-by-k circuit.
  • the redundant clock is a stable clock during the frequency transition. Typical values for the frequency of the system clock, data clock, and core clock are 100 MHz, 400 MHz, and 2000 MHz, respectively.
  • the processor clock generator 330 generates the processor clock to the processor core circuit 220 under the control of the control circuit 360 .
  • the processor clock generator 330 includes a standby clock generator 340 and a selector 350 .
  • the standby clock generator 330 generates a stable standby clock synchronous to the core clock.
  • the standby clock is a free-running clock with frequency selected according to processor architecture and design process. Some of the criteria to select the frequency of the standby clock include the minimum allowable of the core clock frequency, the core PLL support for odd and even divisors, the stability, skew and jitter characteristics of the PLL circuits in the data clock generator 310 and the core clock generator 320 .
  • the standby clock generator includes a buffer 342 and/or a divider 344 , and optionally a multiplexer 346 .
  • the buffer 342 buffers the redundant clock from the redundant clock generator 336 to provide the standby clock.
  • the standby clock generator 340 may include only the buffer 342 or only the divider 344 .
  • the selector 350 generates the processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
  • the selector 350 selects one of the core clock and the standby clock to provide the processor clock.
  • the selector 350 selects the core clock.
  • the selector 350 selects the standby clock.
  • the selector 350 is a multiplexer having two inputs connected to the core clock and the standby clock.
  • the control circuit 360 generates the selector control signal to the selector 350 to control selection of one of the core clock and the standby clock.
  • the control circuit 360 receives a command from the power management control data provided by the power management circuit or programmed by the driver in the ACPI OS 145 (FIG. 1) when there is a thermal event that requires a change in the frequency of the processor clock.
  • the control circuit 360 may include a synchronizer 365 to synchronize the selector control signal with the data clock.
  • the synchronizer 365 may be a D flip-flop clocked by the data clock.
  • processor clock Since the processor clock is generated continuously during the normal mode period and the frequency transition period, the processor execution is maintained. Furthermore, if the processor clock or its derivatives is used to clock other elements or circuits, the data integrity is maintained during the frequency transition period.
  • FIG. 4 is a timing diagram illustrating the clock waveforms according to one embodiment of the invention.
  • the clock waveforms include the data clock, the selector control signal, the core clock, the standby clock, and the resulting processor clock.
  • the data clock is a free-running clock from which the core clock and the standby clock are derived.
  • the selector control signal has two states. In a first state (e.g., LOW), the selector control signal is negated corresponding to the normal operation period. During this period, the processor clock is the core clock. In a second state (e.g., HIGH), the selector control signal is asserted corresponding to the frequency transition period. During this period, the core clock is stopped while the core clock generator locks to the new divisor or ratio, and the processor clock is the standby clock. After the frequency transition period is over, the selector control signal is negated low to return to the normal operation mode. The core clock is generated with a new frequency in the normal operation mode.
  • the processor clock is the core clock. Note that the negation and assertion of the selector control signal may be reversed as is known by one of ordinary skill in the art. In other words, the selector control signal may be negated during the frequency transition period and asserted during the normal operation period.
  • the selector control signal When the frequency transition period is over, the selector control signal is negated so that the processor clock becomes the new core clock.
  • the processor clock therefore, is continuously running in both normal and frequency transition periods.
  • Many personal computer (PC) platforms or software specify that the processor's unavailability be less than some time period, e.g., 5 ⁇ sec.
  • the processor clock is continuously available. Therefore, the processor is almost always available, exceeding the requirements by these PC platforms or software.
  • FIG. 5 is a flowchart illustrating a process 500 to generate processor clock according to one embodiment of the invention.
  • the process 500 Upon START, the process 500 generates the standby clock synchronous to the core clock (Block 510 ).
  • the standby clock may be generated from the data clock or from a stable redundant clock from the core clock generator.
  • the process 500 determines if there is a frequency transition due to a thermal event or a power management command (Block 520 ). If so, the process 500 receives a power management control data or command (Block 530 ). The process 500 then asserts the selector control signal (Block 540 ).
  • the process 550 generates the processor clock from the standby clock using the asserted selector control signal (Block 550 ) and is then terminated or returns back to Block 520 .
  • the process 500 negates the selector control signal Block 560 ).
  • the process 500 generates the processor clock from the core clock using the negated selector control signal (Block 570 ) and is then terminated, or returns back to Block 520 .

Landscapes

  • Engineering & Computer Science (AREA)
  • Theoretical Computer Science (AREA)
  • Physics & Mathematics (AREA)
  • General Engineering & Computer Science (AREA)
  • General Physics & Mathematics (AREA)
  • Power Sources (AREA)
  • Microcomputers (AREA)
  • Executing Machine-Instructions (AREA)

Abstract

An embodiment of the present invention includes a standby clock generator and a selector. The standby clock generator generates a standby clock synchronous to a core clock. The core clock is generated by a core clock generator during a normal operation mode. The core clock generator stops the core clock during a frequency transition. The selector generates a processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.

Description

    BACKGROUND
  • 1. Field [0001]
  • Embodiments of the invention relate to the field of microprocessors, and more specifically, to frequency management. [0002]
  • 2. Background [0003]
  • Advances in microprocessor technology have provided users with high level of performance flexibility. For example, mobile processors offer users two performance modes: Maximum Performance mode and Battery Optimized mode. Maximum Performance mode takes advantage of the additional power provided by an alternating current (AC) power source to provide a new level of mobile personal computer (PC) performance, while Battery Optimized mode provides optimal performance while running on battery. In Maximum Performance mode, the processor delivers highest performance at the expense of high power consumption. In Battery Optimized mode, the processor provides lower performance but consumes much less power. [0004]
  • Recently, demands for high performance have accelerated development of very fast processors at more than 1 GHz operating frequency. Thermal throttling or monitoring and other performance operations feature power management by changing the frequency at which the processor operates. In existing circuits, frequency switching between performance states requires the processor to stop execution during frequency transition. This transitioning from one mode to another may lead to many undesirable effects such as excessive bus master and software latency, end-user visible artifacts (e.g., audio drop-out, video frame loss), and component stress. [0005]
  • BRIEF DESCRIPTION OF THE DRAWINGS
  • The invention may best be understood by referring to the following description and accompanying drawings that are used to illustrate embodiments of the invention. In the drawings: [0006]
  • FIG. 1 is a diagram illustrating a system in which one embodiment of the invention can be practiced. [0007]
  • FIG. 2 is a diagram illustrating a processor circuit according to one embodiment of the invention. [0008]
  • FIG. 3 is a diagram illustrating a clock circuit shown in FIG. 2 according to one embodiment of the invention. [0009]
  • FIG. 4 is a timing diagram illustrating the clock waveforms according to one embodiment of the invention. [0010]
  • FIG. 5 is a flowchart illustrating a process to generate processor clock according to one embodiment of the invention. [0011]
  • DESCRIPTION
  • An embodiment of the present invention includes a standby clock generator and a selector. The standby clock generator generates a standby clock synchronous to a core clock. The core clock is generated by a core clock generator during a normal operation mode. The core clock generator stops the core clock during a frequency transition. The selector generates a processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal. [0012]
  • In the following description, numerous specific details are set forth. However, it is understood that embodiments of the invention may be practiced without these specific details. In other instances, well-known circuits, structures, and techniques have not been shown in order not to obscure the understanding of this description. [0013]
  • One embodiment of the invention may be described as a process which is usually depicted as a flowchart, a flow diagram, a structure diagram, or a block diagram. Although a flowchart may describe the operations as a sequential process, many of the operations can be performed in parallel or concurrently. In addition, the order of the operations may be re-arranged. A process is terminated when its operations are completed. A process may correspond to a method, a program, a procedure, etc. [0014]
  • FIG. 1 is a diagram illustrating a [0015] system 100 in which one embodiment of the invention can be practiced. The system 100 includes a host processor 1 10, a host bus 120, a memory control hub (MCH) 130, a system memory 140, an input/output control hub (ICH) 150, a peripheral bus 155, a mass storage device 170, and input/output devices 180 1 to 180 K. Note that the system 100 may include more or less elements than these elements.
  • The [0016] host processor 110 represents a central processing unit of any type of architecture, such as embedded processors, mobile processors, micro-controllers, digital signal processors, superscalar computers, vector processors, single instruction multiple data (SIMD) computers, complex instruction set computers (CISC), reduced instruction set computers (RISC), very long instruction word (VLIW), or hybrid architecture. The host processor 110 includes a processor circuit 105.
  • The host bus [0017] 120 provides interface signals to allow the processor 110 to communicate with other processors or devices, e.g., the MCH 130. The host bus 120 may support a uni-processor or multiprocessor configuration. The host bus 120 may be parallel, sequential, pipelined, asynchronous, synchronous, or any combination thereof.
  • The MCH [0018] 130 provides control and configuration of memory and input/output devices such as the system memory 140 and the ICH 150. The MCH 130 may be integrated into a chipset that integrates multiple functionalities such as the isolated execution mode, host-to-peripheral bus interface, memory control. The MCH 130 interfaces to the peripheral bus 155. For clarity, not all the peripheral buses are shown. It is contemplated that the system 100 may also include peripheral buses such as Peripheral Component Interconnect (PCI), accelerated graphics port (AGP), Industry Standard Architecture (ISA) bus, and Universal Serial Bus (USB), etc.
  • The [0019] system memory 140 stores system code and data. The system memory 140 is typically implemented with dynamic random access memory (DRAM) or static random access memory (SRAM). The system memory may include an operating system or an advanced configuration and power interface (ACPI) operating system (OS) 145. The ACPI OS 145 is the OS that is compatible to the power management scheme as specified in the ACPI standard, published by Compaq Computer Corporation, Intel Corporation, Microsoft Corporation, Phoenix Technologies Ltd, and Toshiba Corporation, Revision 2.0, in Jul. 27 2000. The system memory 140 may also include other programs or data which are not shown.
  • The ICH [0020] 150 has a number of functionalities that are designed to support I/O functions. The ICH 150 may also be integrated into a chipset together or separate from the MCH 130 to perform I/O functions. The ICH 150 may include a number of interface and I/O functions such as PCI bus interface to interface to the peripheral bus 155, processor interface, interrupt controller, direct memory access (DMA) controller, power management logic, timer, system management bus (SMBus), universal serial bus (USB) interface, mass storage interface, low pin count (LPC) interface, etc.
  • The [0021] mass storage device 170 stores archive information such as code, programs, files, data, applications, and operating systems. The mass storage device 170 may include compact disk (CD) ROM 172, a digital video/versatile disc (DVD) 173, floppy drive 174, and hard drive 176, and any other magnetic or optic storage devices. The mass storage device 170 provides a mechanism to read machine-accessible media.
  • The I/O devices [0022] 180 1 to 180 K may include any I/O devices to perform I/O functions. Examples of I/O devices 180 1 to 180 K include controller for input devices (e.g., keyboard, mouse, track ball, pointing device), media card (e.g., audio, video, graphics), network card, and any other peripheral controllers.
  • FIG. 2 is a diagram illustrating a [0023] processor circuit 105 according to one embodiment of the invention. The processor circuit 105 includes a clock circuit 210, a processor core circuit 220, and a power management circuit 230. Note that the power management circuit 230 may be optional. In the following, the term “clock” refers to a clock signal.
  • The [0024] clock circuit 210 generates a processor clock to the processor core circuit 220. The clock circuit 210 receives a system clock from an external source such as a clock signal from a crystal oscillator, a clock generator on the system board, etc. Typically, the system clock provides the basic clock signal in the system from which other clock signals are generated. In addition, the system clock is also stable and is a free-running clock. The clock circuit 210 also receives power management control data from a power management circuit 230. The power management data may be a single bit indicating if a frequency transition is desired due to some thermal throttling or performance switch-over.
  • The [0025] processor core circuit 220 contains the core circuitry for the processor 100. This may include any elements of the processor 100 such as instruction decoder, pipeline registers, execution units (e.g., arithmetic logic unit, floating-point processors), branch prediction logic circuit, etc. The processor core circuit 220 receives the processor clock to clock all the synchronous elements.
  • The [0026] power management circuit 230 generates the power management control data based on the configuration information provided by a power management driver such as one from the ACPI OS 145. The power management circuit 230 may be optional and the power management control data may be provided directly from an external signal to a pin of the processor 110. The pin may be an interrupt pin, a thermal control pin, or any other suitable pin. The power management circuit 230 may include a configuration register that stores configuration information as provided by the driver from the ACPI OS 145.
  • A performance state of the [0027] processor 110 is typically dictated by the frequency at which the processor operates. The higher the frequency, the faster the processor's speed and the higher the performance. A performance state is also related to power consumption and thermal state. A higher performance state consumes higher power and thus generates more heat. The power management policy is one that adjusts the performance state of the processor according to the system and/or user's requirements. This policy may increase or decrease the processor's clock frequency. A frequency transition period is an interval during which the processor's clock frequency is changed.
  • FIG. 3 is a diagram illustrating the [0028] clock circuit 210 shown in FIG. 2 according to one embodiment of the invention. The clock circuit 210 includes a data clock generator 310, a core clock generator 320, a processor clock generator 330, and a control circuit 360.
  • The [0029] data clock generator 310 receives the system clock and generates a data clock. The data clock is used to clock the core clock generator 320 and the processor clock generator 330. The data clock may also be used by various circuits in the processor core circuit 220. The data clock generator 310 includes a phase-locked loop (PLL) circuit to synthesize the data clock from the system clock and a data divisor. The PLL circuit includes a locking circuit 312 and a divider 314. The locking circuit 312 locks a data feedback signal from the divider 314 with the system clock to provide the data clock. The locking circuit 312 contains phase-locked loop elements as known by one of ordinary skill in the art such as phase comparator and loop filter. The divider 314 is a divide-by-m circuit that divides the data clock by the data divisor to provide the data feedback signal to the locking circuit 312. The data divisor is an integer, typically fixed and selected for a suitable frequency for the data clock.
  • The [0030] core clock generator 320 generates a core clock from the data clock. The core clock is selected as the processor clock during a normal operation mode. The core clock generator 320 is a PLL circuit to synthesize the core clock from the data clock and a core divisor. The core PLL circuit includes a locking circuit 322 and a divider 324. The locking circuit 322 locks a core feedback signal from the divider with the data clock to provide the core clock. The locking circuit 322 contains phase-locked loop elements as known by one of ordinary skill in the art such as phase comparator and loop filter. The divider 324 is a divide-by-n circuit that divides the core clock by the core divisor to provide the core feedback signal to the locking circuit 322. The core divisor is an integer provided to adjust the frequency of the core clock according to the power management policy. The core divisor may be provided by the power management circuit 230 (FIG. 2) or programmed by the driver in the ACPI OS 145 (FIG. 1). During a thermal throttling or monitoring, the processor clock is to be changed to a different frequency. This change takes place during a frequency transition from the normal operation mode. During this time, the core divisor is changed to a suitable value. The core clock generator 320 stops the core clock during the frequency transition in order to lock on the data clock with the new core divisor. After the frequency transition period, the core clock generator 320 resumes generation of the core clock with the new frequency. The core clock generator 320 may also include a redundant clock generator 336 to generate a redundant clock from the data clock. The redundant clock generator 336 may be any suitable clock synthesizer such as a PLL circuit with a fixed divisor or a divide-by-k circuit. The redundant clock is a stable clock during the frequency transition. Typical values for the frequency of the system clock, data clock, and core clock are 100 MHz, 400 MHz, and 2000 MHz, respectively.
  • The processor clock generator [0031] 330 generates the processor clock to the processor core circuit 220 under the control of the control circuit 360. The processor clock generator 330 includes a standby clock generator 340 and a selector 350.
  • The standby clock generator [0032] 330 generates a stable standby clock synchronous to the core clock. Typically, the standby clock is a free-running clock with frequency selected according to processor architecture and design process. Some of the criteria to select the frequency of the standby clock include the minimum allowable of the core clock frequency, the core PLL support for odd and even divisors, the stability, skew and jitter characteristics of the PLL circuits in the data clock generator 310 and the core clock generator 320. In one embodiment, the standby clock generator includes a buffer 342 and/or a divider 344, and optionally a multiplexer 346. The buffer 342 buffers the redundant clock from the redundant clock generator 336 to provide the standby clock. Since this redundant clock is stable during the frequency transition even when the core PLL locks to the new divisor, the standby clock is stable during this period. The divider 344 divides the data clock with a fixed divisor to provide an alternate standby clock. Since the data clock is stable during the frequency transition, the standby clock so generated is also stable. The multiplexer 346 selects one of the buffered redundant clock and the divided data clock to be the standby clock. The muliplexer 346 may not be needed. The standby clock generator 340 may include only the buffer 342 or only the divider 344.
  • The [0033] selector 350 generates the processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal. The selector 350 selects one of the core clock and the standby clock to provide the processor clock. During the normal operation mode, the selector 350 selects the core clock. During the frequency transition, the selector 350 selects the standby clock. In one embodiment, the selector 350 is a multiplexer having two inputs connected to the core clock and the standby clock.
  • The [0034] control circuit 360 generates the selector control signal to the selector 350 to control selection of one of the core clock and the standby clock. The control circuit 360 receives a command from the power management control data provided by the power management circuit or programmed by the driver in the ACPI OS 145 (FIG. 1) when there is a thermal event that requires a change in the frequency of the processor clock. The control circuit 360 may include a synchronizer 365 to synchronize the selector control signal with the data clock. The synchronizer 365 may be a D flip-flop clocked by the data clock.
  • Since the processor clock is generated continuously during the normal mode period and the frequency transition period, the processor execution is maintained. Furthermore, if the processor clock or its derivatives is used to clock other elements or circuits, the data integrity is maintained during the frequency transition period. [0035]
  • FIG. 4 is a timing diagram illustrating the clock waveforms according to one embodiment of the invention. The clock waveforms include the data clock, the selector control signal, the core clock, the standby clock, and the resulting processor clock. [0036]
  • The data clock is a free-running clock from which the core clock and the standby clock are derived. The selector control signal has two states. In a first state (e.g., LOW), the selector control signal is negated corresponding to the normal operation period. During this period, the processor clock is the core clock. In a second state (e.g., HIGH), the selector control signal is asserted corresponding to the frequency transition period. During this period, the core clock is stopped while the core clock generator locks to the new divisor or ratio, and the processor clock is the standby clock. After the frequency transition period is over, the selector control signal is negated low to return to the normal operation mode. The core clock is generated with a new frequency in the normal operation mode. The processor clock is the core clock. Note that the negation and assertion of the selector control signal may be reversed as is known by one of ordinary skill in the art. In other words, the selector control signal may be negated during the frequency transition period and asserted during the normal operation period. [0037]
  • When the frequency transition period is over, the selector control signal is negated so that the processor clock becomes the new core clock. The processor clock, therefore, is continuously running in both normal and frequency transition periods. Many personal computer (PC) platforms or software specify that the processor's unavailability be less than some time period, e.g., 5 μsec. Using the clock circuit as described above, the processor clock is continuously available. Therefore, the processor is almost always available, exceeding the requirements by these PC platforms or software. [0038]
  • FIG. 5 is a flowchart illustrating a [0039] process 500 to generate processor clock according to one embodiment of the invention.
  • Upon START, the [0040] process 500 generates the standby clock synchronous to the core clock (Block 510). The standby clock may be generated from the data clock or from a stable redundant clock from the core clock generator. Next, the process 500 determines if there is a frequency transition due to a thermal event or a power management command (Block 520). If so, the process 500 receives a power management control data or command (Block 530). The process 500 then asserts the selector control signal (Block 540). Next, the process 550 generates the processor clock from the standby clock using the asserted selector control signal (Block 550) and is then terminated or returns back to Block 520.
  • If there is no frequency transition, the [0041] process 500 negates the selector control signal Block 560). Next, the process 500 generates the processor clock from the core clock using the negated selector control signal (Block 570) and is then terminated, or returns back to Block 520.
  • While the invention has been described in terms of several embodiments, those of ordinary skill in the art will recognize that the invention is not limited to the embodiments described, but can be practiced with modification and alteration within the spirit and scope of the appended claims. The description is thus to be regarded as illustrative instead of limiting. [0042]

Claims (30)

What is claimed is:
1. An apparatus comprising:
a standby clock generator to generate a standby clock synchronous to a core clock, the core clock being generated by a core clock generator during a normal operation mode, the core clock generator stopping the core clock during a frequency transition; and
a selector coupled to the standby clock generator to generate a processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
2. The apparatus of claim 1 wherein the standby clock generator comprises:
a divider coupled to a data clock generator to divide a data clock into the standby clock, the data clock being divided by the core clock generator into the core clock.
3. The apparatus of claim 1 wherein the standby clock generator comprises:
a buffer to buffer a redundant clock from the core clock generator, the redundant clock being stable during the frequency transition.
4. The apparatus of claim 1 wherein the selector generates the processor clock from the core clock during the normal operation mode.
5. The apparatus of claim 1 wherein the selector comprises:
a multiplexer coupled to the standby clock generator and the core clock generator to select one of the standby clock and the core clock according to the selector control signal, the selected one of the standby clock and the core clock being the processor clock.
6. The apparatus of claim 2 further comprising:
a control circuit coupled to the selector to generate the selector control signal according to a power management policy.
7. The apparatus of claim 6 wherein the control circuit comprises:
a synchronizer to synchronize the selector control signal to the data clock.
8. A method comprising:
generating a standby clock synchronous to a core clock, the core clock being generated by a core clock generator during a normal operation mode, the core clock generator stopping the core clock during a frequency transition; and
generating a processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
9. The method of claim 8 wherein generating the standby clock comprises:
dividing a data clock into the standby clock, the data clock being divided by the core clock generator into the core clock.
10. The method of claim 8 wherein generating standby clock comprises:
buffering a redundant clock from the core clock generator, the redundant clock being stable during the frequency transition.
11. The method of claim 8 wherein generating a processor clock comprises:
generating the processor clock from the core clock during the normal operation mode.
12. The method of claim 8 wherein generating a processor clock comprises:
selecting one of the standby clock and the core clock by a multiplexer according to the selector control signal, the selected one of the standby clock and the core clock being the processor clock.
13. The method of claim 9 further comprising:
generating the selector control signal according to a power management policy.
14. The method of claim 13 wherein generating the selector control signal comprises:
synchronizing the selector control signal to the data clock.
15. A circuit comprising:
a data clock generator to generate a data clock from a system clock;
a core clock generator coupled to the data clock generator to generate a core clock during a normal operation mode, the core clock generator stopping the core clock during a frequency transition; and
a processor clock generator coupled to the core clock generator to generate a processor clock to a processor core circuit, the processor clock generator comprising:
a standby clock generator to generate a standby clock synchronous to the core clock, and
a selector coupled to the standby clock generator to generate the processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
16. The circuit of claim 15 wherein the standby clock generator comprises:
a divider coupled to a data clock generator to divide a data clock into the standby clock, the data clock being divided by the core clock generator into the core clock.
17. The circuit of claim 15 wherein the standby clock generator comprises:
a buffer to buffer a redundant clock from the core clock generator, the redundant clock being stable during the frequency transition.
18. The circuit of claim 15 wherein the selector generates the processor clock from the core clock during the normal operation mode.
19. The circuit of claim 15 wherein the selector comprises:
a multiplexer coupled to the standby clock generator and the core clock generator to select one of the standby clock and the core clock according to the selector control signal, the selected one of the standby clock and the core clock being the processor clock.
20. The circuit of claim 16 further comprising:
a control circuit coupled to the selector to generate the selector control signal according to a power management policy.
21. The circuit of claim 20 wherein the control circuit comprises:
a synchronizer to synchronize the selector control signal to the data clock.
22. The circuit of claim 15 wherein the data clock generator comprises:
a data phase-locked loop (PLL) circuit to lock a data feedback signal to the system clock using a data divider, the data feedback signal being divided from the data clock by the data divider.
23. The circuit of claim 15 wherein the core clock generator comprises:
a core phase-locked loop (PLL) circuit to lock a core feedback signal to the data clock using a first core divider during the normal operation mode, the core feedback signal being divided from the core clock by the first core divider.
24. The circuit of claim 23 wherein the core PLL circuit locks the core feedback signal using a second core divider during the frequency transition, the core feedback signal being divided from the core clock by the second core divider.
25. A circuit comprising:
a power management circuit to manage power of a processor core circuit according to a power management policy, and
a clock circuit to provide a processor clock to the processor core circuit according to the power managed by the power management circuit, the clock circuit comprising:
a data clock generator to generate a data clock from a system clock,
a core clock generator coupled to the data clock generator to generate a core clock during a normal operation mode, the core clock generator stopping the core clock during a frequency transition, and
a processor clock generator coupled to the core clock generator to generate a processor clock to a processor core circuit, the processor clock generator comprising:
a standby clock generator to generate a standby clock synchronous to the core clock, and
a selector coupled to the standby clock generator to generate the processor clock from the standby clock during the frequency transition from the normal operation mode according to a selector control signal.
26. The circuit of claim 25 wherein the standby clock generator comprises:
a divider coupled to a data clock generator to divide a data clock into the standby clock, the data clock being divided by the core clock generator into the core clock.
27. The circuit of claim 25 wherein the standby clock generator comprises:
a buffer to buffer a redundant clock from the core clock generator, the redundant clock being stable during the frequency transition.
28. The circuit of claim 25 wherein the selector generates the processor clock from the core clock during the normal operation mode.
29. The circuit of claim 25 wherein the selector comprises:
a multiplexer coupled to the standby clock generator and the core clock generator to select one of the standby clock and the core clock according to the selector control signal, the selected one of the standby clock and the core clock being the processor clock.
30. The circuit of claim 26 wherein the clock circuit further comprises:
a control circuit coupled to the selector to generate the selector control signal according to the power management policy.
US10/180,836 2002-06-25 2002-06-25 Maintaining processor execution during frequency transitioning Expired - Fee Related US7210054B2 (en)

Priority Applications (4)

Application Number Priority Date Filing Date Title
US10/180,836 US7210054B2 (en) 2002-06-25 2002-06-25 Maintaining processor execution during frequency transitioning
AU2003241462A AU2003241462A1 (en) 2002-06-25 2003-05-15 Maintaining processor execution during frequency transitioning
PCT/US2003/015306 WO2004001564A2 (en) 2002-06-25 2003-05-15 Maintaining processor execution during frequency transitioning
TW092117146A TWI300891B (en) 2002-06-25 2003-06-24 Apparatus ,method and circuit for maintaining processor execution during frequency transitioning

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
US10/180,836 US7210054B2 (en) 2002-06-25 2002-06-25 Maintaining processor execution during frequency transitioning

Publications (2)

Publication Number Publication Date
US20030237012A1 true US20030237012A1 (en) 2003-12-25
US7210054B2 US7210054B2 (en) 2007-04-24

Family

ID=29735096

Family Applications (1)

Application Number Title Priority Date Filing Date
US10/180,836 Expired - Fee Related US7210054B2 (en) 2002-06-25 2002-06-25 Maintaining processor execution during frequency transitioning

Country Status (4)

Country Link
US (1) US7210054B2 (en)
AU (1) AU2003241462A1 (en)
TW (1) TWI300891B (en)
WO (1) WO2004001564A2 (en)

Cited By (10)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040139356A1 (en) * 2003-01-10 2004-07-15 Kenneth Ma Method and apparatus for improving bus master performance
US20040255176A1 (en) * 2003-06-10 2004-12-16 Varghese George Method and apparatus for improved reliability and reduced power in a processor by automatic voltage control during processor idle states
US20050022044A1 (en) * 2003-07-22 2005-01-27 Yoshinori Shimosakoda Clock control circuit and clock control method
US20050188235A1 (en) * 2004-02-24 2005-08-25 Atkinson Lee W. System and method for performing CPU soft-start
US20090019185A1 (en) * 2003-02-14 2009-01-15 Kardach James P Non Main CPU/OS Based Operational Environment
US7667500B1 (en) * 2006-11-14 2010-02-23 Xilinx, Inc. Glitch-suppressor circuits and methods
US20130086395A1 (en) * 2011-09-30 2013-04-04 Qualcomm Incorporated Multi-Core Microprocessor Reliability Optimization
US8892935B2 (en) 2011-04-22 2014-11-18 Wistron Corporation Dynamic bus clock rate adjusting method and device
US8996902B2 (en) 2012-10-23 2015-03-31 Qualcomm Incorporated Modal workload scheduling in a heterogeneous multi-processor system on a chip
US20150113304A1 (en) * 2013-10-22 2015-04-23 Wisconsin Alumni Research Foundation Energy-efficient multicore processor architecture for parallel processing

Families Citing this family (12)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US6917658B2 (en) * 2002-09-16 2005-07-12 Silicon Labs Cp, Inc. Clock recovery method for bursty communications
US7698583B2 (en) * 2002-10-03 2010-04-13 Via Technologies, Inc. Microprocessor capable of dynamically reducing its power consumption in response to varying operating temperature
US7770042B2 (en) * 2002-10-03 2010-08-03 Via Technologies, Inc. Microprocessor with improved performance during P-state transitions
US7774627B2 (en) * 2002-10-03 2010-08-10 Via Technologies, Inc. Microprocessor capable of dynamically increasing its performance in response to varying operating temperature
US7814350B2 (en) * 2002-10-03 2010-10-12 Via Technologies, Inc. Microprocessor with improved thermal monitoring and protection mechanism
US6974252B2 (en) * 2003-03-11 2005-12-13 Intel Corporation Failsafe mechanism for preventing an integrated circuit from overheating
CN100470656C (en) 2003-10-31 2009-03-18 宇田控股有限公司 Method and apparatus for generating oscillating clock signal
US7496774B2 (en) * 2004-06-04 2009-02-24 Broadcom Corporation Method and system for generating clocks for standby mode operation in a mobile communication device
DE102004030969A1 (en) * 2004-06-26 2006-01-12 Robert Bosch Gmbh Method and device for controlling a bus system and corresponding bus system
US7809973B2 (en) * 2005-11-16 2010-10-05 Cypress Semiconductor Corporation Spread spectrum clock for USB
CN101576767B (en) * 2008-07-01 2010-12-08 鸿富锦精密工业(深圳)有限公司 Main board power supply circuit
US9411360B2 (en) * 2014-01-13 2016-08-09 Apple Inc. Method to manage current during clock frequency changes

Citations (22)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5021679A (en) * 1989-06-30 1991-06-04 Poqet Computer Corporation Power supply and oscillator for a computer system providing automatic selection of supply voltage and frequency
US5095280A (en) * 1990-11-26 1992-03-10 Integrated Circuit Systems, Inc. Dual dot clock signal generator
US5142247A (en) * 1991-08-06 1992-08-25 Compaq Computer Corporation Multiple frequency phase-locked loop clock generator with stable transitions between frequencies
US5153535A (en) * 1989-06-30 1992-10-06 Poget Computer Corporation Power supply and oscillator for a computer system providing automatic selection of supply voltage and frequency
US5355090A (en) * 1989-10-06 1994-10-11 Rockwell International Corporation Phase corrector for redundant clock systems and method
US5579353A (en) * 1993-10-12 1996-11-26 Texas Instruments Incorporated Dynamic clock mode switch
US5594895A (en) * 1992-12-15 1997-01-14 International Business Machines Corporation Method and apparatus for switching between clock generators only when activity on a bus can be stopped
US5627412A (en) * 1994-11-07 1997-05-06 Norand Corporation Dynamically switchable power supply
US5752011A (en) * 1994-06-20 1998-05-12 Thomas; C. Douglas Method and system for controlling a processor's clock frequency in accordance with the processor's temperature
US5774701A (en) * 1995-07-10 1998-06-30 Hitachi, Ltd. Microprocessor operating at high and low clok frequencies
US5903746A (en) * 1996-11-04 1999-05-11 Texas Instruments Incorporated Apparatus and method for automatically sequencing clocks in a data processing system when entering or leaving a low power state
US6163583A (en) * 1998-03-25 2000-12-19 Sony Corporation Of Japan Dynamic clocking apparatus and system for reducing power dissipation
US6204732B1 (en) * 1999-02-09 2001-03-20 Eci Telecom Ltd Apparatus for clock signal distribution, with transparent switching capability between two clock distribution units
US6239626B1 (en) * 2000-01-07 2001-05-29 Cisco Technology, Inc. Glitch-free clock selector
US20020047748A1 (en) * 1999-08-12 2002-04-25 Atsushi Fujita Clock control circuit
US6462592B1 (en) * 1999-09-07 2002-10-08 Lg Electronics Inc. Clock signal converting apparatus of a transmission system
US6519707B2 (en) * 1999-04-30 2003-02-11 Intel Corporation Method and apparatus for dynamic power control of a low power processor
US6664775B1 (en) * 2000-08-21 2003-12-16 Intel Corporation Apparatus having adjustable operational modes and method therefore
US6754837B1 (en) * 2000-07-17 2004-06-22 Advanced Micro Devices, Inc. Programmable stabilization interval for internal stop grant state during which core logic is supplied with clocks and power to minimize stabilization delay
US6772356B1 (en) * 2000-04-05 2004-08-03 Advanced Micro Devices, Inc. System for specifying core voltage for a microprocessor by selectively outputting one of a first, fixed and a second, variable voltage control settings from the microprocessor
US6785829B1 (en) * 2000-06-30 2004-08-31 Intel Corporation Multiple operating frequencies in a processor
US6831959B1 (en) * 2000-08-09 2004-12-14 Cisco Technology, Inc. Method and system for switching between multiple clock signals in digital circuit

Patent Citations (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5021679A (en) * 1989-06-30 1991-06-04 Poqet Computer Corporation Power supply and oscillator for a computer system providing automatic selection of supply voltage and frequency
US5153535A (en) * 1989-06-30 1992-10-06 Poget Computer Corporation Power supply and oscillator for a computer system providing automatic selection of supply voltage and frequency
US5307003A (en) * 1989-06-30 1994-04-26 Poqet Computer Corporation Varying the supply voltage in response to the current supplied to a computer system
US5355090A (en) * 1989-10-06 1994-10-11 Rockwell International Corporation Phase corrector for redundant clock systems and method
US5095280A (en) * 1990-11-26 1992-03-10 Integrated Circuit Systems, Inc. Dual dot clock signal generator
US5142247A (en) * 1991-08-06 1992-08-25 Compaq Computer Corporation Multiple frequency phase-locked loop clock generator with stable transitions between frequencies
US5594895A (en) * 1992-12-15 1997-01-14 International Business Machines Corporation Method and apparatus for switching between clock generators only when activity on a bus can be stopped
US5579353A (en) * 1993-10-12 1996-11-26 Texas Instruments Incorporated Dynamic clock mode switch
US5974557A (en) * 1994-06-20 1999-10-26 Thomas; C. Douglass Method and system for performing thermal and power management for a computer
US6487668B2 (en) * 1994-06-20 2002-11-26 C. Douglass Thomas Thermal and power management to computer systems
US6216235B1 (en) * 1994-06-20 2001-04-10 C. Douglass Thomas Thermal and power management for computer systems
US5752011A (en) * 1994-06-20 1998-05-12 Thomas; C. Douglas Method and system for controlling a processor's clock frequency in accordance with the processor's temperature
US5627412A (en) * 1994-11-07 1997-05-06 Norand Corporation Dynamically switchable power supply
US5774701A (en) * 1995-07-10 1998-06-30 Hitachi, Ltd. Microprocessor operating at high and low clok frequencies
US5903746A (en) * 1996-11-04 1999-05-11 Texas Instruments Incorporated Apparatus and method for automatically sequencing clocks in a data processing system when entering or leaving a low power state
US6163583A (en) * 1998-03-25 2000-12-19 Sony Corporation Of Japan Dynamic clocking apparatus and system for reducing power dissipation
US6204732B1 (en) * 1999-02-09 2001-03-20 Eci Telecom Ltd Apparatus for clock signal distribution, with transparent switching capability between two clock distribution units
US6519707B2 (en) * 1999-04-30 2003-02-11 Intel Corporation Method and apparatus for dynamic power control of a low power processor
US20020047748A1 (en) * 1999-08-12 2002-04-25 Atsushi Fujita Clock control circuit
US6462592B1 (en) * 1999-09-07 2002-10-08 Lg Electronics Inc. Clock signal converting apparatus of a transmission system
US6239626B1 (en) * 2000-01-07 2001-05-29 Cisco Technology, Inc. Glitch-free clock selector
US6772356B1 (en) * 2000-04-05 2004-08-03 Advanced Micro Devices, Inc. System for specifying core voltage for a microprocessor by selectively outputting one of a first, fixed and a second, variable voltage control settings from the microprocessor
US6785829B1 (en) * 2000-06-30 2004-08-31 Intel Corporation Multiple operating frequencies in a processor
US6754837B1 (en) * 2000-07-17 2004-06-22 Advanced Micro Devices, Inc. Programmable stabilization interval for internal stop grant state during which core logic is supplied with clocks and power to minimize stabilization delay
US6831959B1 (en) * 2000-08-09 2004-12-14 Cisco Technology, Inc. Method and system for switching between multiple clock signals in digital circuit
US6664775B1 (en) * 2000-08-21 2003-12-16 Intel Corporation Apparatus having adjustable operational modes and method therefore

Cited By (21)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US20040139356A1 (en) * 2003-01-10 2004-07-15 Kenneth Ma Method and apparatus for improving bus master performance
US6971033B2 (en) * 2003-01-10 2005-11-29 Broadcom Corporation Method and apparatus for improving bus master performance
US7523324B2 (en) 2003-01-10 2009-04-21 Broadcom Corporation Method and apparatus for improving bus master performance
US9305562B2 (en) 2003-02-14 2016-04-05 Intel Corporation Non main CPU/OS based operational environment
US8166325B2 (en) * 2003-02-14 2012-04-24 Intel Corporation Non main CPU/OS based operational environment
US10078363B2 (en) 2003-02-14 2018-09-18 Intel Corporation Non main CPU/OS based operational environment
US9015511B2 (en) 2003-02-14 2015-04-21 Intel Corporation Non main CPU/OS based operational environment
US20090019185A1 (en) * 2003-02-14 2009-01-15 Kardach James P Non Main CPU/OS Based Operational Environment
US20040255176A1 (en) * 2003-06-10 2004-12-16 Varghese George Method and apparatus for improved reliability and reduced power in a processor by automatic voltage control during processor idle states
US7299370B2 (en) 2003-06-10 2007-11-20 Intel Corporation Method and apparatus for improved reliability and reduced power in a processor by automatic voltage control during processor idle states
US7293185B2 (en) * 2003-07-22 2007-11-06 Oki Electric Industry Co., Ltd. Clock control circuit and clock control method that switchingly supplies a high-speed clock and a low-speed clock
US20050022044A1 (en) * 2003-07-22 2005-01-27 Yoshinori Shimosakoda Clock control circuit and clock control method
US7281149B2 (en) * 2004-02-24 2007-10-09 Hewlett-Packard Development Company, L.P. Systems and methods for transitioning a CPU from idle to active
US20050188235A1 (en) * 2004-02-24 2005-08-25 Atkinson Lee W. System and method for performing CPU soft-start
US7667500B1 (en) * 2006-11-14 2010-02-23 Xilinx, Inc. Glitch-suppressor circuits and methods
US7839181B1 (en) 2006-11-14 2010-11-23 Xilinx, Inc. Glitch-suppressor circuits and methods
US8892935B2 (en) 2011-04-22 2014-11-18 Wistron Corporation Dynamic bus clock rate adjusting method and device
US20130086395A1 (en) * 2011-09-30 2013-04-04 Qualcomm Incorporated Multi-Core Microprocessor Reliability Optimization
US8996902B2 (en) 2012-10-23 2015-03-31 Qualcomm Incorporated Modal workload scheduling in a heterogeneous multi-processor system on a chip
US20150113304A1 (en) * 2013-10-22 2015-04-23 Wisconsin Alumni Research Foundation Energy-efficient multicore processor architecture for parallel processing
US9519330B2 (en) * 2013-10-22 2016-12-13 Wisconsin Alumni Research Foundation Energy-efficient multicore processor architecture for parallel processing

Also Published As

Publication number Publication date
US7210054B2 (en) 2007-04-24
AU2003241462A1 (en) 2004-01-06
WO2004001564A3 (en) 2004-02-19
TW200405960A (en) 2004-04-16
TWI300891B (en) 2008-09-11
WO2004001564A2 (en) 2003-12-31

Similar Documents

Publication Publication Date Title
US7210054B2 (en) Maintaining processor execution during frequency transitioning
US7917787B2 (en) Method, apparatus and system to dynamically choose an aoptimum power state
KR100518376B1 (en) Method and apparatus to enhance processor power management
US6016071A (en) Internal source clock generation circuit for use with power management scheme
US7739533B2 (en) Systems and methods for operational power management
JP3734888B2 (en) Microprocessor with power management function
US7454632B2 (en) Reducing computing system power through idle synchronization
KR100388950B1 (en) Method and appratus for deskewing clock signals
US6118306A (en) Changing clock frequency
US7975161B2 (en) Reducing CPU and bus power when running in power-save modes
JP2009064456A (en) Dynamic voltage control method and apparatus
JPH08278827A (en) Clock controller
JPH08263466A (en) Integrated processor,integrated computer system and computersystem
US6496888B1 (en) Incorporation of bus ratio strap options in chipset logic
EP1340136B1 (en) Hardware architecture for a multi-mode power management system using a constant time reference for operating system support
US6668330B1 (en) Constant time reference for OS support in different frequency modes
US5594895A (en) Method and apparatus for switching between clock generators only when activity on a bus can be stopped

Legal Events

Date Code Title Description
AS Assignment

Owner name: INTEL CORPORATION, CALIFORNIA

Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:JAHAGIRDAR, SANJEEV;DERHALLI, ISLAM;GEORGE, VARGHESE;AND OTHERS;REEL/FRAME:013057/0641;SIGNING DATES FROM 20020502 TO 20020609

STCF Information on status: patent grant

Free format text: PATENTED CASE

FPAY Fee payment

Year of fee payment: 4

FPAY Fee payment

Year of fee payment: 8

FEPP Fee payment procedure

Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

LAPS Lapse for failure to pay maintenance fees

Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY

STCH Information on status: patent discontinuation

Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362

FP Lapsed due to failure to pay maintenance fee

Effective date: 20190424