

# CPE 323: Power, MSP430 Low Power Modes

Aleksandar Milenkovic

Electrical and Computer Engineering The University of Alabama in Huntsville

milenka@ece.uah.edu

http://www.ece.uah.edu/~milenka





# Outline

- Introduction
- Background: Power in CMOS Integrated Circuits
- Power in Embedded Systems
- MSP430 Operating Modes (Active, LPMs)
- Demos





#### Power In CMOS > Power: System View >

MSP430 Operating Modes

Demos



# **Power as a Design Constraint**

- Power: work done per unit time (VQ/t = VI)
- Why worry about power?
  - Battery life in portable and mobile platforms
  - Power consumption in desktops, server farms
    - Cooling costs, packaging costs, reliability, timing
    - Power density: 30 W/cm2 in Alpha 21364 (3x of typical hot plate)
  - Environment?
    - IT consumes 10% of energy in the US

### **Power becomes a first class architectural design constraint**



Power: System View

• MSP430 Operating Modes Demos



**Background: Where does power go in CMOS?** 





CPE 323 Introduction to Embedded Systems



# **Dynamic Power Consumption**

C – Total capacitance seen by the gate's outputs Function of wire lengths, transistor sizes, ...

V – Supply voltage Trend: has been dropping with each successive fab

Demos

A - Activity of gates How often on average do wires switch?

f – clock frequency Trend: increasing ...

### **Reducing Dynamic Power**

- 1) Reducing V has quadratic effect; Limits?
- 2) Lower C shrink structures, shorten wires
- 3) Reduce switching activity Turn off unused parts or use design techniques to minimize number of transitions





# **Short-circuit Power Consumption**

MSP430 Operating Modes



Power: System View

Finite slope of the input signal causes a direct current path
between V<sub>DD</sub> and GND for a short
period of time during switching
when both the NMOS and PMOS
transistors are conducting

Demos

#### **Reducing Short-circuit**

Introduction

Power In CMOS

- 1) Lower the supply voltage V
- 2) Slope engineering match the rise/fall time of the input and output signals













# How Can We Reduce Power Consumption?

MSP430 Operating Modes

Demo

Dynamic power consumption

Power: System View >

- Fan-out: charge/discharge of the capacitive load on each gate's output
- Frequency

Power In CMOS

- Control activity
  - Reduce power supply voltage
  - Reduce working frequency
  - Turn off unused parts (module enables)
  - Use low power modes
  - Interrupt driven system
- Minimize the number of transitions

Instruction formats, coding?

CPE 323 Introduction to Embedded Systems





Power: System View > MSP430 Operating Modes

Demos



# **Average Power Consumption**

- Dynamic power supply current
  - Set of modules that are periodically active
  - Typical situation real time cycle T
  - lave =  $\int lcc(t)dt /T$
  - Most cases lave =  $\Sigma \text{ li*ti/T}$





### Low-Power Concept: Basic Conditions for Burst Mode

The example of the heat cost allocator shows that the current of the non-activity periode dominates the current consumption.

|                    | <u>Measure</u>                |   | Process data       |   | Real-Time Clock   |       | LCD Display          |
|--------------------|-------------------------------|---|--------------------|---|-------------------|-------|----------------------|
| I <sub>AVG</sub> = | IMeasure                      | + | ICalculate         | + | IRTC              | +     | I <sub>Display</sub> |
| =                  | IADC <sup>* t</sup> Measure/T | + | lactive * tcalc /T | + | lactive * tRTC /T | +     | I <sub>Display</sub> |
| =                  | 3mA *200µs/60s                | + | 0.5mA * 10ms/60s   | + | 0.5mA * 0.5ms/60s | +     | 2.1µA                |
| =                  | 10nA                          | + | 83nA               | + | 4nA               | +     | 2.1µA                |
| I <sub>AVG</sub> ≅ |                               |   |                    |   |                   | 2.1µA |                      |

The sleep current dominates the current consumption!

The currents are related to the sensor and  $\mu$ C system. Additional current consumption of other system parts should be added for the total system current



CPE 323 Introduction to Embedded Systems



# **Battery Life**

- Battery Capacity BC [mAh]
- **Battery Life** 
  - BL = BC / lavg
- In the previous example, standard 800 mAh batteries will allow battery life of:
  - BL = 750 mAh / 2.1  $\mu$ A  $\approx$  44 years !!!
