# CPE/EE 421 Microcomputers

Instructor: Dr Aleksandar Milenkovic Lecture Note \$13

\*Material used is in part developed by Dr. D. Raskovic and Dr. E. Jovanov

CPE/EE 421/521 Microcomputers

1

### MSP430 Documentation

- ➤ MSP430 home page (TI)
  - www.ti.com/msp430
- User's manual
  - http://www.ece.uah.edu/~milenka/cpe421-04S/manuals/slau049c.pdf
- Datasheet
  - http://www.ece.uah.edu/~milenka/cpe421-04S/manuals/slas272c.pdf
- TI Workshop document
  - http://www.ece.uah.edu/~milenka/cpe421-04S/manuals/430 2002 atc workshop.pdf
- > IAR Workbench Tutorial
  - http://www.ece.uah.edu/~milenka/cpe421-04S/manuals/TUTOR.pdf

CPE/EE 421/521 Microcomputers

-

# The MSP430 Clock Module

# Basic Clock Systems

### MSP430 Clock System

- Low System Cost
- Low Power
- Variety of operating modes driven by application, software selectable
- Support for the Burst Mode when activated system starts and reacts rapidly
- > Stability over voltage and temperature

### **Basic Clock Systems**

- Basic Clock System-MSP430x1xx
- One DCO, digital controlled oscillator

Generated on-chip RC-type frequency controlled by SW + HW



LF: 32768Hz XT: 450kHz .... 8MHz



Clocks:

ACLK auxiliary clock ACLK
MCLK main system clock MCLK
SMCLK sub main system clock

CPE/EE 421/521 Microcomputers





5

### Clock sources

- ➤ LFXT1CLK: Low-frequency/high-frequency oscillator that can be used either with low-frequency 32,768-Hz watch crystals, or standard crystals, resonators, or external clock sources in the 450-kHz to 8-MHz range.
- XT2CLK: Optional high-frequency oscillator that can be used with standard crystals, resonators, or external clock sources in the 450-kHz to 8-MHz range.
- DCOCLK: Internal digitally controlled oscillator (DCO) with RC-type characteristics.

CPE/EE 421/521 Microcomputers

### Available clocks

- ACLK: Auxiliary clock. The ACLK is the buffered LFXT1CLK clock source divided by 1, 2, 4, or 8. ACLK is software selectable for individual peripheral modules.
- MCLK: Master clock. MCLK is software selectable as LFXT1CLK, XT2CLK (if available), or DCOCLK. MCLK is divided by 1, 2, 4, or 8. MCLK is used by the CPU and system.
- > SMCLK: Sub-main clock. SMCLK is software selectable as LFXT1CLK, XT2CLK (if available), or DCOCLK. SMCLK is divided by 1, 2, 4, or 8. SMCLK is software selectable for individual peripheral modules.

CPE/EE 421/521 Microcomputers



# Basic Clock Systems

- > DCOCLK Generated on-chip with 6μs start-up
- 32KHz Watch Crystal or High Speed Crystal / Resonator to 8MHz
   (our system is 4MHz/8MHz high Speed Crystal)
- > Flexible clock distribution tree for CPU and peripherals
- Programmable open-loop DCO Clock with internal and external current source





## Basic operation

- After POC (Power Up Clear) MCLK and SCLK are sourced by DCOCLK (approx. 800KHz) and ACLK is sourced by LFXT1 in LF mode
- Status register control bits SCG0, SCG1, OSCOFF, and CPUOFF configure the MSP430 operating modes and enable or disable portions of the basic clock module. The DCOCTL, BCSCTL1, and BCSCTL2 registers configure the basic clock module
- The basic clock can be configured or reconfigured by software at any time during program execution

CPE/EE 421/521 Microcomputers

11

# Low-power operation: An example

- ACLK can be configured to oscillate with a lowpower 32,786-Hz watch crystal
- MCLK can be configured to operate from the on-chip DCO that can be only activated when requested by interrupt-driven events.
- SMCLK can be configured to operate from either the watch crystal or the DCO, depending on peripheral requirements.

### LFXT1 Oscillator

- ► LF mode: XTS = 0
  - ❖ 32,768-Hz watch crystal in LF mode. A watch crystal connects to XIN and XOUT without any other external components.
