The present disclosure relates generally to integrated circuits, and more particularly to internal power supply architectures for integrated circuits such as microcontrollers (MCUs).
Microcontrollers (MCUs) are integrated circuits that combine the main components of a computer system, i.e. a central processing unit (CPU), memory, and input/output (I/O) peripheral circuits, on a single integrated circuit chip. Modern MCUs are useful in a wide variety of consumer products such as mobile phones, household appliances, automotive components, and the like because of their low-cost. Typical MCUs combine different types of circuits that have different power supply requirements on a single chip. For example, digital circuits implemented using complementary metal-oxide-semiconductor (CMOS) transistors require only a low-voltage power supply for proper operation. Other circuits, such as analog circuits and circuits that interface to external circuitry, require higher power supply voltages for operation. Moreover, these MCUs frequently operate on a battery voltage, and the MCUs generate internal voltages to power the different types of circuits. At the same time, it is necessary to conserve power and MCUs provide a variety of low-power modes to assist in power conservation. There is a tension between supporting different types of internal circuits and maintaining low-power operation because the power supply conversion circuits themselves consume a significant amount of the chip's power.
The use of the same reference symbols in different drawings indicates similar or identical items. Unless otherwise noted, the word “coupled” and its associated verb forms include both direct connection and indirect electrical connection by means known in the art, and unless otherwise noted any description of direct connection implies alternate embodiments using suitable forms of indirect electrical connection as well.
In one form, an integrated circuit includes a first plurality of circuits receiving a first internal power supply voltage, a first regulator, a second regulator, and a controller. The first regulator receives an external power supply voltage and supplies the first internal power supply voltage at a first rated power in response to the external power supply voltage when the integrated circuit is in an active mode. The second regulator receives the external power supply voltage and supplies the first internal power supply voltage at a second rated power less than the first rated power in response to the external power supply voltage when the integrated circuit is in a low power mode. The controller controls a transition of the integrated circuit between the active mode and the low power mode. The controller activates all of the first plurality of circuits in the active mode, and activates a subset of the first plurality of circuits while keeping remaining ones of the first plurality of circuits inactive in the low power mode.
In another form, a microcontroller includes a central processing unit (CPU) core coupled to a low-voltage power bus, a memory coupled to the low-voltage power bus and to the CPU core, a plurality of peripheral circuits coupled to a high-voltage power bus and to the CPU core; and a power saving energy management circuit. The power saving energy management circuit receives an external power supply voltage and provides a digital power supply voltage to the low-voltage power bus and a high-power supply voltage to the high-voltage power bus. The energy management circuit includes a first regulator, a second regulator, and a controller. The first regulator receives the external power supply voltage and supplies the digital power supply voltage to the low-voltage power bus at a first rated power in response to the external power supply voltage when the microcontroller is in an active mode. The second regulator receives the external power supply voltage and supplies the digital power supply voltage at a second rated power less than the first rated power in response to the external power supply voltage when the microcontroller is in a low power mode. The controller controls a transition of the microcontroller between the active mode and the low power mode. The controller activates the CPU core and the memory in the active mode, and places the CPU core and the memory into a low-power state in the low power mode.
In yet another form, a method of operating an integrated circuit, includes, in an active mode, generating a first internal power supply voltage having a first nominal voltage on a first power supply voltage rail using a first voltage regulator, and activating each of a first plurality of circuits coupled to the first power supply voltage rail. In a low power mode, the method includes generating the first internal power supply voltage having the first nominal voltage on the first power supply voltage rail using a second voltage regulator, wherein the second voltage regulator has a lower rated power than the first voltage regulator, and activating a subset of the first plurality of circuits while keeping remaining ones of the first plurality of circuits inactive.
Integrated circuit terminals 110 include a terminal 111 for receiving an external regulated voltage labeled “VREGIN”, a terminal 112 for receiving a power supply voltage labelled “VDD”, a terminal 113 for receiving a ground voltage labelled “GND” to which VREGIN and VDD are referenced, a terminal 114 for conducting a positive USB data signal labeled “D+”, a terminal 115 for conducting a negative USB data signal labeled “D−”, a terminal 116 for receiving an input/output supply labeled “VIO”, and a set of terminals 117 functioning as digital and/or analog I/O port pins.
LDO voltage regulator 120 has an input connected to terminal 111, an output for providing a 3.3-volt internal power supply voltage, and a reference terminal connected to ground. VREGIN is an externally regulated power supply voltage having a nominal value of 5 volts. LDO voltage regulator 120 is adapted to convert VREGIN into an internal, regulated voltage having a value in this example of 3.3 volts.
LDO voltage regulator 130 has an input connected to terminal 112 and to the output of LDO voltage regulator 120, an output for providing a 1.8-volt internal power supply voltage, and a reference terminal connected to terminal 113, which provides the ground for MCU 100. In one mode, LDO voltage regulator is active and outputs the 3.3-volt internal power supply that LDO voltage regulator 130 uses to generate the 1.8-volt internal supply. In an alternate mode, LDO voltage regulator 120 is disabled and an external voltage regulator provides 3.3 volts to terminal 112.
Digital circuit blocks 140 includes an exemplary set of digital circuits useful in an MCU including a central processing unit core 141, a random access memory 142, a flash memory 143, an oscillators block 144, and a peripheral logic block 145. MCU 100 is implemented using low-power complementary metal-oxide-semiconductor (CMOS) transistors, and digital circuit blocks 140 operate on the relatively low power supply voltage of 1.8 volts.
USB PHY 150 has bidirectional terminals connected to terminals 114 and 115 is powered from the internal 3.3-volt power supply. Input/output circuits 160 include a set of digital I/O circuits 161 and a set of analog multiplexers 162. Each of these circuit groups is connected to corresponding ones of terminals 117 and both of them are powered by the 3.3 internal power supply voltage in one more, and terminal 116 in the other mode.
MCU 100 uses LDO voltage regulator 120 and LDO regulator 130 to provide the internal 3.3-volt and 1.8-volt power supply voltages, respectively. In general, LDOs are simple to implement using, e.g., a single high-power series transistor with a simple feedback loop using a comparator and a voltage reference to control the conductivity of the pass transistor to regulate the output to the desired voltage. While simple in construction, however, LDO regulators are relatively inefficient at lighter loads.
In order to generate stable internal power supplies, conventional MCUs require large load capacitors for each on-chip power supply. However, these large load capacitors cause problems. First, they cause the MCU to have high current consumption, because a voltage regulator having large load capacitor must generate a large bias current to make itself stable. Second, if they are integrated on-chip, they increase the circuit area and chip cost. If the MCU cannot support a large current, then the regulator must increase the capacitance of the load capacitor further so that it becomes the dominant pole for stability, requiring a still larger capacitor and resulting in a further increase of the die area and the cost of the chip. Third, if it is not possible to integrate load capacitors with adequate sizes on-chip, then the chip would require large external capacitors and integrated circuit terminals to connect to the off-chip capacitors, which increases chip die area and cost. Thus, the use of large load capacitors makes it difficult to provide a low-cost, low-power MCU.
CPU system 210 includes a CPU bus 212 interconnecting a CPU core 211, a bus bridge 213, a FLASH memory 214, a random-access memory (RAM) 215, a debug circuit 216, and a direct memory access controller (DMAC) 217. CPU system 210 includes a CPU bus 212 separate from peripheral bus 240 to isolate transactions initiated by CPU core 211 to local devices and memory without affecting traffic on peripheral bus 240. Bus bridge 213 is a circuit that allows cross-bus transfers between CPU bus 212 and peripheral bus 240. CPU system 210 provides FLASH memory 214 for non-volatile storage of program code that can be bootstrap loaded from an external source, as well as parameters that need to be preserved when MCU 200 is powered down. RAM 215 provides a working memory for use by CPU core 211. Debug circuit 216 provides program trace capabilities with access to registers on CPU core 211 for software debug. DMAC 217 provides programmable direct memory access channels to offload CPU core 211 from routine data movement tasks between peripherals and memory.
MCU 200 includes a set of peripherals that make it suitable for a variety of general-purpose embedded applications. Peripheral bus 240 interconnects bus bridge 213, clock unit 220, power-saving energy management circuit 230, serial interfaces and I/O ports 250, timers and counters 260, and analog interfaces 270. The serial interfaces in serial interfaces and I/O ports 250 operate according to a variety of synchronous and asynchronous character-oriented and serial protocols. The I/O ports in serial interfaces and I/O ports 250 are a set of general-purpose input/output circuits with terminals that can be programmed for specific functions or remain available to software for general purpose operation. Timers and counters 260 provide various programmable timing and event counting functions useful for embedded control, and include a watchdog timer and a real time clock. Analog interfaces 270 include various analog interface circuits such as an analog comparator and an analog-to-digital converter (ADC) for accurate analog input signal measurement.
Generally, MCU 200 integrates CPU system 210 and several peripherals for a wide variety of application environments and is suitable for very low power operation. MCU 200 includes a clock unit 220 that provides a variety of clocks and clock functions that MCU 200 uses to support its low power modes. For example, clock unit 220 can include high frequency oscillators, as well as lower precision fully integrated resistor-capacitor (RC) oscillators and very low speed RC oscillators that allow standby and keep-alive operations.
MCU 200 also includes power-saving energy management circuit 230 that implements a power architecture that provides several programmable functions to support extremely low-power operation in low-power modes. Power-saving energy management circuit 230 is bidirectionally connected to peripheral bus 240 and has an input for receiving an external power supply voltage labeled “VDDX”, outputs for providing a relatively high-power supply voltage labeled “VDDH”, a relatively high-power supply voltage for FLASH memory 214 labeled “VDDH_FLASH”, and a relatively low digital power supply voltage labeled “VDDD”. In this exemplary embodiment, these voltages have the nominal values shown in TABLE I:
VDDX is an input voltage for all on-chip voltage regulators, as well as I/O signals. VDDH is a voltage used to power analog circuits and circuits that implement external I/O functions. VDDH_FLASH is a voltage provided to FLASH memory 214 to allow it to generate further voltages to program and erase floating-gate memory cells. VDDD is a relatively low voltage provided to digital CMOS circuits such as CPU core 211.
Power-saving energy management circuit 230 also provides other functions besides voltage generation. For example, it also includes a brown-out detector designed to force MCU 200 into reset when power consumption is too high, as well as a low-power power on reset circuit. It implements a state machine to control entry into and exit from various low-power modes. In particular, power-saving energy management circuit 230 provides an internal architecture with multiple voltage regulators for the supported power supply voltages but that operate efficiently in different load ranges created by the different power-saving modes. Further details of the power-saving architecture will now be described.
MCU 200 enters idle mode 320 when a control signal labeled “IDLE” is activated, e.g. by software setting a corresponding IDLE bit in a memory-mapped power control register. In other embodiments, the IDLE signal can be set in different ways, such as from an activity detector failing to detect any activity for a certain period of time, in response to an external control signal, and the like. In idle mode 320, the clocks are removed from the CPU and from certain peripherals, but power continues to be applied to all circuits. Because MCU 200 is implemented with CMOS circuits, they do not lose their state when clock signals are removed. All power supplies remain fully powered, allowing a relatively fast wakeup time, but MCU 200 still consumes leakage power, power consumed by selected peripherals remain active to report wakeup events, and power consumed by the voltage regulators. MCU 200 can return to active mode 310 in response to the activation of either an enabled interrupt or an activation of a reset terminal (i.e. a warm reset), if the ALL_OK signal is true.
MCU 200 enters snooze mode 330 when a control signal labeled “SNOOZE” is activated, e.g. by software setting a corresponding SNOOZE bit in the memory-mapped power control register. In other embodiments, the SNOOZE signal can be set in different ways, such as from an activity detector failing to detect any activity for a certain period of time, in response to an external control signal, and the like. In snooze mode 330, the clocks are removed from the CPU, from certain peripherals, and from high-power voltage regulators, but as will be explained below, low-power voltage regulators continue to apply power to all voltage domains so the components do not lose their state. MCU 200 can return to active mode 310 in response to a wakeup event (an enabled interrupt, a signal from a watchdog timer, etc.), activation of the reset terminal (i.e. a warm reset), or a hard reset (cycling the external power pins), if the ALL_OK signal is true.
MCU 200 enters shutdown mode 340 when a control signal labeled “SHUTDOWN” is activated, e.g. by software setting a corresponding SHUTDOWN bit in the memory-mapped power control register. In other embodiments, the SHUTDOWN signal can be set in different ways, such as from an activity detector failing to detect any activity for a certain period of time, in response to an external control signal, and the like. In shutdown mode 340, external I/O pins, powered by external power supply voltage VDDX, retain their states, but the clocks and internal power are removed from all circuits, including all voltage regulators. MCU 200 can return to active mode 310 only in response to a reset, indicated by either an activation of the reset terminal (i.e. a warm reset) or a hard reset (cycling the external power pins), if the ALL_OK signal is true.
TABLE II summarizes the various power modes supported by MCU 200:
While certain low power modes and their corresponding behavior was described, in other embodiments, MCU 200 may support additional low power modes besides those shown in
Voltage regulators 410 are part of power-saving energy management circuit 230 and include a low-power bias circuits 411, a high-power bias circuit 412, regulators 413 and 414, a capacitor 415, regulators 416 and 417, a capacitor 418, a power monitor 420, and capacitors 421, 422, and 423. Low-power bias circuit 411 is a low-power bias circuit having a power supply terminal for receiving VDDX, and an output for providing a bias signal labeled “VBG_LP”. High-power bias circuit 412 is a high-power bias circuit having a power supply terminal, and an output for providing a bias signal labeled “VBG_HP”. Regulator 413 is a high-voltage, high-power regulator having a power supply terminal for receiving VDDX, a reference input for receiving VBG_HP, a first output for providing VDDH through a replica path, a second output for providing VDDH_FLASH through a replica path, and a third output connected to input of high-power bias circuit 412 for providing a voltage labeled “VDDH_LP”. Regulator 414 is a high-voltage, low-power regulator having a power supply terminal for receiving VDDX, a reference input for receiving VBG_LP, a first output connected to the second output of regulator 413, and a second output connected to the power supply input of high-power bias circuit 412. Capacitor 415 has a first terminal connected to the second output of regulator 414, and a second terminal connected to ground. Regulator 416 is a low-voltage, high-power regulator having a power supply terminal for receiving VDDX, a reference input for receiving VBG_HP, and an output for providing VDDD. Regulator 417 is a low-voltage, low-power regulator having a power supply terminal for receiving VDDX, a reference input for receiving VBG_LP, a first output connected to the output of regulator 416, and a second output. Capacitor 418 has a first terminal connected to the second output of regulator 417, and a second terminal connected to ground. Power monitor 420 has a power supply input for receiving VDDX, a first input for receiving VDDH_LP, a second input for receiving VBG_LP, a third input for receiving VBG_HP, a fourth input for receiving VDDD_LP, a fifth input for receiving VDDH_LP, a sixth input for receiving VDDD, a seventh input for receiving VDDH, and an output for providing a control signal labelled “ALL_OK”. Capacitor 421 has a first terminal for receiving VDDH_FLASH, and a second terminal connected to ground. Capacitor 422 has a first terminal for receiving VDDH, and a second terminal connected to ground. Capacitor 423 has a first terminal for receiving VDDD, and a second terminal connected to ground.
High-voltage peripherals 430 include a digital-to-analog converter 431, a set of I/O buffers 432, a successive approximation register (SAR) 433, and an analog comparator 434 all connected to high-voltage (e.g. 5 volt) I/O, a watchdog timer 435, a high frequency oscillator 436, a low frequency oscillator 437, and a fast startup (FS) oscillator 438 that communicate to internal digital peripherals on a 1.2-volt supply voltage. Each of high-voltage peripherals 430 has a power supply terminal for receiving VDDH, and a ground terminal connected to ground.
Digital circuits 440 includes an SRAM 441 and a digital block 442. Digital block 442 represents the digital circuits other than SRAM 441, such as CPU core 211, bus bridge 213, debug circuit 216, DMAC 217 of MCU 200 of
FLASH memory 450 has a first power supply voltage terminal for receiving VDDH_FLASH, a second power supply voltage terminal for receiving VDDD, and a ground terminal connected to ground. FLASH memory 450 performs read, write, and erase cycles internally using VHHD_FLASH (or a voltage derived from VDDH_FLASH, but communicates with CPU core 211 over CPU bus 212 with signals referenced to VDDD, and thus uses both power supply voltages.
Control register 460 has three bits (or bit fields) to indicate a request to enter a low-power mode, including a SNOOZE bit 461, an IDLE bit 462, and a SHUTDOWN bit 463.
Power management controller 470 has a first input for receiving a signal labeled “RESET”, a second input for receiving a wakeup event signal labeled “WAKEUP_EVENT”, a third input for receiving the ALL_OK signal, inputs connected to the outputs of control register 460, and outputs for providing signals indicating, directly or indirectly, that integrated circuit 400 if in the active mode, the snooze mode, the idle mode, and the shutdown mode, and an output labeled “POR” (power-on reset).
In operation, power management controller 470 determines the operating mode of MCU 400, in which the operating mode can be requested by software setting the bit or bit field corresponding to the desired mode in control register 460. Power management controller 470 then enters the appropriate mode when all pre-conditions have been met, such as power monitor 420 indicating that all power supply voltages have been enabled through the ALL_OK signal. Power management controller 470 also observes the POR, RESET, and WAKEUP_EVENT signals to determine when to make power state transitions. The supported power modes were previously shown in TABLE II above.
MCU 400 has a power architecture that simultaneously achieves low cost and low power consumption. In order to achieve both goals at the same time, MCU 400 does not use the known, large capacitor approach described above, but approaches the two goals separately.
MCU 400 achieves low cost by partitioning its constituent circuits according to function, noise, voltage, and current requirements. FLASH memory 450 generates a high level of noise and uses high voltage and current. Thus, FLASH memory 450 receives a stronger supply, i.e. a supply with higher rated power, and uses a relatively large on-chip capacitor, namely capacitor 421 with a value of 150 picoFarads (pF). Analog circuitry including DAC 431, SAR 433, and analog comparator 434 generate less noise and use a relatively small current, but require a power supply that produces a stable, low-noise voltage. Thus, the analog circuitry receives a lower supply voltage VDDH with a smaller rated power consumption and a smaller on-chip capacitor, namely capacitor 422 with a value of 75 pF. High-power bias circuit 412 and power monitor 420 generate very little noise and use a very low current, but require a power supply that produces a stable, low-noise voltage to provide stable reference voltages and accurate ALL_OK signals. Thus, high-power bias circuit 412 and power monitor 420 receive a lower power supply voltage VDDH_LP and a very small on-chip capacitor 415, namely capacitor 415 with a value of 10 pF. SRAM 441 and digital block 442 generate a high amount of noise and use large amounts of current but since they are digital CMOS circuits, they can operate with relatively low voltages. Thus, SRAM 441 and digital block 442 receive the lowest power supply voltage VDDD but use the largest capacitor, namely on-chip capacitor 423 with a value of 700 pF.
Partitioning MCU 400 into these functional groups allows the total on-chip capacitance value to be reduced for a given die area and current/power consumption by using large capacitors only used for voltage domains with the greatest need. In addition, partitioning MCU 400 into these functional groups isolates noise generated in one partition (or voltage domain) from the other partitions.
MCU 400 achieves low power by providing one set of high-power regulators and bias reference circuits, and another set (or “replica” set) of low-power regulators and bias reference circuits. The high-power regulators include regulators 413 and 416, and the high-power reference circuit is high-power bias circuit 412. These circuits provide fast-settling, highly-accurate internal supply and reference voltages. Regulators 413 and 416 support relatively large current loadings, for example up to 12 milliamps (mA) for VDDH_FLASH, 6 mA for VDDH, and 10 mA for VDDD. The low-power regulators include regulators 414 and 417, and the low-power bias circuit includes low-power bias circuit 411. Regulators 414 and 417 support internal power supplies that have a moderate level of accuracy and settling time, but consume far lower amounts of bias current compared to their higher rated power counterparts. Regulators 414 and 417 support smaller current loadings of up to 20 μA for VDDH_FLASH, 100 μA for VDDH, and 1 mA for VDDD, but only require a bias current of approximately 6.5 μA.
Different combinations of high-power and low-power regulators and bias reference circuits can be used to support different power modes. Each power supply voltage rail uses both a main branch and a replica branch to alternate between regulators that have higher rated powers and those that have lower rated powers.
Consistent with the selected power state, voltage regulators 410 provide various power supply voltages to internal circuits of MCU 400 using alternate voltage regulators as specifically outlined in TABLE IV:
In addition, the states of the voltage regulators of MCU 400 when it is in various power modes are shown in TABLE V below:
In one specific example, the total bias current for all the voltage regulators is 600 microamps (μA) in active mode, 200 μA in idle mode, 6.5 μA in snooze mode, and 0.3 μA in shutdown mode. When MCU 400 transitions from active mode to idle mode, power management controller 470 turns off regulator 413, and power consumption reduces to 200 μA. When MCU 400 transitions from active mode to snooze mode, power management controller 470 turns off high-power bias circuit 412, high-power regulator 413, and high-power regulator 416, and power consumption reduces to 6.5 μA. When MCU 400 transitions from active mode to shutdown mode, power management controller 470 turns off all regulators and bias circuits, and power consumption reduces to 0.3 μA.
Digital circuits 440 operate in the VDDD domain and receive VDDD as their power supply voltage. Portions of SRAM 441 and digital block 442 remain powered during snooze mode, while power is gated off to other portions. For example, regulator 417 continues to provide power supply voltage VDDD to the memory core so that it retains its state while MCU 400 is in the snooze mode, but SRAM 441 power gates the access circuitry. Thus SRAM 441 only consumes leakage power in its core, but no power in the power-gated circuits. Likewise, portions of digital circuits 440 are power gated, while other portions are powered by the low-voltage supply.
FLASH memory 450 stops receiving VDDH_FLASH from voltage regulator 413 when in idle mode 320, snooze mode 330, and shutdown mode 340, but continues to receive VDDH_FLASH from voltage regulator 414 using the replica path in the idle and snooze modes so it. However, in these modes, MCU 400 does not allow read, write, and erase accesses to FLASH memory 450 since any circuits that may access them, including CPU core 211, are disabled. Since it is non-volatile, FLASH memory 450 retains its contents when powered down. FLASH memory 450 continues to receive VDDD using regulator 417 in the idle and snooze modes.
By using separate voltage regulators that are tailored for lower rated power in idle and/or snooze modes, MCU 400 saves significant amounts of bias current that would be required by the higher power rated voltage regulators used in active mode. Thus MCU 400 provides low power consumption in low power modes, saving battery life, while preserving compact integrated circuit size and hence preserving low cost. Also, by separating voltage regulators based on the types of circuits powered by them, MCU eliminates the need for an external capacitor that is large enough for most or all of the internal circuitry, and thus saves the cost of an external capacitor and extra MCU terminal. The design of the regulators can also be changed according to their need. For example in one embodiment, regulator 413 can be implemented as an LDO regulator to provide better efficiency at large loads, while regulator 414 can be implemented as a regulated charge pump, which provides better efficiency at lighter loads.
Power monitor 420 determines whether all power supply circuits are operational such that MCU 400 can enter active mode 310. Power monitor 420 has inputs for receiving both the low-power bias voltage VBG_LP and the high-power bias voltage VBG_HP, as well as each of the supply voltages VDDX, VDDH_LP, VDDD_LP, VDDH, and VDDD.
Power management controller 470 causes the various regulators to power up in an orderly fashion as follows. Low-power bias circuit 411 receives external power supply voltage VDDX, and provides bias voltage VBG_LP as soon as VDDX rises to a sufficient voltage. VBG_LP is a reference voltage that is equal to or is based on a bandgap voltage. The bandgap of silicon is 1.2 volts, so if VBG_LP is equal to the bandgap voltage, VDDX must rise to a sufficient voltage above 1.2 volts so that the bandgap voltage generation circuit is operational. Once VBG_LP is at its proper level, regulators 414 and 417 can provide their respective output voltages at proper levels. The second output of high-voltage, low-power regulator generates VDDH_LP, which is provided on a separate signal line to high-power bias circuit 412. Once regulator 414 becomes operational and provides VDDH_LP at its proper level, high-power bias circuit 412 can become operational. Moreover, once high-power bias circuit 412 becomes operational, it biases regulators 413 and 416 and they begin ramping their respective output voltages by charging up capacitors 422 and 423, respectively. Once these voltages reach their nominal levels, then power monitor 420 activates signal ALL_OK, and power management controller 470 transitions MCU 400 into the Active mode, and asserts the ACTIVE signal.
The sequence of powering up MCU 400 can be summarized as follows. Power supply voltage VDDX starts in an off state at 0 volts and ramps up until time to when it reaches a voltage of 0.6 volts. Before time t1, all circuits in regulators 410 are disabled.
At time t1, VDDX reaches 0.6 volts. The value of 0.6 volts corresponds to a threshold voltage of a 3-volt N-channel MOS transistor. At time t1, low power bias circuit 411 is turned on, and after a delay, power monitor 420 starts monitoring power supply voltages, and regulators 414 and 417 are also turned on without activating the replica branches. When the output of low-power bias circuit 411 exceeds a threshold voltage of a 3-volt P-channel MOS transistor plus a drain-to-source voltage of a 3-volt N-channel MOS transistor, power monitor 420 enables a charge pump function of regulators 414 and 417 to allow them to generate voltages greater than VDDX using their replica branches. When power monitor 420 detects that VDDH_LP>1.5 volts and VDDD_LP>0.9V, then power monitor 420 enables high-power bias circuit 412. When power monitor 420 detects that the output of high-power bias circuit 412 is greater than 1 volt, it turns on voltage regulator 413 and low-voltage, high power regulator 416. Finally, when power monitor 420 detects VDDH>1.57 volts and VDDD>1 volt, then power monitor 420 starts to detect the VDDX level.
At time t2, power monitor 420 detects that VDDX has reached 1.8 volts. power monitor 420 activates ALL_OK, and power management controller 470 places MCU 400 into the active mode, in which all circuitry is operational. Power monitor 420 programs the voltage regulators to more accurate, calibrated settings stored by MCU 400, allowing voltage regulators 410 to provide highly accurate internal voltages. It then reduces the VDDX threshold to 1.71 volts, which is the level at which the chips will enter shutdown mode, and providing an increased VDDX operating range. Power monitor 420 allows read operations to FLASH memory 214 until it detects that VDDH_FLASH≥2.4V, at which time it enables FLASH memory 214 for write and erase operations as well as read operations.
MCU 400 changes from active mode 310 to snooze mode 330 as follows. When SNOOZE=1, a snooze controller inside power management controller 470 activates low-power regulators 414 and 417 and replica paths for VDDH, VDDH_FLASH, and VDDD, and during this time both high-power regulators 413 and 416 and low-power regulators 414 and 417 are active. The snooze controller controls regulator 417 to reduce VDDD to 1.1 volts to remove any transient glitch when regulator 416 is disabled. After a certain period of time, the snooze controller disables high-power regulator 413 and high-power regulator 416 and high-power bias circuit 412. The current consumption of voltage regulators 410 is reduced from 600 μA to about 6.5 μA, with less accurate output voltages, and MCU 400 is then in snooze mode.
MCU 400 changes from snooze mode 330 back to active mode 310 as follows. When ACTIVE=1, regulators 413 and 414 are reactivated. Power management controller 470 controls regulator 417 to increase VDDD to 1.2 volts, and activates high-power bias circuit 412, and regulators 413 and 415. After another certain period of time, both regulators 414 and 417 and the replica paths are disabled. The current consumption of voltage regulators 410 is increased from 6.5 μA to about 600 μA, and the outputs of regulators 413 and 416 are again highly accurate. MCU 400 is then in active mode.
According to one aspect of the disclosed embodiments, MCU 400 includes a set of circuits that define a voltage domain, e.g. high-voltage peripherals 430 in the VDDH voltage domain that receive VDDH as their power supply voltage. To generate VDDH, power-saving energy management circuit 230 uses either voltage regulator 413 or voltage regulator 414. For example, when MCU 400 is in the active mode, power management controller 470 uses the VDDH generated by high-power, high voltage regulator 413, since it is efficient at high power levels and has a higher rated power than regulator 414. However, when MCU 400 is in the snooze mode, certain ones of high-voltage peripherals 430 are disabled, and power-saving energy management circuit 230 uses high-voltage, low-power regulator 414 to generate VDDH. In the Snooze mode, power management controller 470 disables regulator 413. Regulator 414 has a lower rated power than regulator 413, and while it is unable to generate VDDH at a stable voltage at high power levels, it is more efficient than regulator 413 in generating power supply voltage VDDH at relatively low power levels.
Likewise, to generate VDDD, power-saving energy management circuit 230 uses either voltage regulator 416 or voltage regulator 417. For example, when MCU 400 is in the active mode, power management controller 470 uses the VDDD generated by high-power, low-voltage regulator 416, since it is efficient at high power levels and has a higher rated power than regulator 417. However, when MCU 400 is in the snooze mode, certain ones of digital circuits 440 are disabled, and power-saving energy management circuit 230 uses low-voltage, low-power regulator 417 to generate VDDD. In the Snooze mode, power management controller 470 disables regulator 416. Regulator 417 has a lower rated power than regulator 416, and while it is unable to generate VDDD at a stable voltage at high power levels, it is more efficient than regulator 416 in generating power supply voltage VDDD at relatively low power levels.
The above-disclosed subject matter is to be considered illustrative, and not restrictive, and the appended claims are intended to cover all such modifications, enhancements, and other embodiments that fall within the true scope of the claims. For example, various low-power modes have been described, but in other embodiments the MCU may support other low-power modes that keep a different set of internal circuits active while powering down other circuits. The conditions in which the various modes are entered and exited may also change in difference embodiments. Also while the current consumption was described with respect to a particular example, the values are only approximate, and different integrated circuits and MCUs will have difference current levels.
Thus, to the maximum extent allowed by law, the scope of the present invention is to be determined by the broadest permissible interpretation of the following claims and their equivalents, and shall not be restricted or limited by the foregoing detailed description.