- Conclusion:
  - Power efficient modes
  - Interrupt driven system with processor in idle mode





# **Power and Related Metrics**

- Peak power
  - Possible damage
- Dynamic power
  - Non-ideal battery characteristics
  - Ground bounce, di/dt noise
- **Energy/operation ratio** 
  - MIPS/W
  - Energy x Delay



MSP430 Operating Modes

Demo

# **Operating Modes in MS430**

- Support low- and ultra-low energy consumption
  - Intelligent management of individual modules and clock subsystems
- An interrupt event wakes the system from each of the various operating modes and the RETI instruction returns operation to the mode that was selected before the interrupt event
- Balance requirements
  - The desire for speed and data throughput despite conflicting needs for ultra-low power
  - Minimization of individual current consumption
  - Limitation of the activity state to the minimum required by the use of low power modes





# Current (F, Mode, V)

MSP430 Operating Modes

Demos





CPE 323 Introduction to Embedded Systems

Power In CMOS



# Operating Modes in MSP430 (cont'd)

| SCG1 | SCG0 | OSCOFF   | CPUOFF | Mode   | CPU and Clocks Status                                                                                                                                                                            |
|------|------|----------|--------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | 0        | 0      | Active | CPU is active, all enabled clocks are active                                                                                                                                                     |
| 0    | 0    | 0        | 1      | LPM0   | CPU, MCLK are disabled (41x/42x peripheral MCLK<br>remains on)<br>SMCLK , ACLK are active                                                                                                        |
| 0    | 1    | 0        | 1      | LPM1   | CPU, MCLK, DCO oscillator are disabled (41x/42x<br>peripheral MCLK remains on)<br>DC generator is disabled if the DCO is not used for<br>MCLK or SMCLK in active mode<br>SMCLK , ACLK are active |
| 1    | 0    | 0        | 1      | LPM2   | CPU, MCLK, SMCLK, DCO oscillator are disabled<br>DC generator remains enabled<br>ACLK is active                                                                                                  |
| 1    | 1    | 0        | 1      | LPM3   | CPU, MCLK, SMCLK, DCO oscillator are disabled<br>DC generator disabled<br>ACLK is active                                                                                                         |
| 1    | 1    | 1        | 1      | LPM4   | CPU and all clocks disabled                                                                                                                                                                      |
| 15   |      |          |        | 98     | 7 0                                                                                                                                                                                              |
|      |      | Reserved |        | v      | SCG1 SCG0 OSC CPU<br>OFF OFF GIE N Z C                                                                                                                                                           |
|      |      |          |        |        |                                                                                                                                                                                                  |
|      |      |          |        | 1      | rw-0                                                                                                                                                                                             |





Introduction Power In CMOS Power: System View > MSP430 Operating Modes

Demo



# Low Power Mode Control

- CPUOff: CPU Off (bit 4 in SR)
  - When set, turns off the CPU
- OscOff: Oscillator Off (bit 5 in SR)
  - When set, turns off the LFXT1 crystal oscillator when LFXT1CLK is not used for MCLK and SMCLK
- SCG0: System Clock Generator 0 (bit 6 in SR)
  - When set, turns off the DCO DC generator if DCOCLK is not used for MCLK and SMCLK
- SCG1: System Clock Generator 1 (bit 7 in SR)
  - When set, turns off the SMCLK



Demo



# Low Power Mode Control (cont'd)

- Control bits are in SR
- => Present state of the operating condition is saved onto the stack during an interrupt service request
- As long as the stored status register information is not altered, the processor continues (after RETI) with the same operating mode as before the interrupt event





# Operating Modes in MSP430 with FLL+



LaCASA

Power In CMOS > Power: Syster

THE UNIVERSITY OF ALABAMA IN HUNTSVILLE

# **Operating Modes (AM, LPM0-LMP2)**

- Active mode AM; SCG1=0, SCG0=0, OscOff=0, CPUOff=0: CPU clocks are active
- Low power mode 0 (LPM0); SCG1=0, SCG0=0, OscOff=0, CPUOff=1:
  - CPU is disabled/ MCLK is disabled
  - SMCLK and ACLK remain active
