

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

#### Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

E·XFI

| Product Status             | Active                                                      |
|----------------------------|-------------------------------------------------------------|
| Core Processor             | HC08                                                        |
| Core Size                  | 8-Bit                                                       |
| Speed                      | 8MHz                                                        |
| Connectivity               | CANbus, LINbus, SCI, SPI                                    |
| Peripherals                | LVD, POR, PWM                                               |
| Number of I/O              | 37                                                          |
| Program Memory Size        | 8KB (8K x 8)                                                |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | -                                                           |
| RAM Size                   | 1K x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V                                                   |
| Data Converters            | A/D 8x10b                                                   |
| Oscillator Type            | Internal                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                          |
| Mounting Type              | Surface Mount                                               |
| Package / Case             | 48-LQFP                                                     |
| Supplier Device Package    | 48-LQFP (7x7)                                               |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc68908gz8mfae |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



#### Input/Output (I/O) Section

| Addr.                                              | Register Name                                |                 | Bit 7  | 6          | 5               | 4           | 3              | 2              | 1     | Bit 0  |  |
|----------------------------------------------------|----------------------------------------------|-----------------|--------|------------|-----------------|-------------|----------------|----------------|-------|--------|--|
|                                                    | Timer 2 Channel 0 Status and                 | Read:           | CH0F   | CH0IE      | MS0B            | MS0A        | ELS0B          | ELS0A          | TOV0  | CHOMAX |  |
| \$0030                                             | Control Register (T2SC0)                     | Write:          | 0      |            |                 |             |                |                |       |        |  |
|                                                    | See page 267.                                | Reset:          | 0      | 0          | 0               | 0           | 0              | 0              | 0     | 0      |  |
| Timer 2 Channel 0<br>\$0031 Register High (T2CH0H) |                                              | Read:<br>Write: | Bit 15 | 14         | 13              | 12          | 11             | 10             | 9     | Bit 8  |  |
|                                                    | See page 270.                                | Reset:          |        |            |                 | Indetermina | te after reset |                |       |        |  |
| Timer 2 Channel 0<br>\$0032 Register Low (T2CH0L)  | Read:<br>Write:                              | Bit 7           | 6      | 5          | 4               | 3           | 2              | 1              | Bit 0 |        |  |
|                                                    | See page 270.                                | Reset:          |        |            |                 | Indetermina | te after reset |                |       |        |  |
|                                                    | Timer 2 Channel 1 Status and                 | Read:           | CH1F   |            | 0               | MOTA        |                |                | TOVA  | OUTMAX |  |
| \$0033                                             | Control Register (T2SC1)                     | Write:          | 0      | CHIE       |                 | MSTA        | ELSIB          | ELSTA          | 1001  | CHIMAX |  |
|                                                    | See page 267.                                | Reset:          | 0      | 0          | 0               | 0           | 0              | 0              | 0     | 0      |  |
| \$0034                                             | Timer 2 Channel 1<br>Register High (T2CH1H)  | Read:<br>Write: | Bit 15 | 14         | 13              | 12          | 11             | 10             | 9     | Bit 8  |  |
|                                                    | See page 270.                                | Reset:          |        |            |                 | Indetermina | te after reset |                |       |        |  |
| \$0035                                             | Timer 2 Channel 1<br>Register Low (T2CH1L)   | Read:<br>Write: | Bit 7  | 6          | 5               | 4           | 3              | 2              | 1     | Bit 0  |  |
|                                                    | See page 270.                                | Reset:          |        |            |                 | Indetermina | te after reset |                |       |        |  |
| \$0036                                             | PLL Control Register<br>(PCTL)               | Read:<br>Write: | PLLIE  | PLLF       | PLLON           | BCS         | R              | R              | VPR1  | VPR0   |  |
|                                                    | See page 69.                                 | Reset:          | 0      | 0          | 1               | 0           | 0              | 0              | 0     | 0      |  |
|                                                    | DI L. Dondwidth Control                      | Read:           |        | LOCK       |                 | 0           | 0              | 0              | 0     |        |  |
| \$0037                                             | PLL Bandwidth Control<br>Register (PBWC)     | Write:          | AUTO   |            | ACQ             |             |                |                |       | R      |  |
| ·                                                  | See page 71.                                 | Reset:          | 0      | 0          | 0               | 0           | 0              | 0              | 0     | 0      |  |
|                                                    | DLL Multiplier Select High                   | Read:           | 0      | 0          | 0               | 0           |                |                |       |        |  |
| \$0038                                             | Register (PMSH)                              | Write:          |        |            |                 |             | MUL11          | MUL10          | MUL9  | MUL8   |  |
|                                                    | See page 72.                                 | Reset:          | 0      | 0          | 0               | 0           | 0              | 0              | 0     | 0      |  |
| \$0039                                             | PLL Multiplier Select Low<br>Register (PMSL) | Read:<br>Write: | MUL7   | MUL6       | MUL5            | MUL4        | MUL3           | MUL2           | MUL1  | MULO   |  |
|                                                    | See page 73.                                 | Reset:          | 0      | 0          | 0               | 0           | U              | U              | U     | U      |  |
| <b>*</b> ****                                      | PLL VCO Select Range                         | Read:           | VRS7   | VRS6       | VRS5            | VRS4        | VRS3           | VRS2           | VRS1  | VRS0   |  |
| \$003A                                             | Register (PMRS)<br>See nage 73               | Write:          |        |            |                 |             |                |                |       |        |  |
|                                                    | oce page 70.                                 | Reset:          | 0      | 1          | 0               | 0           | 0              | 0              | 0     | 0      |  |
|                                                    |                                              | Read:           | 0      | 0          | 0               | 0           | R              | R              | R     | R      |  |
| \$003B                                             | Reserved                                     | Write:          |        |            | _               | _           |                |                |       |        |  |
|                                                    |                                              | Reset:          | 0      | 0          | 0               | 0           | 0              | 0              | 0     | 1      |  |
|                                                    |                                              |                 |        | = Unimplem | = Unimplemented |             | d              | U = Unaffected |       |        |  |





#### Memory