- ➤ HF mode: XTS = 1
  - The high-speed crystal or resonator connects to XIN and XOUT and requires external capacitors on both terminals. These capacitors should be sized according to the crystal or resonator specifications.
- Software can disable LFXT1 by setting OSCOFF, if this signal does not source SMCLK or MCLK

CPE/EE 421/521 Microcomputers

13

### XT2 Oscillator

- > Similar to LFXT1 in HF mode
- XT2OFF bit disables the XT2 oscillator if XT2CLK is not used for MCLK or SMCLK



CPE/EE 421/521 Microcomputers

# Digitally-Controlled Oscillator DCO

- Integrated ring oscillator with RC-type characteristics.
  - frequency varies with temperature, voltage, and from device to device.
- DCO frequency can be adjusted by software using the DCOx, MODx, and RSELx bits.
- The digital control of the oscillator allows frequency stabilization despite its RC-type characteristics.

CPE/EE 421/521 Microcomputers

15

# Disabling DCO

Software can disable DCO if not used for MCLK and SMCLK



CPE/EE 421/521 Microcomputers

16

\_\_

# Adjusting frequency

- > After a PUC, an internal resistor is selected for the DC generator RSELx=4, and DCOx=3, allowing the DCO to start at a mid-range frequency.
- MCLK and SMCLK are sourced from DCOCLK. Because the CPU executes code from MCLK, which is sourced from the fast-starting DCO, code execution begins from PUC in less than 6us.

CPE/EE 421/521 Microcomputers

# Adjusting frequency

- DCO frequency is determined by:
  - The current injected into the DC generator by either the internal or external resistor defines the fundamental frequency.
    - DCOR bit selects the internal or external resistor.
  - ❖ The three RSELx bits select one of eight nominal frequency ranges for the DCO.
  - ❖ The three DCOx bits divide the DCO range into 8 frequency steps, separated by approx. 10%.
  - ❖ The five MODx bits, switch between the frequency selected by the DCOx bits and the next higher frequency set by DCO+1.

# Basic Clock Module Registers

Table 4-1. Basic Clock Module Registers

| Register                        | Short Form | Register Type | Address | Initial State  |
|---------------------------------|------------|---------------|---------|----------------|
| DCO control register            | DCOCTL     | Read/write    | 056h    | 056h with PUC  |
| Basic clock system control 1    | BCSCTL1    | Read/write    | 057h    | 084h with PUC  |
| Basic clock system control 2    | BCSCTL2    | Read/write    | 058h    | Reset with POR |
| SFR interrupt enable register 1 | IE1        | Read/write    | 0000h   | Reset with PUC |
| SFR interrupt flag register 1   | IFG1       | Read/write    | 0002h   | Reset with PUC |

CPE/EE 421/521 Microcomputers

19

## Basic Clock Systems-control registers

- Direct SW Control
- > DCOCLK can be Set Stabilized
- Stable DCOCLK over Temp/Vcc.

### BCSCTL2

058h



#### BCSCTL1

057h

| XT2Off | XTS    | DIVA.1 | DIVA.0 | XT5V | Rsel.2 | Rsel.1 | Rsel.0 |
|--------|--------|--------|--------|------|--------|--------|--------|
| rw-(1) | rw-(0) | rw-(0) | rw-(0) | rw-0 | rw-1   | rw-0   | rw-0   |

Selection of DCO nominal frequency

### DCOCTL

056h

| DCO.2 | DCO.1 | DCO.0 | MOD.4 | MOD.3 | MOD.2 | MOD.1 | MOD.0 |
|-------|-------|-------|-------|-------|-------|-------|-------|
| rw-0  | rw-1  | rw-1  | rw-0  | rw-0  | rw-0  | rw-0  | rw-0  |

Which of eight discrete DCO frequencies is selected Define how often frequency  $f_{\rm DCO+1}$  within the period of 32 DCOCLK cycles is used. Remaining clock cycles (32-MOD) the frequency  $f_{\rm DCO}$  is mixed

RSEL.x Select DCO nominal frequency DCO.x and MOD.x set exact DCOCLK

... select other clock tree options

CPE/EE 421/521 Microcomputers

### **Basic Clock Systems-control registers(detail)**

### Basic Clock Module Control Registers