- Low power mode 1 (LPM1); SCG1=0, SCG0=1, OscOff=0, CPUOff=1:
  - CPU is disabled/MCLK is disabled
  - DCO's dc generator is disabled if the DCO is not used for MCLK or SMCLK when in active mode. Otherwise, it remains enabled.
  - SMCLK and ACLK remain active
- Low power mode 2 (LPM2); SCG1=1, SCG0=0, OscOff=0, CPUOff=1:
  - CPU is disabled/ MCLK is disabled
  - SMCLK is disabled
  - DCO oscillator automatically disabled because it is not needed for MCLK or SMCLK; DCO's dcgenerator remains enabled
  - ACLK remains active



Power: System View MSP430 Operating Modes

Demos



# **Operating Modes (LPM3-LPM4)**

- Low power mode 3 (LPM3); SCG1=1, SCG0=1, OscOff=0, CPUOff=1:
  - CPU is disabled/ MCLK is disabled
  - SMCLK is disabled

Power In CMOS

Introduction

- DCO oscillator is disabled; DCO's dc-generator is disabled
- ACLK remains active
- Low power mode 4 (LPM4); SCG1=X, SCG0=X, OscOff=1, CPUOff=1:
  - CPU is disabled/ MCLK is disabled
  - ACLK is disabled
  - SMCLK is disabled
  - DCO oscillator is disabled/DCO's dc-generator is disabled
  - Crystal oscillator is stopped



🕑 Demo:



# What Happens in a LPM0/LPM1

- Immediately after the bit CPUOff is set the CPU stops operation
  - CPU halts and all internal bus activities stop until an interrupt request or reset occurs
  - System clock generator continues operation, and the clock signals DCO, SMCLK, and ACLK stay active depending on the state of the other three status register bits, SCG0, SCG1, and OscOff
  - Peripherals are enabled or disabled with their individual control register settings, and with the module enable registers in the SFRs
  - All I/O port pins and RAM/registers are unchanged. Wake up is possible through all enabled interrupts



MSP430 Operating Modes

Demo



# What Happens in a LPM4

- All activities cease; only the RAM contents, I/O ports, and registers are maintained
- Wake up is only possible by enabled external interrupts
- Before activating LPM4, the software should consider the system conditions during the low power mode period. The two most important conditions are environmental (that is, temperature effect on the DCO), and the clocked operation conditions.
- The environment defines whether the value of the frequency integrator should be held or corrected. A correction should be made when ambient conditions are anticipated to change drastically enough to increase or decrease the system frequency while the device is in LPM4





# **Enter ISR**

- Enter LPM: Set corresponding bits
- Process ISR
  - Entered and processed if an enabled interrupt awakens the MSP430
  - The SR and PC are stored on the stack, with the content present at the interrupt event
  - Subsequently, the operation mode control bits OscOff, SCG1, and CPUOff are cleared automatically in the status register





# **Return from ISR**

## Option #1:

- Return with low-power mode bits set (RETI will restore the original SR)
  - PC points to an instruction that will not be executed, since the restored low power mode stops CPU activity

## Option #2:

- Return with low-power mode bits reset (want to stay in active mode)
- => ISR must reset the OscOff, CPUOff, SCGO, and SCG1 bits in the original SR on the stack





## **Operating Modes-Examples**

| execution of this instruction and |  |  |
|-----------------------------------|--|--|
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
| 5                                 |  |  |
|                                   |  |  |
| te                                |  |  |
| n                                 |  |  |
|                                   |  |  |
|                                   |  |  |
|                                   |  |  |
| he                                |  |  |
|                                   |  |  |



CPE 323 Introduction to Embedded Systems



### **Operating Modes C Examples**

|   | #define | С      | (0x0001u) |
|---|---------|--------|-----------|
|   | #define | Z      | (0x0002u) |
|   | #define | N      | (0x0004u) |
| l | #define | v      | (0x0100u) |
| l | #define | GIE    | (0x0008u) |
| l | #define | CPUOFF | (0x0010u) |
| I | #define | OSCOFF | (0x0020u) |
| l | #define | SCG0   | (0x0040u) |
|   | #define | SCG1   | (0x0080u) |
|   |         |        |           |

#include "in430.h"