| Addr.        | Register Name                               | _               | Bit 7                                                                                         | 6         | 5                     | 4              | 3                               | 2                        | 1        | Bit 0 |  |
|--------------|---------------------------------------------|-----------------|-----------------------------------------------------------------------------------------------|-----------|-----------------------|----------------|---------------------------------|--------------------------|----------|-------|--|
| \$003C       | ADC Status and Control<br>Register (ADSCR)  | Read:<br>Write: | 0000                                                                                          | AIEN      | ADCO                  | ADCH4          | ADCH3                           | ADCH2                    | ADCH1    | ADCH0 |  |
|              | See page 53.                                | Reset:          | 0                                                                                             | 0         | 0                     | 1              | 1                               | 1                        | 1        | 1     |  |
|              | ADC Data High Register                      | Read:           | 0                                                                                             | 0         | 0                     | 0              | 0                               | 0                        | AD9      | AD8   |  |
| \$003D       | \$003D (ADRH)                               |                 |                                                                                               |           |                       |                |                                 |                          |          |       |  |
|              | See page 55.                                | Reset:          |                                                                                               |           |                       | Unaffecte      | d by reset                      |                          |          |       |  |
|              | ADC Data Low Register                       | Read:           | AD7                                                                                           | AD6       | AD5                   | AD4            | A3                              | AD2                      | AD1      | AD0   |  |
| \$003E       | (ADRL)                                      | Write:          |                                                                                               |           |                       |                |                                 |                          |          |       |  |
|              | See page 55.                                | Reset:          |                                                                                               |           |                       | Unaffecte      | d by reset                      |                          |          |       |  |
| ¢0005        | ADC Clock Register                          | Read:           | ADIV2                                                                                         | ADIV1     | ADIV0                 | ADICLK         | MODE1                           | MODE0                    | R        | 0     |  |
| See page 57. | Reset:                                      | 0               | 0                                                                                             | 0         | 0                     | 0              | 1                               | 0                        | 0        |       |  |
| \$0500       | MSCAN08 Control                             | [               | -                                                                                             | -         |                       |                |                                 |                          |          |       |  |
| $\downarrow$ | Registers                                   |                 | MSCAN08 control registers (9 bytes)<br>Refer to 12 13 Programmer's Model of Control Begisters |           |                       |                |                                 |                          |          |       |  |
| \$0508       | See page 141.                               |                 |                                                                                               |           |                       |                |                                 |                          |          |       |  |
|              |                                             | г               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| \$0509<br>↓  | Reserved                                    |                 |                                                                                               |           |                       | Reserved       | l (5 bytes)                     |                          |          |       |  |
| \$050D       | 1000100                                     |                 |                                                                                               |           |                       | 110001100      | (0.5)(00)                       |                          |          |       |  |
|              |                                             | L               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| \$050E       | MSCAN08                                     | Ī               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| ¢050⊑        | Error Counters                              |                 |                                                                                               |           | MS                    | CAN08 error of | counters (2 by                  | /tes)                    |          |       |  |
| φυσυι        |                                             | L               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| \$0510       | MSCAN08                                     | F               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| Ŷ            | Identifier Filter                           |                 |                                                                                               |           | MSC<br>Refer to 12.13 | AN08 control   | registers (9 b<br>s Model of Co | ytes)<br>patrol Register | re       |       |  |
| \$0517       | See page 141.                               |                 |                                                                                               |           |                       | riogrammer     |                                 |                          | 15       |       |  |
|              |                                             | г               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| \$0518<br>I  | Pacanyod                                    |                 |                                                                                               |           |                       | Pecanyod       | (10 bytes)                      |                          |          |       |  |
| \$053F       | neserveu                                    |                 |                                                                                               |           |                       | neserveu       | (40 bytes)                      |                          |          |       |  |
|              |                                             | L               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| \$0540       | MSCAN08                                     | [               |                                                                                               |           |                       |                |                                 |                          |          |       |  |
| ↓            | Receive Buffer                              |                 |                                                                                               | R         | efer to 12.12         | Programmer'    | s Model of Me                   | essage Storad            | je       |       |  |
| \$054F       | See page 137.                               |                 |                                                                                               |           |                       | 0              |                                 | 0 0                      | <i>.</i> |       |  |
| ¢0550        |                                             | Г               |                                                                                               |           |                       |                |                                 |                          |          | ,     |  |
| ¢0550<br>↓   | MSCAN08 Transmit Buffer 0                   |                 |                                                                                               |           |                       | MSC08 trans    | mitter buffer (                 | )                        |          |       |  |
| \$055F       | See page 137.                               |                 |                                                                                               | K         | eier to 12.12         | Frogrammer     | s would of Me                   | essage Storag            | je       |       |  |
|              |                                             |                 |                                                                                               |           |                       |                |                                 |                          |          |       |  |
|              |                                             | Г               |                                                                                               |           | ontod                 | D - Doorre     | d                               |                          | od       |       |  |
|              | = Unimplemented R = Reserved U = Unaffected |                 |                                                                                               |           |                       |                |                                 |                          |          |       |  |
|              | Figure                                      | 2-2. C          | ontrol, S                                                                                     | Status, a | nd Data               | Register       | s (Sheet                        | 6 of 8)                  |          |       |  |



#### Memory

| Addr.         | Register Name                                           |                                             | Bit 7                    | 6    | 5       | 4           | 3            | 2      | 1    | Bit 0 |  |  |
|---------------|---------------------------------------------------------|---------------------------------------------|--------------------------|------|---------|-------------|--------------|--------|------|-------|--|--|
| \$FE0A        | Break Address Register Low<br>(BRKL)                    | Read:<br>Write:                             | Bit 7                    | 6    | 5       | 4           | 3            | 2      | 1    | Bit 0 |  |  |
|               | See page 274.                                           | Reset:                                      | 0                        | 0    | 0       | 0           | 0            | 0      | 0    | 0     |  |  |
|               | Break Status and Control                                | Read:                                       | PDVE                     | DDKA | 0       | 0           | 0            | 0      | 0    | 0     |  |  |
| \$FE0B        | Register (BRKSCR)                                       | Write:                                      | DNKE                     | DRKA |         |             |              |        |      |       |  |  |
|               | See page 274.                                           | Reset:                                      | 0                        | 0    | 0       | 0           | 0            | 0      | 0    | 0     |  |  |
| \$FE0C        |                                                         | Read:                                       | LVIOUT                   | 0    | 0       | 0           | 0            | 0      | 0    | 0     |  |  |
|               | LVI Status Register (LVISR)<br>See page 119.            | Write:                                      |                          |      |         |             |              |        |      |       |  |  |
|               |                                                         | Reset:                                      | 0                        | 0    | 0       | 0           | 0            | 0      | 0    | 0     |  |  |
| \$FF7E        | FLASH Block Protect<br>Begister (FL BPB) <sup>(3)</sup> | Read:<br>Write:                             | BPR7                     | BPR6 | BPR5    | BPR4        | BPR3         | BPR2   | BPR1 | BPR0  |  |  |
| <b>+</b> ···- | See page 44.                                            | Reset:                                      | set: Unaffected by reset |      |         |             |              |        |      |       |  |  |
| 3. Nor        | volatile FLASH register                                 |                                             |                          |      |         |             |              |        |      |       |  |  |
|               | COP Control Begister                                    | Read:                                       |                          |      |         | Low byte of | reset vector |        |      |       |  |  |
| \$FFFF        | (COPCTL)                                                | Write:                                      |                          |      | Writing | clears COP  | counter (any | value) |      |       |  |  |
|               | See page 85.                                            | Reset:                                      |                          |      |         | Unaffecte   | d by reset   |        |      |       |  |  |
|               |                                                         | = Unimplemented R = Reserved U = Unaffected |                          |      |         |             |              |        |      |       |  |  |

Figure 2-2. Control, Status, and Data Registers (Sheet 8 of 8)



The address ranges for the user memory and vectors are:

- \$C000–\$FDFF; user memory
- \$FE08; FLASH control register
- \$FF7E; FLASH block protect register
- \$FFD4-\$FFFF; these locations are reserved for user-defined interrupt and reset vectors

Programming tools are available from Freescale Semiconductor. Contact your local representative for more information.

#### NOTE

A security feature prevents viewing of the FLASH contents.<sup>(1)</sup>

### 2.6.2 FLASH Control Register

The FLASH control register (FLCR) controls FLASH program and erase operations.



Figure 2-3. FLASH Control Register (FLCR)

### HVEN — High-Voltage Enable Bit

This read/write bit enables the charge pump to drive high voltages for program and erase operations in the array. HVEN can only be set if either PGM = 1 or ERASE = 1 and the proper sequence for program or erase is followed.

1 = High voltage enabled to array and charge pump on

0 = High voltage disabled to array and charge pump off

#### MASS — Mass Erase Control Bit

Setting this read/write bit configures the 16-Kbyte FLASH array for mass erase operation.

1 = MASS erase operation selected

0 = PAGE erase operation selected

#### ERASE — Erase Control Bit

This read/write bit configures the memory for erase operation. ERASE is interlocked with the PGM bit such that both bits cannot be equal to 1 or set to 1 at the same time.

1 = Erase operation selected

0 = Erase operation unselected

#### PGM — Program Control Bit

This read/write bit configures the memory for program operation. PGM is interlocked with the ERASE bit such that both bits cannot be equal to 1 or set to 1 at the same time.

1 = Program operation selected

0 = Program operation unselected

<sup>1.</sup> No security feature is absolutely secure. However, Freescale's strategy is to make reading or copying the FLASH difficult for unauthorized users.



Analog-to-Digital Converter (ADC)



The following conditions apply when in manual mode:

- ACQ is a writable control bit that controls the mode of the filter. Before turning on the PLL in manual mode, the ACQ bit must be clear.
- Before entering tracking mode (ACQ = 1), software must wait a given time, t<sub>ACQ</sub> (See 4.8 Acquisition/Lock Time Specifications.), after turning on the PLL by setting PLLON in the PLL control register (PCTL).
- Software must wait a given time, t<sub>AL</sub>, after entering tracking mode before selecting the PLL as the clock source to CGMOUT (BCS = 1).
- The LOCK bit is disabled.
- CPU interrupts from the CGM are disabled.

## 4.3.6 Programming the PLL

Use the following procedure to program the PLL. For reference, the variables used and their meaning are shown in Table 4-1.

| Variable             | Definition                         |
|----------------------|------------------------------------|
| f <sub>BUSDES</sub>  | Desired bus clock frequency        |
| f <sub>VCLKDES</sub> | Desired VCO clock frequency        |
| f <sub>RCLK</sub>    | Chosen reference crystal frequency |
| f <sub>VCLK</sub>    | Calculated VCO clock frequency     |
| f <sub>BUS</sub>     | Calculated bus clock frequency     |
| f <sub>NOM</sub>     | Nominal VCO center frequency       |
| f <sub>VRS</sub>     | Programmed VCO center frequency    |

Table 4-1. Variable Definitions

### NOTE

The round function in the following equations means that the real number should be rounded to the nearest integer number.

- 1. Choose the desired bus frequency, f<sub>BUSDES</sub>.
- 2. Calculate the desired VCO frequency (four times the desired bus frequency).

 $f_{VCLKDES} = 4 \times f_{BUSDES}$ 

 Choose a practical PLL (crystal) reference frequency, f<sub>RCLK</sub>. Typically, the reference crystal is 1–8 MHz.

Frequency errors to the PLL are corrected at a rate of f<sub>RCLK</sub>.

For stability and lock time reduction, this rate must be as fast as possible. The VCO frequency must be an integer multiple of this rate. The relationship between the VCO frequency,  $f_{VCLK}$ , and the reference frequency,  $f_{RCLK}$ , is:

$$f_{VCLK} = (N) (f_{RCLK})$$

N, the range multiplier, must be an integer.



**Clock Generator Module (CGM)** 

## 4.3.9 CGM External Connections

In its typical configuration, the CGM requires external components. Five of these are for the crystal oscillator and two or four are for the PLL.

The crystal oscillator is normally connected in a Pierce oscillator configuration, as shown in Figure 4-2. Figure 4-2 shows only the logical representation of the internal components and may not represent actual circuitry. The oscillator configuration uses five components:

- Crystal, X<sub>1</sub>
- Fixed capacitor, C<sub>1</sub>
- Tuning capacitor, C<sub>2</sub> (can also be a fixed capacitor)
- Feedback resistor, R<sub>B</sub>
- Series resistor, R<sub>S</sub>

The series resistor ( $R_S$ ) is included in the diagram to follow strict Pierce oscillator guidelines. Refer to the crystal manufacturer's data for more information regarding values for C1 and C2.

Figure 4-2 also shows the external components for the PLL:

- Bypass capacitor, C<sub>BYP</sub>
- Filter network

Routing should be done with great care to minimize signal cross talk and noise.



Note: Filter network in box can be replaced with a single capacitor, but will degrade stability.

Figure 4-2. CGM External Connections





## 4.5.4 PLL Multiplier Select Register Low

The PLL multiplier select register low (PMSL) contains the programming information for the low byte of the modulo feedback divider.



### Figure 4-7. PLL Multiplier Select Register Low (PMSL)

### NOTE

For applications using 1–8 MHz reference frequencies this register must be reprogrammed before enabling the PLL. The reset value of this register will cause applications using 1–8 MHz reference frequencies to become unstable if the PLL is enabled without programming an appropriate value. The programmed value must not allow the VCO clock to exceed 32 MHz. See 4.3.6 Programming the PLL for detailed instructions on choosing the proper value for PMSL.

### MUL7–MUL0 — Multiplier Select Bits

These read/write bits control the low byte of the modulo feedback divider that selects the VCO frequency multiplier, N. (See 4.3.3 PLL Circuits and 4.3.6 Programming the PLL.) MUL7–MUL0 cannot be written when the PLLON bit in the PCTL is set. A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the register to \$40 for a default multiply value of 64.

### NOTE

The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1).

## 4.5.5 PLL VCO Range Select Register

#### NOTE

PMRS may be called PVRS on other HC08 derivatives.

The PLL VCO range select register (PMRS) contains the programming information required for the hardware configuration of the VCO.



Figure 4-8. PLL VCO Range Select Register (PMRS)



**Central Processor Unit (CPU)** 

| Source                                                                                         | Operation                                                         | Description                                                                                                                                                                                                                               |   | o | Eff<br>on ( | ec<br>CC | t<br>R |   | ress<br>e                                           | ode                                              | rand                                            | es                    |
|------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-------------|----------|--------|---|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|-----------------------|
| Form                                                                                           | Operation                                                         | Description                                                                                                                                                                                                                               | v | н | I           | Ν        | z      | С | Addi                                                | Opci                                             | Opei                                            | Cycl                  |
| PULA                                                                                           | Pull A from Stack                                                 | $SP \leftarrow (SP + 1); Pull (A)$                                                                                                                                                                                                        | - | - | -           | -        | -      | - | INH                                                 | 86                                               |                                                 | 2                     |
| PULH                                                                                           | Pull H from Stack                                                 | $SP \leftarrow (SP + 1); Pull (H)$                                                                                                                                                                                                        | - | - | -           | -        | -      | - | INH                                                 | 8A                                               |                                                 | 2                     |
| PULX                                                                                           | Pull X from Stack                                                 | $SP \leftarrow (SP + 1); Pull (X)$                                                                                                                                                                                                        | - | - | -           | -        | -      | - | INH                                                 | 88                                               |                                                 | 2                     |
| ROL <i>opr</i><br>ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X<br>ROL <i>opr</i> ,SP            | Rotate Left through Carry                                         |                                                                                                                                                                                                                                           | t | _ | _           | ţ        | ţ      | ţ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 39<br>49<br>59<br>69<br>79<br>9E69               | dd<br>ff<br>ff                                  | 4<br>1<br>4<br>3<br>5 |
| ROR <i>opr</i><br>RORA<br>RORX<br>ROR <i>opr</i> ,X<br>ROR ,X<br>ROR <i>opr</i> ,SP            | Rotate Right through Carry                                        | b7 b0                                                                                                                                                                                                                                     | ţ | _ | _           | ţ        | ţ      | ţ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 36<br>46<br>56<br>66<br>76<br>9E66               | dd<br>ff<br>ff                                  | 411435                |
| RSP                                                                                            | Reset Stack Pointer                                               | $SP \leftarrow \$FF$                                                                                                                                                                                                                      | - | - | -           | -        | -      | - | INH                                                 | 9C                                               |                                                 | 1                     |
| RTI                                                                                            | Return from Interrupt                                             | $\begin{array}{l} SP \leftarrow (SP) + 1;  Pull \; (CCR) \\ SP \leftarrow (SP) + 1;  Pull \; (A) \\ SP \leftarrow (SP) + 1;  Pull \; (X) \\ SP \leftarrow (SP) + 1;  Pull \; (PCH) \\ SP \leftarrow (SP) + 1;  Pull \; (PCL) \end{array}$ | ţ | t | ţ           | ţ        | ţ      | ţ | INH                                                 | 80                                               |                                                 | 7                     |
| RTS                                                                                            | Return from Subroutine                                            | $SP \leftarrow SP + 1$ ; Pull (PCH)<br>$SP \leftarrow SP + 1$ ; Pull (PCL)                                                                                                                                                                | - | - | -           | -        | -      | - | INH                                                 | 81                                               |                                                 | 4                     |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X<br>SBC opr,SP<br>SBC opr,SP | Subtract with Carry                                               | $A \leftarrow (A) - (M) - (C)$                                                                                                                                                                                                            | ţ | _ | _           | ţ        | ţ      | ţ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A2<br>B2<br>C2<br>D2<br>E2<br>F2<br>9EE2<br>9ED2 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 23443245              |
| SEC                                                                                            | Set Carry Bit                                                     | C ← 1                                                                                                                                                                                                                                     | - | - | -           | -        | -      | 1 | INH                                                 | 99                                               |                                                 | 1                     |
| SEI                                                                                            | Set Interrupt Mask                                                | l ← 1                                                                                                                                                                                                                                     | - | - | 1           | -        | -      | - | INH                                                 | 9B                                               |                                                 | 2                     |
| STA opr<br>STA opr<br>STA opr,X<br>STA opr,X<br>STA ,X<br>STA opr,SP<br>STA opr,SP             | Store A in M                                                      | M ← (A)                                                                                                                                                                                                                                   | 0 | _ | _           | ţ        | ţ      | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | B7<br>C7<br>D7<br>E7<br>F7<br>9EE7<br>9ED7       | dd<br>hh II<br>ee ff<br>ff<br>ee ff             | 3443245               |
| STHX opr                                                                                       | Store H:X in M                                                    | $(M{:}M+1) \leftarrow (H{:}X)$                                                                                                                                                                                                            | 0 | - | -           | \$       | \$     | - | DIR                                                 | 35                                               | dd                                              | 4                     |
| STOP                                                                                           | Enable Interrupts, Stop Processing,<br>Refer to MCU Documentation | $I \leftarrow 0$ ; Stop Processing                                                                                                                                                                                                        | - | - | 0           | —        | -      | - | INH                                                 | 8E                                               |                                                 | 1                     |
| STX opr<br>STX opr<br>STX opr;X<br>STX opr;X<br>STX,X<br>STX,X<br>STX opr;SP<br>STX opr;SP     | Store X in M                                                      | M ← (X)                                                                                                                                                                                                                                   | 0 | _ | _           | ţ        | ţ      | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | BF<br>CF<br>DF<br>FF<br>9EEF<br>9EDF             | dd<br>hh II<br>ee ff<br>ff<br>ee ff             | 3443245               |
| SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,X<br>SUB opr,SP<br>SUB opr,SP | Subtract                                                          | A ← (A) – (M)                                                                                                                                                                                                                             | ţ | _ | _           | ţ        | ţ      | ţ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A0<br>B0<br>C0<br>D0<br>E0<br>F0<br>9EE0<br>9ED0 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 23443245              |

## Table 7-1. Instruction Set Summary (Sheet 5 of 6)



#### MSCAN08 Controller (MSCAN08)

A double buffer scheme would de-couple the re-loading of the transmit buffers from the actual message being sent and as such reduces the reactiveness requirements on the CPU. Problems may arise if the sending of a message would be finished just while the CPU re-loads the second buffer. In that case, no buffer would then be ready for transmission and the bus would be released.

At least three transmit buffers are required to meet the first of the above requirements under all circumstances. The MSCAN08 has three transmit buffers.

The second requirement calls for some sort of internal prioritization which the MSCAN08 implements with the "local priority" concept described in 12.4.2 Receive Structures.

## 12.4.2 Receive Structures

The received messages are stored in a 2-stage input first in first out (FIFO). The two message buffers are mapped using a "ping pong" arrangement into a single memory area (see Figure 12-3). While the background receive buffer (RxBG) is exclusively associated to the MSCAN08, the foreground receive buffer (RxFG) is addressable by the central processor unit (CPU08). This scheme simplifies the handler software, because only one address area is applicable for the receive process.

Both buffers have a size of 13 bytes to store the CAN control bits, the identifier (standard or extended), and the data content. For details, see 12.12 Programmer's Model of Message Storage.

The receiver full flag (RXF) in the MSCAN08 receiver flag register (CRFLG), signals the status of the foreground receive buffer. When the buffer contains a correctly received message with matching identifier, this flag is set. See 12.13.5 MSCAN08 Receiver Flag Register (CRFLG)

On reception, each message is checked to see if it passes the filter (for details see 12.5 Identifier Acceptance Filter) and in parallel is written into RxBG. The MSCAN08 copies the content of RxBG into RxFG<sup>(1)</sup>, sets the RXF flag, and generates a receive interrupt to the CPU<sup>(2)</sup>. The user's receive handler has to read the received message from RxFG and to reset the RXF flag to acknowledge the interrupt and to release the foreground buffer. A new message which can follow immediately after the IFS field of the CAN frame, is received into RxBG. The overwriting of the background buffer is independent of the identifier filter function.

When the MSCAN08 module is transmitting, the MSCAN08 receives its own messages into the background receive buffer, RxBG. It does NOT overwrite RxFG, generate a receive interrupt or acknowledge its own messages on the CAN bus. The exception to this rule is in loop-back mode (see 12.13.2 MSCAN08 Module Control Register 1), where the MSCAN08 treats its own messages exactly like all other incoming messages. The MSCAN08 receives its own transmitted messages in the event that it loses arbitration. If arbitration is lost, the MSCAN08 must be prepared to become the receiver.

An overrun condition occurs when both the foreground and the background receive message buffers are filled with correctly received messages with accepted identifiers and another message is correctly received from the bus with an accepted identifier. The latter message will be discarded and an error interrupt with overrun indication will be generated if enabled. The MSCAN08 is still able to transmit messages with both receive message buffers filled, but all incoming messages are discarded.

<sup>1.</sup> Only if the RXF flag is not set.

<sup>2.</sup> The receive interrupt will occur only if not masked. A polling scheme can be applied on RXF also.



#### **MSCAN08 Controller (MSCAN08)**



Figure 12-7. Sleep Request/Acknowledge Cycle

After wakeup, the MSCAN08 waits for 11 consecutive recessive bits to synchronize to the bus. As a consequence, if the MSCAN08 is woken-up by a CAN frame, this frame is not received. The receive message buffers (RxFG and RxBG) contain messages if they were received before sleep mode was entered. All pending actions are executed upon wakeup: copying of RxBG into RxFG, message aborts and message transmissions. If the MSCAN08 is still in bus-off state after sleep mode was left, it continues counting the 128\*11 consecutive recessive bits.

### 12.8.2 MSCAN08 Soft Reset Mode

In soft reset mode, the MSCAN08 is stopped. Registers can still be accessed. This mode is used to initialize the module configuration, bit timing and the CAN message filter. See 12.13.1 MSCAN08 Module Control Register 0 for a complete description of the soft reset mode.

When setting the SFTRES bit, the MSCAN08 immediately stops all ongoing transmissions and receptions, potentially causing CAN protocol violations.

NOTE

The user is responsible to take care that the MSCAN08 is not active when soft reset mode is entered. The recommended procedure is to bring the MSCAN08 into sleep mode before the SFTRES bit is set.

### 12.8.3 MSCAN08 Power-Down Mode

The MSCAN08 is in power-down mode when the CPU is in stop mode.

When entering the power-down mode, the MSCAN08 immediately stops all ongoing transmissions and receptions, potentially causing CAN protocol violations.

#### NOTE

The user is responsible to take care that the MSCAN08 is not active when power-down mode is entered. The recommended procedure is to bring the MSCAN08 into sleep mode before the STOP instruction is executed.



## 12.13 Programmer's Model of Control Registers

The programmer's model has been laid out for maximum simplicity and efficiency. Figure 12-15 gives an overview on the control register block of the MSCAN08.

| Addr.  | Register |                 | Bit 7  | 6           | 5      | 4      | 3      | 2          | 1      | Bit 0  |
|--------|----------|-----------------|--------|-------------|--------|--------|--------|------------|--------|--------|
| \$0500 | CMCR0    | Read:<br>Write: | 0      | 0           | 0      | SYNCH  | TLNKEN | SLPAK      | SLPRQ  | SFTRES |
| \$0501 | CMCR1    | Read:           | 0      | 0           | 0      | 0      | 0      | LOOPB      | WUPM   | CLKSRC |
| \$0502 | CBTR0    | Read:<br>Write: | SJW1   | SJW0        | BRP5   | BRP4   | BRP3   | BRP2       | BRP1   | BRP0   |
| \$0503 | CBTR1    | Read:<br>Write: | SAMP   | TSEG22      | TSEG21 | TSEG20 | TSEG13 | TSEG12     | TSEG11 | TSEG10 |
| \$0504 | CRFLG    | Read:<br>Write: | WUPIF  | RWRNIF      | TWRNIF | RERRIF | TERRIF | BOFFIF     | OVRIF  | RXF    |
| \$0505 | CRIER    | Read:<br>Write: | WUPIE  | RWRNIE      | TWRNIE | RERRIE | TERRIE | BOFFIE     | OVRIE  | RXFIE  |
| \$0506 | CTFLG    | Read:<br>Write: | 0      | ABTAK2      | ABTAK1 | ABTAK0 | 0      | TXE2       | TXE1   | TXE0   |
| \$0507 | CTCR     | Read:<br>Write: | 0      | ABTRQ2      | ABTRQ1 | ABTRQ0 | 0      | TXEIE2     | TXEIE1 | TXEIE0 |
| \$0508 | CIDAC    | Read:<br>Write: | 0      | 0           | IDAM1  | IDAM0  | 0      | 0          | IDHIT1 | IDHIT0 |
| \$0509 | Reserved | Read:<br>Write: | R      | R           | R      | R      | R      | R          | R      | R      |
| \$050E | CRXERR   | Read:<br>Write: | RXERR7 | RXERR6      | RXERR5 | RXERR4 | RXERR3 | RXERR2     | RXERR1 | RXERR0 |
| \$050F | CTXERR   | Read:<br>Write: | TXERR7 | TXERR6      | TXERR5 | TXERR4 | TXERR3 | TXERR2     | TXERR1 | TXERR0 |
| \$0510 | CIDAR0   | Read:<br>Write: | AC7    | AC6         | AC5    | AC4    | AC3    | AC2        | AC1    | AC0    |
| \$0511 | CIDAR1   | Read:<br>Write: | AC7    | AC6         | AC5    | AC4    | AC3    | AC2        | AC1    | AC0    |
|        |          |                 |        | = Unimpleme | ented  |        | R      | = Reserved |        |        |

## Figure 12-15. MSCAN08 Control Register Structure



Figure 13-4 shows the port A I/O logic.



Figure 13-4. Port A I/O Circuit

When bit DDRAx is a logic 1, reading address \$0000 reads the PTAx data latch. When bit DDRAx is a logic 0, reading address \$0000 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. Table 13-2 summarizes the operation of the port A pins.

Table 13-2. Port A Pin Functions

| PTAPUE | DDRA | ΡΤΑ              | I/O Pin                               | Accesses to DDRA | Accesses to PTA |                          |  |  |
|--------|------|------------------|---------------------------------------|------------------|-----------------|--------------------------|--|--|
| Bit    | Bit  | Bit              | Mode                                  | Read/Write       | Read            | Write                    |  |  |
| 1      | 0    | X <sup>(1)</sup> | Input, V <sub>DD</sub> <sup>(2)</sup> | DDRA7-DDRA0      | Pin             | PTA7–PTA0 <sup>(3)</sup> |  |  |
| 0      | 0    | Х                | Input, Hi-Z <sup>(4)</sup>            | DDRA7-DDRA0      | Pin             | PTA7–PTA0 <sup>(3)</sup> |  |  |
| Х      | 1    | Х                | Output                                | DDRA7-DDRA0      | PTA7–PTA0       | PTA7-PTA0                |  |  |

1. X = Don't care

2. I/O pin pulled up to  $V_{\mbox{\scriptsize DD}}$  by internal pullup device

3. Writing affects data register, but does not affect input.

4. Hi-Z = High impedance

## 13.3.3 Port A Input Pullup Enable Register

The port A input pullup enable register (PTAPUE) contains a software configurable pullup device for each of the eight port A pins. Each bit is individually configurable and requires that the data direction register, DDRA, bit be configured as an input. Each pullup is automatically and dynamically disabled when a port bit's DDRA is configured for output mode.



Figure 13-5. Port A Input Pullup Enable Register (PTAPUE)



Input/Output (I/O) Ports

## 13.5.3 Port C Input Pullup Enable Register

The port C input pullup enable register (PTCPUE) contains a software configurable pullup device for each of the seven port C pins. Each bit is individually configurable and requires that the data direction register, DDRC, bit be configured as an input. Each pullup is automatically and dynamically disabled when a port bit's DDRC is configured for output mode.





### PTCPUE6–PTCPUE0 — Port C Input Pullup Enable Bits

These writable bits are software programmable to enable pullup devices on an input port bit.

- 1 = Corresponding port C pin configured to have internal pullup
- 0 = Corresponding port C pin internal pullup disconnected

## 13.6 Port D

Port D is an 8-bit special-function port that shares four of its pins with the serial peripheral interface (SPI) module and four of its pins with the two timer interface (TIM1 and TIM2) modules. Port D also has software configurable pullup devices if configured as an input port.

## 13.6.1 Port D Data Register

The port D data register (PTD) contains a data latch for each of the eight port D pins.



Figure 13-13. Port D Data Register (PTD)

### PTD7-PTD0 — Port D Data Bits

These read/write bits are software-programmable. Data direction of each port D pin is under the control of the corresponding bit in data direction register D. Reset has no effect on port D data.

### T2CH1 and T2CH0 — Timer 2 Channel I/O Bits

The PTD7/T2CH1–PTD6/T2CH0 pins are the TIM2 input capture/output compare pins. The edge/level select bits, ELSxB:ELSxA, determine whether the PTD7/T2CH1–PTD6/T2CH0 pins are timer channel I/O pins or general-purpose I/O pins. See Chapter 19 Timer Interface Module (TIM).



#### **Functional Description**

| Addr.                                                     | Register Name                      |                 | Bit 7   | 6               | 5          | 4         | 3          | 2                 | 1      | Bit 0 |
|-----------------------------------------------------------|------------------------------------|-----------------|---------|-----------------|------------|-----------|------------|-------------------|--------|-------|
| \$0009                                                    | ESCI Prescaler Register<br>(SCPSC) | Read:<br>Write: | PDS2    | PDS1            | PDS0       | PSSB4     | PSSB3      | PSSB2             | PSSB1  | PSSB0 |
|                                                           | See page 206.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
|                                                           | ESCI Arbiter Control               | Read:           | A 1 4 1 | ALOST           | 4140       |           | AFIN       | ARUN              | AROVFL | ARD8  |
| \$000A                                                    | \$000A Register (SCIACTL)          | Write:          | AIVIT   |                 | Alvio      | AULK      |            |                   |        |       |
|                                                           | See page 209.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
| ESCI Arbiter                                              | ESCI Arbiter Data                  | Read:           | ARD7    | ARD6            | ARD5       | ARD4      | ARD3       | ARD2              | ARD1   | ARD0  |
| \$000B                                                    | Register (SCIADAT)                 | Write:          |         |                 |            |           |            |                   |        |       |
|                                                           | See page 210.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
| ESCI Control Register 1<br>\$0013 (SCC1)                  | Read:<br>Write:                    | LOOPS           | ENSCI   | TXINV           | М          | WAKE      | ILTY       | PEN               | PTY    |       |
|                                                           | See page 196.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
| ESCI Control Register 2<br>\$0014 (SCC2)<br>See page 198. | Read:<br>Write:                    | SCTIE           | TCIE    | SCRIE           | ILIE       | TE        | RE         | RWU               | SBK    |       |
|                                                           | See page 198.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
| FSC                                                       | ESCI Control Begister 3            | Read:           | R8      | то              | Р          | Р         |            | NEIE              | EEIE   | DEIE  |
| \$0015                                                    | (SCC3)                             | Write:          |         | 10              | n          | n         | ONIE       | INCIE             | FEIE   | FLIC  |
|                                                           | See page 200.                      | Reset:          | U       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
|                                                           | ESCI Status Register 1             | Read:           | SCTE    | TC              | SCRF       | IDLE      | OR         | NF                | FE     | PE    |
| \$0016                                                    | (SCS1)                             | Write:          |         |                 |            |           |            |                   |        |       |
|                                                           | See page 201.                      | Reset:          | 1       | 1               | 0          | 0         | 0          | 0                 | 0      | 0     |
|                                                           | ESCI Status Register 2             | Read:           | 0       | 0               | 0          | 0         | 0          | 0                 | BKF    | RPF   |
| \$0017                                                    | (SCS2)<br>See page 203             | Write:          |         |                 |            |           |            |                   |        |       |
|                                                           | See page 203.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
|                                                           | ESCI Data Register                 | Read:           | R7      | R6              | R5         | R4        | R3         | R2                | R1     | R0    |
| \$0018                                                    | (SCDR)<br>See page 204             | Write:          | T7      | Т6              | T5         | T4        | Т3         | T2                | T1     | Т0    |
|                                                           | 000 page 204.                      | Reset:          |         | 1               | . <u> </u> | Unaffecte | d by reset |                   |        |       |
| ESCI<br>\$0019                                            | ESCI Baud Rate Register<br>(SCBR)  | Read:<br>Write: | LINT    | LINR            | SCP1       | SCP0      | R          | SCR2              | SCR1   | SCR0  |
|                                                           | See page 204.                      | Reset:          | 0       | 0               | 0          | 0         | 0          | 0                 | 0      | 0     |
|                                                           |                                    |                 |         | = Unimplemented |            | R         | = Reserved | ed U = Unaffected |        |       |

Figure 15-3. ESCI I/O Register Summary



The maximum percent difference between the receiver count and the transmitter count of a slow 9-bit character with no errors is:

$$\frac{170 - 163}{170} \times 100 = 4.12\%$$

### **Fast Data Tolerance**

Figure 15-9 shows how much a fast received character can be misaligned without causing a noise error or a framing error. The fast stop bit ends at RT10 instead of RT16 but is still there for the stop bit data samples at RT8, RT9, and RT10.



Figure 15-9. Fast Data

For an 8-bit character, data sampling of the stop bit takes the receiver9 bit times  $\times$  16 RT cycles + 10 RT cycles = 154 RT cycles.

With the misaligned character shown in Figure 15-9, the receiver counts 154 RT cycles at the point when the count of the transmitting device is 10 bit times  $\times$  16 RT cycles = 160 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 8-bit character with no errors is

$$\frac{154 - 160}{154} \times 100 = 3.90\%.$$

For a 9-bit character, data sampling of the stop bit takes the receiver 10 bit times  $\times$  16 RT cycles + 10 RT cycles = 170 RT cycles.

With the misaligned character shown in Figure 15-9, the receiver counts 170 RT cycles at the point when the count of the transmitting device is 11 bit times  $\times$  16 RT cycles = 176 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 9-bit character with no errors is:

$$\left|\frac{170 - 176}{170}\right| \times 100 = 3.53\%.$$

#### 15.4.3.6 Receiver Wakeup

So that the MCU can ignore transmissions intended only for other receivers in multiple-receiver systems, the receiver can be put into a standby state. Setting the receiver wakeup bit, RWU, in SCC2 puts the receiver into a standby state during which receiver interrupts are disabled.



#### Timer Interface Module (TIM)

If TIM functions are not required during wait mode, reduce power consumption by stopping the TIM before executing the WAIT instruction.

### 19.6.2 Stop Mode

The TIM is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions or the state of the TIM counter. TIM operation resumes when the MCU exits stop mode after an external interrupt.

## **19.7 TIM During Break Interrupts**

A break interrupt stops the TIM counter.

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. See 16.7.3 Break Flag Control Register.

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect status bits during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a 2-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

## 19.8 I/O Signals

Port D shares four of its pins with the TIM. The four TIM channel I/O pins are T1CH0, T1CH1, T2CH0, and T2CH1 as described in 19.3 Pin Name Conventions.

Each channel I/O pin is programmable independently as an input capture pin or an output compare pin. T1CH0 and T2CH0 can be configured as buffered output compare or buffered PWM pins.

## 19.9 I/O Registers

#### NOTE

References to either timer 1 or timer 2 may be made in the following text by omitting the timer number. For example, TSC may generically refer to both T1SC AND T2SC.

These I/O registers control and monitor operation of the TIM:

- TIM status and control register (TSC)
- TIM counter registers (TCNTH:TCNTL)
- TIM counter modulo registers (TMODH:TMODL)
- TIM channel status and control registers (TSC0 and TSC1)
- TIM channel registers (TCH0H:TCH0L, TCH1H:TCH1L)



# Chapter 20 Development Support

## 20.1 Introduction

This section describes the break module, the monitor read-only memory (MON), and the monitor mode entry methods.

## 20.2 Break Module (BRK)

The break module can generate a break interrupt that stops normal program flow at a defined address to enter a background program.

Features of the break module include:

- Accessible input/output (I/O) registers during the break Interrupt
- Central processor unit (CPU) generated break interrupts
- Software-generated break interrupts
- Computer operating properly (COP) disabling during break interrupts

## 20.2.1 Functional Description

When the internal address bus matches the value written in the break address registers, the break module issues a breakpoint signal (BKPT) to the system integration module (SIM). The SIM then causes the CPU to load the instruction register with a software interrupt instruction (SWI). The program counter vectors to \$FFFC and \$FFFD (\$FEFC and \$FEFD in monitor mode).

The following events can cause a break interrupt to occur:

- A CPU generated address (the address in the program counter) matches the contents of the break address registers.
- Software writes a logic 1 to the BRKA bit in the break status and control register.

When a CPU generated address matches the contents of the break address registers, the break interrupt is generated. A return-from-interrupt instruction (RTI) in the break routine ends the break interrupt and returns the microcontroller unit (MCU) to normal operation.

Figure 20-1 shows the structure of the break module.

Figure 20-2 provides a summary of the I/O registers.



#### **Electrical Specifications**

| Characteristic <sup>(1)</sup>                                                                                 | Symbol              | Min                   | Тур <sup>(2)</sup> | Мах                   | Unit |
|---------------------------------------------------------------------------------------------------------------|---------------------|-----------------------|--------------------|-----------------------|------|
| Monitor mode entry voltage                                                                                    | V <sub>TST</sub>    | V <sub>DD</sub> + 2.5 |                    | V <sub>DD</sub> + 4.0 | V    |
| Low-voltage inhibit, trip falling voltage                                                                     | V <sub>TRIPF</sub>  | 2.35                  | 2.6                | 2.7                   | V    |
| Low-voltage inhibit, trip rising voltage                                                                      | V <sub>TRIPR</sub>  | 2.4                   | 2.66               | 2.8                   | V    |
| Low-voltage inhibit reset/recover hysteresis<br>(V <sub>TRIPF</sub> + V <sub>HYS</sub> = V <sub>TRIPR</sub> ) | V <sub>HYS</sub>    | _                     | 100                | _                     | mV   |
| POR rearm voltage <sup>(12)</sup>                                                                             | V <sub>POR</sub>    | 0                     |                    | 100                   | mV   |
| POR reset voltage <sup>(13)</sup>                                                                             | V <sub>PORRST</sub> | 0                     | 700                | 800                   | mV   |
| POR rise time ramp rate <sup>(14)</sup>                                                                       | R <sub>POR</sub>    | 0.035                 | _                  | _                     | V/ms |

1.  $V_{DD}$  = 3.3 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_A$  (min) to  $T_A$  (max), unless otherwise noted

2. Typical values reflect average measurements at midpoint of voltage range, 25°C only.

 Run (operating) I<sub>DD</sub> measured using external square wave clock source (f<sub>OSC</sub> = 16 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects run I<sub>DD</sub>. Measured with all modules enabled.

4. Wait I<sub>DD</sub> measured using external square wave clock source ( $f_{OSC} = 16$  MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait I<sub>DD</sub>. Measured with CGM and LVI enabled.

Stop I<sub>DD</sub> is measured with OSC1 = V<sub>SS</sub>. All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. All ports configured as inputs. Typical values at midpoint of voltage range, 25°C only.

6. Stop I<sub>DD</sub> with TBM enabled is measured using an external square wave clock source (f<sub>OSC</sub> = 4 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. All inputs configured as inputs.

7. This parameter is characterized and not tested on each device.

8. All functional non-supply pins are internally clamped to  $V_{SS}$  and  $V_{DD}$ .

9. Input must be current limited to the value specified. To determine the value of the required current-limiting resistor, calculate resistance values for positive and negative clamp voltages, then use the larger of the two values.

10. Power supply must maintain regulation within operating V<sub>DD</sub> range during instantaneous and operating maximum current conditions. If positive injection current (V<sub>in</sub> > V<sub>DD</sub>) is greater than I<sub>DD</sub>, the injection current may flow out of V<sub>DD</sub> and could result in external power supply going out of regulation. Ensure external V<sub>DD</sub> load will shunt current greater than maximum injection current. This will be the greatest risk when the MCU is not consuming power. Examples are: if no system clock is present, or if clock rate is very low (which would reduce overall power consumption).

11. Pullups and pulldowns are disabled.

12. Maximum is highest voltage that POR is guaranteed.

13. Maximum is highest voltage that POR is possible.

14. If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, RST must be driven low ext ernally until minimum V<sub>DD</sub> is reached.



**Electrical Specifications** 

## 21.11 3.3-Volt ADC Characteristics

| Characteristic <sup>(1)</sup>                 | Symbol            | Min               | Max               | Unit                    | Comments                                                                         |
|-----------------------------------------------|-------------------|-------------------|-------------------|-------------------------|----------------------------------------------------------------------------------|
| Supply voltage                                | V <sub>DDAD</sub> | 3.0               | 3.6               | V                       | $V_{DDAD}$ should be tied to the same potential as $V_{DD}$ via separate traces. |
| Input voltages                                | V <sub>ADIN</sub> | 0                 | V <sub>DDAD</sub> | V                       | V <sub>ADIN</sub> <= V <sub>DDAD</sub>                                           |
| Resolution                                    | B <sub>AD</sub>   | 10                | 10                | Bits                    |                                                                                  |
| Absolute accuracy                             | A <sub>AD</sub>   | -6                | +6                | LSB                     | Includes quantization                                                            |
| ADC internal clock                            | f <sub>ADIC</sub> | 500 k             | 1.048 M           | Hz                      | $t_{AIC} = 1/f_{ADIC}$                                                           |
| Conversion range                              | R <sub>AD</sub>   | V <sub>SSAD</sub> | V <sub>DDAD</sub> | V                       |                                                                                  |
| Power-up time                                 | t <sub>ADPU</sub> | 16                | —                 | t <sub>AIC</sub> cycles |                                                                                  |
| Conversion time                               | t <sub>ADC</sub>  | 16                | 17                | t <sub>AIC</sub> cycles |                                                                                  |
| Sample time                                   | t <sub>ADS</sub>  | 5                 | —                 | t <sub>AIC</sub> cycles |                                                                                  |
| Monotonicity                                  | M <sub>AD</sub>   |                   |                   | Guaranteed              |                                                                                  |
| Zero input reading                            | Z <sub>ADI</sub>  | 000               | 005               | Hex                     | $V_{ADIN} = V_{SSA}$                                                             |
| Full-scale reading                            | F <sub>ADI</sub>  | 3FA               | 3FF               | Hex                     | $V_{ADIN} = V_{DDA}$                                                             |
| Input capacitance                             | C <sub>ADI</sub>  | —                 | 30                | pF                      | Not tested                                                                       |
| V <sub>DDAD</sub> /V <sub>REFH</sub> current  | I <sub>VREF</sub> | _                 | 1.2               | mA                      |                                                                                  |
| Absolute accuracy<br>(8-bit truncation mode)  | A <sub>AD</sub>   | -1                | +1                | LSB                     | Includes quantization                                                            |
| Quantization error<br>(8-bit truncation mode) | _                 | -1/8              | +7/8              | LSB                     |                                                                                  |

1.  $V_{DD}$  = 3.3 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $V_{DDAD/VREFH}$  = 3.3 Vdc  $\pm$  10%,  $V_{SSAD}/V_{REFL}$  = 0 Vdc