The Basic Clock Module is configured using control registers DCOCTL, BCSCTL1, and BCSCTL2, and four bits from the CPU status register: SCG1, SCG0, OscOff, and CPUOFF.

User software can modify these control registers from their default condition at any time. The Basic Clock Module control registers are located in the byte-wide peripheral map and should be accessed with byte (.B) instructions.

| Register State                  | Short Form | Register Type | Address | Initial State |
|---------------------------------|------------|---------------|---------|---------------|
| DCO control                     |            |               |         |               |
| register                        | DCOCTL     | Read/write    | 056h    | 060h          |
| Basic clock                     | DOCOTI 4   | D = = = 1/1   | 0.571-  | 00.41-        |
| system control 1<br>Basic clock | BCSCTL1    | Read/write    | 057h    | 084h          |
| system control 2                | BCSCTL2    | Read/write    | 058h    | reset         |

CPE/EE 421/521 Microcomputers

21

#### **Basic Clock Systems-control registers(detail)**

### > Digitally-Controlled Oscillator (DCO) Clock-Frequency Control

DCOCTL is loaded with a value of 060h with a valid PUC condition.

7

.

0

DCOCTL DCO.2 DCO.1 DCO.0 MOD.4 MOD.3 MOD.2 MOD.1 MOD.0 056H 0 1 1 0 0 0 0 0

MOD.0 .. MOD.4: The MOD constant defines how often the discrete frequency  $f_{\text{DCO+1}}$  is used within a period of 32 DCOCLK cycles.

During the remaining clock cycles (32–MOD) the discrete frequency f  $_{\tiny DCO}$  is used. When the DCO constant is set to seven, no modulation is possible since the highest feasible frequency has then been selected.

**DCO.0** .. **DCO.2**: The DCO constant defines which one of the eight discrete frequencies is selected. The frequency is defined by the current injected into the dc generator.

CPE/EE 421/521 Microcomputers

### **Basic Clock Systems-control registers(detail)**

#### Oscillator and Clock Control Register

BCSCTL1 is affected by a valid PUC or POR condition.

|         | 7      |     |        |        |      |        |               | _ 0 |
|---------|--------|-----|--------|--------|------|--------|---------------|-----|
| BCSCTL1 | XT2Off | XTS | DIVA.1 | DIVA.0 | XT5V | Rsel.0 | Rsel.1 Rsel.2 | _   |
| 057h    | 1      | 0   | 0      | 0      | 0    | 1 0    | 0             |     |

**Bit0 to Bit2**: The internal resistor is selected in eight different steps.

**Rsel.0 to Rsel.2** The value of the resistor defines the nominal frequency.

The lowest nominal frequency is selected by setting Rsel=0.

Bit3, XT5V: XT5V should always be reset.

Bit4 to Bit5: The selected source for ACLK is divided by:

DIVA = 0: 1 DIVA = 1: 2 DIVA = 2: 4 DIVA = 3: 8

CPE/EE 421/521 Microcomputers

23

### **Basic Clock Systems-control registers(detail)**

**Bit6, XTS**: The LFXT1 oscillator operates with a low-frequency or with a high-frequency crystal:

XTS = 0: The low-frequency oscillator is selected.

XTS = 1: The high-frequency oscillator is selected.

The oscillator selection must meet the external crystal's operating condition.

Bit7, XT2Off: The XT2 oscillator is switched on or off:

XT2Off = 0: the oscillator is on

XT2Off = 1: the oscillator is off if it is not used for MCLK or SMCLK.

### Basic Clock Systems-control registers(detail)

### **BCSCTL2** is affected by a valid PUC or POR condition.

7

**BCSCTL2** <u>SELM.1 SELM.0 DIVM.1 DIVM.0 SELS DIVS.1 DIVS.0 DCOR</u> 058h

**BitO, DCOR**: The DCOR bit selects the resistor for injecting current into the dc generator. Based on this current, the oscillator operates if activated.

DCOR = 0: Internal resistor on, the oscillator can operate. The fail-safe mode is on.

DCOR = 1: Internal resistor off, the current must be injected externally if the DCO output drives any clock using the DCOCLK.

Bit1, Bit2: The selected source for SMCLK is divided by:

DIVS.1 .. DIVS.0 DIVS = 0:1

DIVS = 1: 2 DIVS = 2: 4 DIVS = 3: 8

CPE/EE 421/521 Microcomputers