| <pre>#define LPM0 _BIS_</pre> | SR(LPM0_bits) /*      | Enter Low Power Mode 0 */   |
|-------------------------------|-----------------------|-----------------------------|
| #define LPM0_EXIT             | BIC_SR_IRQ(LPM0_bits) | /* Exit Low Power Mode 0 */ |
| #define LPM1BIS               | S_SR(LPM1_bits) /*    | Enter Low Power Mode 1 */   |
| #define LPM1_EXIT             | BIC_SR_IRQ(LPM1_bits) | /* Exit Low Power Mode 1 */ |
| #define LPM2BIS               | S_SR(LPM2_bits) /*    | Enter Low Power Mode 2 */   |
|                               |                       | /* Exit Low Power Mode 2 */ |
| #define LPM3 BIS              | S_SR(LPM3_bits) /*    | Enter Low Power Mode 3 */   |
| #define LPM3_EXIT             | BIC_SR_IRQ(LPM3_bits) | /* Exit Low Power Mode 3 */ |
|                               |                       | Enter Low Power Mode 4 */   |
| #define LPM4_EXIT             | BIC_SR_IRQ(LPM4_bits) | /* Exit Low Power Mode 4 */ |
| #endif /* End #defi           | ines                  |                             |

/\* Low Power Modes coded with Bits 4-7 in SR \*/

| #ifndef<br>ass | IAR_SYSTEMS_ICC<br>embler */ | /* Begin #defines for    |
|----------------|------------------------------|--------------------------|
| #define        | LPM0                         | (CPUOFF)                 |
| #define        | LPM1                         | (SCG0+CPUOFF)            |
| #define        | LPM2                         | (SCG1+CPUOFF)            |
| #define        | LPM3                         | (SCG1+SCG0+CPUOFF)       |
| #define        | LPM4                         | (SCG1+SCG0+OSCOFF+CPUOFF |
|                |                              |                          |

/\* End #defines for assembler \*/

| <pre>#else /* Begin #defines for</pre> | c */                      |        |
|----------------------------------------|---------------------------|--------|
| #define LPM0_bits                      | (CPUOFF)                  |        |
| #define LPM1_bits                      | (SCG0+CPUOFF)             |        |
| #define LPM2_bits                      | (SCG1+CPUOFF)             |        |
| #define LPM3_bits                      | (SCG1+SCG0+CPUOFF)        |        |
| #define LPM4_bits                      | (SCG1+SCG0+OSCOFF+CPUOFF) |        |
|                                        |                           | /stems |







### **C** Examples

// MSP-FET430P140 Demo - WDT Toggle P1.0, Interval ISR, 32kHz ACLK 11 11 Description; Toggle P1.0 using software timed by WDT ISR. Toggle rate is exactly 250ms based on 32kHz ACLK WDT clock source. 11 In this example the WDT is configured to divide 32768 watch-11 crystal(2^15) by 2<sup>13</sup> with an ISR triggered @ 4Hz. 11 ACLK= LFXT1= 32768, MCLK= SMCLK= DCO~ 800kHz 11 //\*External watch crystal installed on XIN XOUT is required for ACLK\* 11 11 11 11 MSP430F149 11 11 /1XIN|-11 11 | 32kHz 11 --|RST XOUT | -11 11 P1.0|-->LED 11 M.Buccini Texas Instruments, Inc August 2003 11 Built with IAR Embedded Workbench Version: 1.26B 11 December 2003 Updated for IAR Embedded Workbench Version: 2.21B 11 

#include <msp430x14x.h>

#### void main (void)

{

}

// WDT 250ms, ACLK, interval timer
WDTCTL = WDT\_ADLY\_250;
IE1 |= WDTIE; // Enable WDT interrupt
P1DIR |= 0x01; // Set P1.0 to output dir.
 // Enter LPM3 w/interrupt
 \_BIS\_SR(LPM3\_bits + GIE);
}

// Watchdog Timer interrupt service routine
interrupt[WDT\_TIMER] void watchdog\_timer(void)
{

P1OUT ^= 0x01; // Toggle P1.0 using exclusive-OR







### **C** Examples

### \_BIS\_SR(LPM0\_bits + GIE); // Enter LPM0 w/ interrupt

// program stops here

## QQ?

Your program is in LPMO mode and it is woke up by an interrupt. What should be done if you do not want to go back to LPMO after servicing the interrupt request, but rather you would let the main program reenter LMPO, based on current conditions?



Power: System View > MSP430 Operating Modes

Demos



### An Example: Wake up in ISR