25

0

### Basic Clock Systems-control registers(detail)

#### Bit3, SELS: Selects the source for generating SMCLK:

SELS = 0: Use the DCOCLK

SELS = 1: Use the XT2CLK signal (in three-oscillator systems)

or

LFXT1CLK signal (in two-oscillator systems)

### Bit4, Bit5: The selected source for MCLK is divided by DIVM.0 .. DIVM.1

DIVM = 0:1

DIVM = 1: 2

DIVM = 2: 4

DIVM = 3: 8

#### Bit6, Bit7: Selects the source for generating MCLK:

SELM.0 .. SELM.1

SELM = 0: Use the DCOCLK

SELM = 1: Use the DCOCLK

SELM = 2: Use the XT2CLK (x13x and x14x devices)

or

Use the LFXT1CLK (x11x(1) devices)

SELM = 3: Use the LFXT1CLK

CPE/EE 421/521 Microcomputers

### Basic Clock Systems-software FII idea

### > Basic Clock DCO is an open loop - close with SW+HW

- A reference frequency e.g. ACLK or 50/60Hz can be used to measure DCOCLK's
- ❖ Initialization or Periodic software set and stabilizes DCOCLK over reference clock
- ❖ DCOCLK is programmable 100kHz 5Mhz and stable over voltage and temperature



CPE/EE 421/521 Microcomputers

27

### Basic Clock Systems-software FII implementation

- > Example: Set DCOCLK= 1228800, ACLK= 32768
- ACLK/4 captured on CCI2B, DCOCLK is clock source for Timer\_A
- Comparator2 HW captures SMCLK (1228800Hz) in one ACLK/4 (8192Hz) period
- ❖ Target Delta = 1228800/8192= 150

CCI2BInt ... ; Compute Delta

> #150,Delta ; Delta= 1228800/8192 cmp

IncDCO ; JMP to IncDCO jlo

DecDCO dec &DCOCTL Decrease DCOCLK

reti &DCOCTL

IncDCO inc ; Increase DCOCLK



CPE/EE 421/521 Microcomputers

#### Basic Clock Systems-DCO TAPS DCOCLK frequency control DCOCLK nominal - injected current into DC generator 1) internal resistors Rsel2, Rsel1 and Rsel0 2) an external resistor at Rosc (P2.5/11x) f<sub>nominal+1</sub> Control bits DCO0 to DCO2 set fDCO tap Modulation bits MOD0 to MOD4 allow mixing of fDCO and fDCO+1 for precise frequency generation f<sub>nominal</sub> Frequency Cycle time 1000 nsec f3: 943kHz 1060 nsec f4: 1042kHz 960 nsec f<sub>nominal-1</sub> MOD=19 Modulation Period $f_3$ f<sub>4</sub> f<sub>5</sub> Cycle\_time = ((32-MOD)\*t1+MOD\*t2)/32 = 1000.625 ns, selected frequency $\approx 1$ MHz. CPE/EE 421/521 Microcomputers 29

#### F149 default DCO clock setting PARAMETER MAX V<sub>CC</sub> = 2.2 V Rsel = 0, DCO = 3, MOD = 0, DCOR = 0, TA = 25°C 0.08 0.12 0.15 MHz f(DC003) VCC = 3 V 0.08 0.13 0.16 R<sub>sel</sub> = 1, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C V<sub>CC</sub> = 2.2 V 0.14 0.19 0.23 MHz f(DCO13) V<sub>CC</sub> = 3 V 0.22 V<sub>CC</sub> = 2.2 V $R_{sel} = 2$ , DCO = 3, MOD = 0, DCOR = 0, $T_A = 25$ °C 0.30 0.36 MHz f(DCO23) VCC = 3 V 0.22 0.28 0.34 R<sub>Sel</sub> = 3, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C V<sub>CC</sub> = 2.2 V 0.37 0.49 0.59 f(DCO33) MHz V<sub>CC</sub> = 3 V 0.47 0.56 V<sub>CC</sub> = 2.2 V R<sub>sel</sub> = 4, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C 0.61 0.77 0.93 f(DCO43) MHz V<sub>CC</sub> = 3 V 0.61 0.75 0.90 V<sub>CC</sub> = 2.2 V R<sub>Sel</sub> = 5, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C 1.2 1.5 f(DCO53) MHz VCC = 3 V1.3 1.5 R<sub>Sel</sub> = 6, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C V<sub>CC</sub> = 2.2 V 1.6 f(DCO63) MHz V<sub>CC</sub> = 3 V 1.69 2.29 V<sub>CC</sub> = 2.2 V R<sub>SAI</sub> = 7, DCO = 3, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C 2.4 2.9 3.4 f(DCO73) MHz ACC = 3 A3.65 2.7 3.2 fDCO40 × 1.7 fDCO40 fDCO40 R<sub>Sel</sub> = 4, DCO = 7, MOD = 0, DCOR = 0, T<sub>A</sub> = 25°C f(DCO47) VCC = 2.2 V/3 V MHz V<sub>CC</sub> = 2.2 V 4.5 4.9 $R_{sel} = 7$ , DCO = 7, MOD = 0, DCOR = 0, $T_A = 25$ °C MHz f(DC077) 4.9 5.4 V<sub>CC</sub> = 2.2 V/3 V 1.35 1.65 2 S(Rsel) S<sub>R</sub> = f<sub>Rsel+1</sub> / f<sub>Rsel</sub> V<sub>CC</sub> = 2.2 V/3 V 1.07 1.12 1.16 S(DCO) SDCO = fDCO+1 / fDCO V<sub>CC</sub> = 2.2 V -0.31 -0.36 -0.40 Temperature drift, R<sub>Sel</sub> = 4, DCO = 3, MOD = 0 %/°C (see Note 30) -0.33 Drift with V<sub>CC</sub> variation, R<sub>Sel</sub> = 4, DCO = 3, MOD = 0 (see Note 30) V<sub>CC</sub> = 2.2 V/3 V 0 10 %√V slas272c/page CPE/EE 421/521 Microcomputers





### DCO Modulator

➤ To produce 1 an intermediate effective frequency between f<sub>DCO</sub> and f<sub>DCO+1</sub>

The modulator mixing formula is:

$$t = (32-MODx) \times t_{DCO} + MODx \times t_{DCO+1}$$

CPE/EE 421/521 Microcomputers

33

# Fail Safe Operation

- Basic module incorporates an oscillator-fault detection fail-safe feature.
- The oscillator fault detector is an analog circuit that monitors the LFXT1CLK (in HF mode) and the XT2CLK.
- An oscillator fault is detected when either clock signal is not present for approximately 50 us.
  - When an oscillator fault is detected, and when MCLK is sourced from either LFXT1 in HF mode or XT2, MCLK is automatically switched to the DCO for its clock source.

# Fail Safe Operation

When OFIFG is set and OFIE is set, an NMI interrupt is requested. The NMI interrupt service routine can test the OFIFG flag to determine if an oscillator fault occurred. The OFIFG flag must be cleared by software.

CPE/EE 421/521 Microcomputers

# Synchronization of clock signals

- To avoid race conditions
  - The current clock cycle continues until the next rising edge.
  - ❖ The clock remains high until the next rising edge of the new clock.
  - The new clock source is selected and continues with a full high period.



### **Basic Clock Systems-Examples**

### How to select the Crystal Clock

### How to select a clock for MCLK

```
BCSCTL2=SELM0+SELM1; /*Then set MCLK same as LFXT1CLK*/
TACTL=TASSEL0+TACLR+ID1; /*USE ACLK/4 AS TIMER_A INPUT CLOCK
(1MHz) */
```

CPE/EE 421/521 Microcomputers

37

#### **Basic Clock Systems-Examples**

### Adjusting the Basic Clock

The control registers of the Basic Clock are under full software control. If clock requirements other than those of the default from PUC are necessary, the Basic Clock can be configured or reconfigured by software at any time during program execution.

- □ ACLKGEN from LFXT1 crystal, resonator, or external-clock source and divided by 1, 2, 4, or 8. If no LFXTCLK clock signal is needed in the application, the OscOff bit should be set in the status register.
- □ SCLKGEN from LFXTCLK, DCOCLK, or XT2CLK (x13x and x14x only) and divided by 1, 2, 4, or 8. The SCG1 bit in the status register enables or disables SMCLK.
- MCLKGEN from LFXTCLK, DCOCLK, or XT2CLK (x13x and x14x only) and divided by 1, 2, 4, or 8. When set, the CPUOff bit in the status register enables or disables MCLK.
- DCOCLK frequency is adjusted using the RSEL, DCO, and MOD bits. The DCOCLK clock source is stopped when not used, and the dc generator can be disabled by the SCG0 bit in the status register (when set).
- ☐ The XT2 oscillator sources XT2CLK (x13x and x14x only) by clearing the XT2Off bit.

### **Interrupt Service Routines**

### > Interrupt Service Routine declaration

```
// Func. declaration
Interrupt[int_vector] void myISR (Void);

Interrupt[int_vector] void myISR (Void)
{
// ISR code
}

Interrupt[TIMERAO_VECTOR] void myISR (Void);

Interrupt[TIMERAO_VECTOR] void myISR (Void)
{
// ISR code
}
```

CPE/EE 421/521 Microcomputers

39

### **Interrupt Service Routines**

### MSP430 interrupt vectors (int\_vector)

\* Interrupt Vectors (offset from 0xFFE0)

/\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*

- #define UARTOTX\_VECTOR 8 \* 2 /\* 0xFFF0 UART 0 Transmit \*/
- #define COMPARATORA\_VECTOR 11 \* 2 /\* 0xFFF6 Comparator A \*/
- ightharpoonup #define TIMERB1\_VECTOR 12 \* 2 /\* 0xFFF8 Timer B 1-7 \*/ ightharpoonup #define TIMERB0\_VECTOR 13 \* 2 /\* 0xFFFA Timer B 0 \*/
- #define NMI\_VECTOR 14 \* 2 /\* 0xFFFC Non-maskable \*/

### **Watchdog Timer-General**

#### General

The primary function of the watchdog-timer module (WDT) is to perform a controlled-system restart after a software problem occurs. If the selected time interval expires, a system reset is generated. If the watchdog function is not needed in an application, the module can work as an interval timer, to generate an interrupt after the selected time interval.

### Features of the Watchdog Timer include:

- > Eight software-selectable time intervals
- > Two operating modes: as watchdog or interval timer
- Expiration of the time interval in watchdog mode, which generates a system reset; or in timer mode, which generates an interrupt request
- Safeguards which ensure that writing to the WDT control register is only possible using a password
- Support of ultralow-power using the hold mode

### Watchdog/Timer two functions:

- SW Watchdog Mode
- Interval Timer Mode

CPE/EE 421/521 Microcomputers



### **Watchdog Timer-Registers**

### ■ Watchdog Timer Counter

The watchdog-timer counter (WDTCNT) is a 16-bit up-counter that is not directly accessible by software. The WDTCNT is controlled through the watchdog-timer control register (WDTCTL), which is a 16-bit read/write register located at the low byte of word address 0120h. Any read or write access must be done using word instructions with no suffix or .w suffix. In both operating modes (watchdog or timer), it is only possible to write to WDTCTL using the correct password.

### □ Watchdog Timer Control Register



Bits 0, 1: Bits ISO and IS1 select one of four taps from the WDTCNT, as described in following table. Assuming f crystal = 32,768 Hz and f System = 1 MHz, the following intervals are possible:

CPE/EE 421/521 Microcomputers

43

### **Watchdog Timer-Registers**

| SSEL         | IS1 | IS0 | In    | terval [ms]                      |                    |
|--------------|-----|-----|-------|----------------------------------|--------------------|
| 0            | 1   | 1   | 0.064 | t SMCLK × 2 <sup>6</sup>         | Table: WDTCNT Taps |
| 0            | 1   | 0   | 0.5   | t SMCLK × 2 9                    |                    |
| 1            | 1   | 1   | 1.9   | t ACLK × 2 <sup>6</sup>          |                    |
| 0            | 0   | 1   | 8     | t SMCLK $\times$ 2 <sup>13</sup> |                    |
| 1            | 1   | 0   | 16.0  | t ACLK × 2 9                     |                    |
| o<br>(reset) | 0   | 0   | 32    | t SMCLK $\times$ 2 <sup>15</sup> | <- Value after PUC |
| 1            | 0   | 1   | 250   | t ACLK $\times$ 2 $^{13}$        |                    |
| 1            | 0   | 0   | 1000  | $t$ ACLK $\times$ 2 $^{15}$      |                    |

Bit 2: The SSEL bit selects the clock source for WDTCNT.

SSEL = 0: WDTCNT is clocked by SMCLK.

SSEL = 1: WDTCNT is clocked by ACLK.

**Bit 3**: Counter clear bit. In both operating modes, writing a 1 to this bit restarts the WDTCNT at 00000h. The value read is not defined.

Bit 4: The TMSEL bit selects the operating mode: watchdog or timer.

TMSEL = 0: Watchdog mode

TMSEL = 1: Interval-timer mode CPE/EE 421/521 Microcomputers

**Bit 5**: The NMI bit selects the function of the RST/NMI input pin. It is

### **Watchdog Timer-Registers**

**NMI = 0**: The RST/NMI input works as reset input.

As long as the RST/NMI pin is held low, the internal signal is active (level sensitive).

**NMI = 1**: The RST/NMI input works as an edge-sensitive non-maskable interrupt input.

**Bit 6**: If the NMI function is selected, this bit selects the activating edge of the RST/NMI input. It is cleared by the PUC signal.

**NMIES = 0**: A rising edge triggers an NMI interrupt.

**NMIES = 1**: A falling edge triggers an NMI interrupt.

CAUTION: Changing the NMIES bit with software can generate an NMI interrupt.

**Bit 7**: This bit stops the operation of the watchdog counter. The clock multiplexer is disabled and the counter stops incrementing. It holds the last value until the hold bit is reset and the operation continues. It is cleared by the PUC signal.

**HOLD = 0**: The WDT is fully active.

**HOLD = 1**: The clock multiplexer and counter are stopped.

CPE/EE 421/521 Microcomputers

45

#### **Watchdog Timer-Interrupt Function**

☐ The Watchdog Timer (WDT) uses two bits in the SFRs for interrupt control.

The WDT interrupt flag (WDTIFG) (located in IFG1.0, initial state is reset)
The WDT interrupt enable (WDTIE) (located in IE1.0, initial state is reset)

- When using the watchdog mode, the WDTIFG flag is used by the reset interrupt service routine to determine if the watchdog caused the device to reset. If the flag is set, then the Watchdog Timer initiated the reset condition (either by timing out or by a security key violation). If the flag is cleared, then the PUC was caused by a different source. See chapter 3 for more details on the PUC and POR signals.
- When using the Watchdog Timer in interval-timer mode, the WDTIFG flag is set after the selected time interval and a watchdog interval-timer interrupt is requested. The interrupt vector address in interval-timer mode is different from that in watchdog mode. In interval-timer mode, the WDTIFG flag is reset automatically when the interrupt is serviced.
- The WDTIE bit is used to enable or disable the interrupt from the Watchdog Timer when it is being used in interval-timer mode. Also, the GIE bit enables or disables the interrupt from the Watchdog Timer when it is being used in interval-timer mode.

### **Watchdog Timer-Timer Mode**

- Setting WDTCTL register bit TMSEL to 1 selects the timer mode. This mode provides periodic interrupts at the selected time interval. A time interval can also be initiated by writing a 1 to bit CNTCL in the WDTCTL register.
- When the WDT is configured to operate in timer mode, the WDTIFG flag is set after the selected time interval, and it requests a standard interrupt service. The WDT interrupt flag is a single-source interrupt flag and is automatically reset when it is serviced. The enable bit remains unchanged. In interval-timer mode, the WDT interrupt-enable bit and the GIE bit must be set to allow the WDT to request an interrupt. The interrupt vector address in timer mode is different from that in watchdog mode.

CPE/EE 421/521 Microcomputers

47

### **Watchdog Timer-Examples**

☐ How to select timer mode

```
/* WDT is clocked by fACLK (assumed 32Khz) */
WDTCL=WDT_ADLY_250; // WDT 250MS/4 INTERVAL TIMER
IE1 |=WDTIE; // ENABLE WDT INTERRUPT
```

□ How to stop watchdog timer

```
WDTCTL=WDTPW + WDTHOLD ; // stop watchdog timer
```

□ Assembly programming

```
WDT_key    .equ    05A00h    ; Key to access WDT
WDTStop    mov    #(WDT_Key+80h),&WDTCTL; Hold Watchdog
WDT250    mov    #(WDT_Key+1Dh),&WDTCTL; WDT, 250ms Interval
```