

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               | I <sup>2</sup> C, IRSCI, SCI, SPI                           |
| Peripherals                | LED, LVD, POR, PWM                                          |
| Number of I/O              | 32                                                          |
| Program Memory Size        | 32KB (32K x 8)                                              |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | -                                                           |
| RAM Size                   | 2K x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                 |
| Data Converters            | A/D 8x10b                                                   |
| Oscillator Type            | Internal                                                    |
| Operating Temperature      | -40°C ~ 85°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=mc908ap32cfaer |

Email: info@E-XFL.COM

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



#### Table of Contents

| 22.13 | MMIIC Electrical Characteristics | 307 |
|-------|----------------------------------|-----|
| 22.14 | CGM Electrical Specification     | 309 |
| 22.15 | 5V SPI Characteristics           | 310 |
| 22.16 | 3V SPI Characteristics           | 311 |
| 22.17 | Memory Characteristics           | 314 |

# Chapter 23 Mechanical Specifications

| 23.1 | Introduction                              | 315 |
|------|-------------------------------------------|-----|
| 23.2 | 48-Pin Low-Profile Quad Flat Pack (LQFP)  | 316 |
| 23.3 | 44-Pin Quad Flat Pack (QFP)               | 317 |
| 23.4 | 42-Pin Shrink Dual In-Line Package (SDIP) | 318 |

# Chapter 24 Ordering Information

| 24.1 | Introduction     | 319 |
|------|------------------|-----|
| 24.2 | MC Order Numbers | 319 |



\_\_\_\_\_

**Monitor ROM** 

| Keyboard Status and Control<br>Rogister<br>(KBSCR)<br>S001B         Register<br>Register<br>(KBIER)<br>Enable Register<br>(KBIER)<br>Enable Register<br>(KBIER)<br>Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                             | Addr.     | Register Name                             |                 | Bit 7            | 6                      | 5               | 4          | 3       | 2     | 1          | Bit 0    |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|-------------------------------------------|-----------------|------------------|------------------------|-----------------|------------|---------|-------|------------|----------|
| S01A         Register         Write<br>(KBSCR)         Reset<br>Reset         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0        <                                                                                                                                                                                                                                                                          |           | Keyboard Status and Control               | Read:           | 0                | 0                      | 0               | 0          | KEYF    | 0     | IMASK      | MODE     |
| (KBSCH)         Reast:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <t< td=""><td>\$001A</td><td>Register</td><td>Write:</td><td></td><td></td><td></td><td></td><td></td><td>ACK</td><td></td><td>MODE</td></t<>                                                                                                                                                      | \$001A    | Register                                  | Write:          |                  |                        |                 |            |         | ACK   |            | MODE     |
| Keyboard Interrupt<br>Enable Register         KBIE2         KBIE4         KBIE3         KBIE2         KBIE1         KBIE0           S001B         Enable Register<br>(KBIE3)         Write:<br>(KBIE4)         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                      |           | (KBSCR)                                   | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| IRQ2 Status and Control Reg.<br>S001D         Reset:<br>IRQ2 Status and Control Reg.<br>(INTSCR2)         Reset:<br>Reset:<br>(INTSCR2)         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <td>\$001B</td> <td>Keyboard Interrupt<br/>Enable Register</td> <td>Read:<br/>Write:</td> <td>KBIE7</td> <td>KBIE6</td> <td>KBIE5</td> <td>KBIE4</td> <td>KBIE3</td> <td>KBIE2</td> <td>KBIE1</td> <td>KBIE0</td>                   | \$001B    | Keyboard Interrupt<br>Enable Register     | Read:<br>Write: | KBIE7            | KBIE6                  | KBIE5           | KBIE4      | KBIE3   | KBIE2 | KBIE1      | KBIE0    |
| IRQ2 Status and Control Reg.<br>ister         Read:<br>ister         0         0         IRQ2F         0         IMASK2         MODE2           S001D         Configuration Register 2<br>(INTSCR)         Read:<br>Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                            |           | (KBIER)                                   | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| S001C         ister         Write:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                  |           | IRQ2 Status and Control Reg-              | Read:           | 0                |                        | 0               | 0          | IRQ2F   | 0     | IMASK2     |          |
| INTSCR2         Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0 <t< td=""><td>\$001C</td><td>ister</td><td>Write:</td><td></td><td>TOODEND</td><td></td><td></td><td></td><td>ACK2</td><td></td><td>MODEL</td></t<>                                                                                                                                                | \$001C    | ister                                     | Write:          |                  | TOODEND                |                 |            |         | ACK2  |            | MODEL    |
| Sool D         Configuration Register 2<br>(CONFIG2) <sup>†</sup> Read:<br>Reset:         STOP_<br>ICLKDIS         STOP_<br>RCLKEN         OSCCLKI         OSC                            |           | (INTSCR2)                                 | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| Lock Higg         Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                  | \$001D    | Configuration Register 2                  | Read:<br>Write: | STOP_<br>ICLKDIS | STOP_<br>RCLKEN        | STOP_<br>XCLKEN | OSCCLK1    | OSCCLK0 | 0     | 0          | SCIBDSRC |
| ↑ One-time writable register after each reset.       IRQ1 Status and Control Register if ister right write:       Read: (INTSCR)       0       0       0       IRQ1F       0       IMASK1       MODE1         \$001E       (INTSCR)       Read: (INTSCR)       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                  |           | (CONFIG2)                                 | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| IR01 Status and Control Register<br>(INTSCRI)         Read:<br>(INTSCRI)         0         0         0         0         IR01F         0         IMASK1         MODE1           \$001E         (INTSCRI)         Read:<br>(INTSCRI)         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                       | † One-tin | ne writable register after each re        | eset.           |                  |                        |                 |            |         |       |            |          |
| \$001E         ister         Write:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                 |           | IRQ1 Status and Control Reg-              | Read:           | 0                | 0                      | 0               | 0          | IRQ1F   | 0     |            |          |
| (INTSCR1)         Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                  | \$001E    | ister                                     | Write:          |                  |                        |                 |            |         | ACK1  | INASKI     | MODET    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           | (INTSCR1)                                 | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| (bork hold)         Reset:         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0         0                                                                                                                                                                                                                                                                                                | \$001F    | Configuration Register 1                  | Read:<br>Write: | COPRS            | LVISTOP                | LVIRSTD         | LVIPWRD    | LVIREGD | SSREC | STOP       | COPD     |
| $ \begin{tabular}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |           |                                           | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | † One-tir | ne writable register after each re        | eset.           |                  |                        |                 |            |         |       |            |          |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0020    | Timer 1 Status and<br>Control Register    | Read:<br>Write: | TOF<br>0         | TOIE                   | TSTOP           | 0<br>TRST  | 0       | PS2   | PS1        | PS0      |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           | (T1SC)                                    | Reset:          | 0                | 0                      | 1               | 0          | 0       | 0     | 0          | 0        |
| S0021       Register High<br>(T1CNTH)       Write:<br>Reset:       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                              |           | Timer 1 Counter                           | Read:           | Bit 15           | 14                     | 13              | 12         | 11      | 10    | 9          | Bit 8    |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0021    | Register High                             | Write:          |                  |                        |                 |            |         |       |            |          |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           | (T1CNTH)                                  | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| \$0022       Register Low<br>(T1CNTL)       Write:<br>Reset:       0       0       0       0       0       0       0       0       0         Timer 1 Counter Modulo Reg<br>(T1MODH)       Read:<br>(T1MODH)       Read:<br>(T1MODH)       Bit 15       14       13       12       11       10       9       Bit 8         \$0023       ister High<br>(T1MODH)       Reset:       1       1       1       1       1       1       1         Timer 1 Counter Modulo<br>Register Low<br>(T1MODL)       Read:<br>(T1MODL)       Bit 7       6       5       4       3       2       1       Bit 0         \$0024       Register Low<br>(T1MODL)       Read:<br>(T1MODL)       Bit 7       6       5       4       3       2       1       Bit 0         \$0025       Timer 1 Channel 0 Status and<br>Control Register (T1SCO)       Read:<br>Reset:       CHOF<br>Reset:       CHOIE       MSOB       MSOA       ELSOB       ELSOA       TOV0       CHOMAX         \$0025       U = Unaffected       X = Indeterminate       = Unimplemented       R       = Reserved                                                                                                                                                                                                                                                                                                                                         |           | Timer 1 Counter                           | Read:           | Bit 7            | 6                      | 5               | 4          | 3       | 2     | 1          | Bit 0    |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0022    | Register Low                              | Write:          |                  |                        |                 |            |         |       |            |          |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           | (T1CNTL)                                  | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0023    | Timer 1 Counter Modulo Reg-<br>ister High | Read:<br>Write: | Bit 15           | 14                     | 13              | 12         | 11      | 10    | 9          | Bit 8    |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |           | (T1MODH)                                  | Reset:          | 1                | 1                      | 1               | 1          | 1       | 1     | 1          | 1        |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0024    | Timer 1 Counter Modulo<br>Register Low    | Read:<br>Write: | Bit 7            | 6                      | 5               | 4          | 3       | 2     | 1          | Bit 0    |
| \$0025       Timer 1 Channel 0 Status and Control Register (T1SC0)       Read:       CHOF       MS0B       MS0B       MS0A       ELS0B       ELS0A       TOV0       CH0MAX         \$0025       U = Unaffected       X = Indeterminate       0       0       0       0       0       0       0       0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |           | (T1MODL)                                  | Reset:          | 1                | 1                      | 1               | 1          | 1       | 1     | 1          | 1        |
| Status and Control Register (T1SC0)       Write:       O       CHOIE       MS0B       MS0A       ELS0B       ELS0A       TOV0       CHOMAX         U = Unaffected       U = Unaffected       X = Indeterminate       U = Unimplemented       R       = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           |                                           | Read:           | CH0F             | <b>0</b> 1151 <b>-</b> |                 |            |         |       |            |          |
| Control Register (11500)       Control Register (11500)       Control Register (11500)       Control Register (11500)         Reset:       0       0       0       0       0       0       0         U = Unaffected       X = Indeterminate       Image: Control Register (11500)       Endeterminate       Endeterminate | \$0025    | Timer 1 Channel 0 Status and              | Write:          | 0                | CH0IE                  | MS0B            | MS0A       | ELS0B   | ELS0A | ΤΟΥΟ       | CH0MAX   |
| U = Unaffected X = Indeterminate = Unimplemented R = Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |           | Control Register (11500)                  | Reset:          | 0                | 0                      | 0               | 0          | 0       | 0     | 0          | 0        |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |           | U = Unaffected                            |                 | X = Indeterm     | ninate                 |                 | = Unimplem | ented   | R     | = Reserved |          |

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



## Table 4-1. Instruction Set Summary

| Source                                                                                                | Operation                     | Description                                                                                                                                                                                                                                                                                                                                         |   |   | ffe<br>C | ct (<br>CR | on |   | dress<br>ode                                        | code                                             | erand                                           | rcles                           |
|-------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|------------|----|---|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|---------------------------------|
| FOIII                                                                                                 |                               |                                                                                                                                                                                                                                                                                                                                                     | v | н | I        | Ν          | z  | С | Ρq<br>Ad                                            | ď                                                | ŏ                                               | С<br>О                          |
| BSR rel                                                                                               | Branch to Subroutine          | $\begin{array}{l} PC \leftarrow (PC) + 2;  push  (PCL) \\ SP \leftarrow (SP) - 1;  push  (PCH) \\ SP \leftarrow (SP) - 1 \\ PC \leftarrow (PC) + \mathit{rel} \end{array}$                                                                                                                                                                          | _ | _ | _        | _          | _  | _ | REL                                                 | AD                                               | rr                                              | 4                               |
| CBEQ opr,rel<br>CBEQA #opr,rel<br>CBEQX #opr,rel<br>CBEQ opr,X+,rel<br>CBEQ X+,rel<br>CBEQ opr,SP,rel | Compare and Branch if Equal   | $\begin{array}{l} PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (X) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 2 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 4 + rel ? (A) - (M) = \$00 \end{array}$       | _ | _ | _        | _          | _  | _ | DIR<br>IMM<br>IMM<br>IX1+<br>IX+<br>SP1             | 31<br>41<br>51<br>61<br>71<br>9E61               | dd rr<br>ii rr<br>ii rr<br>ff rr<br>rr<br>ff rr | 5<br>4<br>5<br>4<br>6           |
| CLC                                                                                                   | Clear Carry Bit               | $C \leftarrow 0$                                                                                                                                                                                                                                                                                                                                    | - | - | -        | -          | -  | 0 | INH                                                 | 98                                               |                                                 | 1                               |
| CLI                                                                                                   | Clear Interrupt Mask          | l ← 0                                                                                                                                                                                                                                                                                                                                               | - | - | 0        | -          | -  | - | INH                                                 | 9A                                               |                                                 | 2                               |
| CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR opr,SP                                  | Clear                         | $\begin{array}{c} M \leftarrow \$00\\ A \leftarrow \$00\\ X \leftarrow \$00\\ H \leftarrow \$00\\ M \leftarrow \$00\\ \end{array}$                                                                                                                                  | 0 | _ | _        | 0          | 1  | _ | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1        | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F         | dd<br>ff<br>ff                                  | 3<br>1<br>1<br>3<br>2<br>4      |
| CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP ,X<br>CMP opr,SP<br>CMP opr,SP        | Compare A with M              | (A) – (M)                                                                                                                                                                                                                                                                                                                                           | o | _ | _        | 0          | 0  | 0 | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A1<br>B1<br>C1<br>E1<br>F1<br>9EE1<br>9ED1       | ii<br>dd<br>hh ll<br>ee ff<br>ff<br>ee ff       | 2<br>3<br>4<br>3<br>2<br>4<br>5 |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X<br>COM opr,SP                                          | Complement (One's Complement) | $\begin{split} M \leftarrow (\overline{M}) &= \$FF - (M) \\ A \leftarrow (\overline{A}) &= \$FF - (M) \\ X \leftarrow (\overline{X}) &= \$FF - (M) \\ M \leftarrow (\overline{M}) &= \$FF - (M) \end{split}$ | 0 | _ | _        | 0          | 0  | 1 | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 33<br>43<br>53<br>63<br>73<br>9E63               | dd<br>ff<br>ff                                  | 4<br>1<br>4<br>3<br>5           |
| CPHX # <i>opr</i><br>CPHX <i>opr</i>                                                                  | Compare H:X with M            | (H:X) – (M:M + 1)                                                                                                                                                                                                                                                                                                                                   | o | - | -        | o          | 0  | 0 | IMM<br>DIR                                          | 65<br>75                                         | ii ii+1<br>dd                                   | 3<br>4                          |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX ,X<br>CPX opr,X<br>CPX opr,X<br>CPX opr,SP<br>CPX opr,SP        | Compare X with M              | (X) – (M)                                                                                                                                                                                                                                                                                                                                           | o | _ | _        | 0          | 0  | 0 | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A3<br>B3<br>C3<br>D3<br>E3<br>F3<br>9EE3<br>9ED3 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff       | 2<br>3<br>4<br>3<br>2<br>4<br>5 |
| DAA                                                                                                   | Decimal Adjust A              | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                                                                   | υ | - | -        | 0          | 0  | 0 | INH                                                 | 72                                               |                                                 | 2                               |



## 6.3.5 Manual and Automatic PLL Bandwidth Modes

The PLL can change the bandwidth or operational mode of the loop filter manually or automatically. Automatic mode is recommended for most users.

In automatic bandwidth control mode (AUTO = 1), the lock detector automatically switches between acquisition and tracking modes. Automatic bandwidth control mode also is used to determine when the VCO clock, CGMVCLK, is safe to use as the source for the base clock, CGMOUT. (See 6.5.2 PLL Bandwidth Control Register.) If PLL interrupts are enabled, the software can wait for a PLL interrupt request and then check the LOCK bit. If interrupts are disabled, software can poll the LOCK bit continuously (during PLL start-up, usually) or at periodic intervals. In either case, when the LOCK bit is set, the VCO clock is safe to use as the source for the base clock. (See 6.3.8 Base Clock Selector Circuit.) If the VCO is selected as the source for the base clock and the LOCK bit is clear, the PLL has suffered a severe noise hit and the software must take appropriate action, depending on the application. (See 6.6 Interrupts for information and precautions on using interrupts.)

The following conditions apply when the PLL is in automatic bandwidth control mode:

- The ACQ bit (See 6.5.2 PLL Bandwidth Control Register.) is a read-only indicator of the mode of the filter. (See 6.3.4 Acquisition and Tracking Modes.)
- The ACQ bit is set when the VCO frequency is within a certain tolerance and is cleared when the VCO frequency is out of a certain tolerance. (See 6.8 Acquisition/Lock Time Specifications for more information.)
- The LOCK bit is a read-only indicator of the locked state of the PLL.
- The LOCK bit is set when the VCO frequency is within a certain tolerance and is cleared when the VCO frequency is out of a certain tolerance. (See 6.8 Acquisition/Lock Time Specifications for more information.)
- CPU interrupts can occur if enabled (PLLIE = 1) when the PLL's lock condition changes, toggling the LOCK bit. (See 6.5.1 PLL Control Register.)

The PLL also may operate in manual mode (AUTO = 0). Manual mode is used by systems that do not require an indicator of the lock condition for proper operation. Such systems typically operate well below  $f_{BUSMAX}$ .

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 6.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.

## 6.3.6 Programming the PLL

The following procedure shows how to program the PLL.

#### NOTE

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



#### **Clock Generator Module (CGM)**

VCO clock frequency is corrupt, and appropriate precautions should be taken. If the application is not frequency sensitive, interrupts should be disabled to prevent PLL interrupt service routines from impeding software performance or from exceeding stack limitations.

NOTE

Software can select the CGMPCLK divided by two as the CGMOUT source even if the PLL is not locked (LOCK = 0). Therefore, software should make sure the PLL is locked before setting the BCS bit.

# 6.7 Special Modes

The WAIT instruction puts the MCU in low power-consumption standby modes.

### 6.7.1 Wait Mode

The WAIT instruction does not affect the CGM. Before entering wait mode, software can disengage and turn off the PLL by clearing the BCS and PLLON bits in the PLL control register (PCTL) to save power. Less power-sensitive applications can disengage the PLL without turning it off, so that the PLL clock is immediately available at WAIT exit. This would be the case also when the PLL is to wake the MCU from wait mode, such as when the PLL is first enabled and waiting for LOCK or LOCK is lost.

## 6.7.2 Stop Mode

The STOP instruction disables the PLL analog circuits and no clock will be driven out of the VCO.

When entering stop mode with the VCO clock (CGMPCLK) selected, before executing the STOP instruction:

- 1. Set the oscillator stop mode enable bit (STOP\_XCLKEN in CONFIG2) if continuos clock is required in stop mode.
- 2. Clear the BCS bit to select CGMXCLK as CGMOUT.

On exit from stop mode:

- 1. Set the PLLON bit if cleared before entering stop mode.
- 2. Wait for PLL to lock by checking the LOCK bit.
- 3. Set BCS bit to select CGMPCLK as CGMOUT.

## 6.7.3 CGM During Break Interrupts

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 7.7.3 SIM 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 the PLLF bit 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 the PLL control register during the break state without affecting the PLLF bit.



#### System Integration Module (SIM)



Figure 7-1. SIM Block Diagram

| Addr.  | Register Name                                |        | Bit 7 | 6   | 5   | 4    | 3    | 2      | 1    | Bit 0 |
|--------|----------------------------------------------|--------|-------|-----|-----|------|------|--------|------|-------|
|        | CIM Brook Ctotus Degister                    | Read:  | B     | в   | B   | в    | в    | B      | SBSW | в     |
| \$FE00 | SIM Dreak Status Register                    | Write: | п     |     | 11  | 11   | 11   | 11     | NOTE |       |
|        | ()                                           | Reset: | 0     | 0   | 0   | 0    | 0    | 0      | 0    | 0     |
|        | Note: Writing a logic 0 clears S             | BSW.   |       |     |     |      |      |        |      |       |
|        | SIM Popot Status Posistor                    | Read:  | POR   | PIN | COP | ILOP | ILAD | MODRST | LVI  | 0     |
| \$FE01 | (SRSR)                                       | Write: |       |     |     |      |      |        |      |       |
|        | (onon)                                       | POR:   | 1     | 0   | 0   | 0    | 0    | 0      | 0    | 0     |
|        | CIM Durals Flag Control                      | Read:  | BCEE  | В   | B   | В    | В    | B      | P    | Р     |
| \$FE03 | Silvi Break Flag Control<br>Register (SBECR) | Write: | DOFE  |     | 11  | n –  | n –  | ň      | 11   | n     |
|        |                                              | Reset: | 0     |     |     |      |      |        |      |       |





#### System Integration Module (SIM)

At power-on, these events occur:

- A POR pulse is generated.
- The internal reset signal is asserted.
- The SIM enables CGMOUT.
- Internal clocks to the CPU and modules are held inactive for 4096 ICLK cycles to allow stabilization of the oscillator.
- The pin is driven low during the oscillator stabilization time.
- The POR bit of the SIM reset status register (SRSR) is set and all other bits in the register are cleared.



Figure 7-7. POR Recovery

## 7.3.2.2 Computer Operating Properly (COP) Reset

An input to the SIM is reserved for the COP reset signal. The overflow of the COP counter causes an internal reset and sets the COP bit in the SIM reset status register (SRSR). The SIM actively pulls down the RST pin for all internal reset sources.

To prevent a COP module timeout, write any value to location \$FFFF. Writing to location \$FFFF clears the COP counter and bits 12 through 5 of the SIM counter. The SIM counter output, which occurs at least every  $2^{13} - 2^4$  ICLK cycles, drives the COP counter. The COP should be serviced as soon as possible out of reset to guarantee the maximum amount of time before the first timeout.

The COP module is disabled if the  $\overline{RST}$  pin or the  $\overline{IRQ1}$  pin is held at  $V_{TST}$  while the MCU is in monitor mode. The COP module can be disabled only through combinational logic conditioned with the high voltage signal on the  $\overline{RST}$  or the  $\overline{IRQ1}$  pin. This prevents the COP from becoming disabled as a result of external noise. During a break state,  $V_{TST}$  on the  $\overline{RST}$  pin disables the COP module.

## 7.3.2.3 Illegal Opcode Reset

The SIM decodes signals from the CPU to detect illegal instructions. An illegal instruction sets the ILOP bit in the SIM reset status register (SRSR) and causes a reset.



#### System Integration Module (SIM)





The LDA opcode is prefetched by both the INT1 and INT2 RTI instructions. However, in the case of the INT1 RTI prefetch, this is a redundant operation.

#### NOTE

To maintain compatibility with the M6805 Family, the H register is not pushed on the stack during interrupt entry. If the interrupt service routine modifies the H register or uses the indexed addressing mode, software should save the H register and then restore it prior to exiting the routine.

#### 7.5.1.2 SWI Instruction

The SWI instruction is a non-maskable instruction that causes an interrupt regardless of the state of the interrupt mask (I bit) in the condition code register.

### NOTE

A software interrupt pushes PC onto the stack. A software interrupt does not push PC – 1, as a hardware interrupt does.

## 7.5.2 Interrupt Status Registers

The flags in the interrupt status registers identify maskable interrupt sources. Table 7-3 summarizes the interrupt sources and the interrupt status register flags that they set. The interrupt status registers can be useful for debugging.



Monitor ROM (MON)







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.

# 9.8 I/O Signals

Port B shares four of its pins with the TIM. The four TIM channel I/O pins are T1CH0, T1CH1, T2CH0, and T2CH1 as described in 9.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.

# 9.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, TSC1)
- TIM channel registers (TCH0H:TCH0L, TCH1H:TCH1L)

## 9.9.1 TIM Status and Control Register

The TIM status and control register (TSC):

- Enables TIM overflow interrupts
- Flags TIM overflows
- Stops the TIM counter
- Resets the TIM counter
- Prescales the TIM counter clock





Figure 9-4. TIM Status and Control Register (TSC)



Timer Interface Module (TIM)

## 9.9.4 TIM Channel Status and Control Registers

Each of the TIM channel status and control registers:

- Flags input captures and output compares
- Enables input capture and output compare interrupts
- Selects input capture, output compare, or PWM operation
- Selects high, low, or toggling output on output compare
- Selects rising edge, falling edge, or any edge as the active input capture trigger
- Selects output toggling on TIM overflow
- Selects 0% and 100% PWM duty cycle
- Selects buffered or unbuffered output compare/PWM operation



Figure 9-9. TIM Channel 0 Status and Control Register (TSC0)

Address: T1SC1, \$0028 and T2SC1, \$0033

|        | Bit 7 | 6     | 5 | 4    | 3      | 2     | 1    | Bit 0   |
|--------|-------|-------|---|------|--------|-------|------|---------|
| Read:  | CH1F  | CHIE  | 0 | MS1A | EL Q1B |       | TOV1 | СН1МАХ  |
| Write: | 0     | OTTIL |   | MOTA | LLOID  | LLOIA | 1001 | OTTIMAA |
| Reset: | 0     | 0     | 0 | 0    | 0      | 0     | 0    | 0       |



### CHxF — Channel x Flag Bit

When channel x is an input capture channel, this read/write bit is set when an active edge occurs on the channel x pin. When channel x is an output compare channel, CHxF is set when the value in the TIM counter registers matches the value in the TIM channel x registers.

When TIM CPU interrupt requests are enabled (CHxIE = 1), clear CHxF by reading TIM channel x status and control register with CHxF set and then writing a logic 0 to CHxF. If another interrupt request occurs before the clearing sequence is complete, then writing logic 0 to CHxF has no effect. Therefore, an interrupt request cannot be lost due to inadvertent clearing of CHxF.

Reset clears the CHxF bit. Writing a logic 1 to CHxF has no effect.

- 1 = Input capture or output compare on channel x
- 0 = No input capture or output compare on channel x

#### CHxIE — Channel x Interrupt Enable Bit

This read/write bit enables TIM CPU interrupt service requests on channel x.

Reset clears the CHxIE bit.

1 = Channel x CPU interrupt requests enabled

0 = Channel x CPU interrupt requests disabled

#### MSxB — Mode Select Bit B

This read/write bit selects buffered output compare/PWM operation. MSxB exists only in the TIM1 channel 0 and TIM2 channel 0 status and control registers.



Setting MS0B disables the channel 1 status and control register and reverts TCH1 to general-purpose I/O.

Reset clears the MSxB bit.

- 1 = Buffered output compare/PWM operation enabled
- 0 = Buffered output compare/PWM operation disabled

## MSxA — Mode Select Bit A

When ELSxB:ELSxA  $\neq$  0:0, this read/write bit selects either input capture operation or unbuffered output compare/PWM operation.

See Table 9-3.

1 = Unbuffered output compare/PWM operation

0 = Input capture operation

When ELSxB:ELSxA = 0:0, this read/write bit selects the initial output level of the TCHx pin. See Table 9-3. Reset clears the MSxA bit.

1 = Initial output level low

0 = Initial output level high

#### NOTE

Before changing a channel function by writing to the MSxB or MSxA bit, set the TSTOP and TRST bits in the TIM status and control register (TSC).

### ELSxB and ELSxA — Edge/Level Select Bits

When channel x is an input capture channel, these read/write bits control the active edge-sensing logic on channel x.

When channel x is an output compare channel, ELSxB and ELSxA control the channel x output behavior when an output compare occurs.

When ELSxB and ELSxA are both clear, channel x is not connected to an I/O port, and pin TCHx is available as a general-purpose I/O pin. Table 9-3 shows how ELSxB and ELSxA work. Reset clears the ELSxB and ELSxA bits.

| MSxB:MSxA | ELSxB:ELSxA | Mode                     | Configuration                                        |
|-----------|-------------|--------------------------|------------------------------------------------------|
| X0        | 00          |                          | Pin under port control;<br>initial output level high |
| X1        | 00          | Output preset            | Pin under port control;<br>initial output level low  |
| 00        | 01          |                          | Capture on rising edge only                          |
| 00        | 10          | Input capture            | Capture on falling edge only                         |
| 00        | 11          |                          | Capture on rising or<br>falling edge                 |
| 01        | 01          |                          | Toggle output on compare                             |
| 01        | 10          | Output compare<br>or PWM | Clear output on compare                              |
| 01        | 11          |                          | Set output on compare                                |
| 1X        | 01          | Buffered output          | Toggle output on compare                             |
| 1X        | 10          | compare or               | Clear output on compare                              |
| 1X        | 11          | buttered PWM             | Set output on compare                                |

Table 9-3. Mode, Edge, and Level Selection



#### Serial Communications Interface Module (SCI)

Depending on the state of the WAKE bit in SCC1, either of two conditions on the RxD pin can bring the receiver out of the standby state:

- Address mark An address mark is a logic 1 in the most significant bit position of a received character. When the WAKE bit is set, an address mark wakes the receiver from the standby state by clearing the RWU bit. The address mark also sets the SCI receiver full bit, SCRF. Software can then compare the character containing the address mark to the user-defined address of the receiver. If they are the same, the receiver remains awake and processes the characters that follow. If they are not the same, software can set the RWU bit and put the receiver back into the standby state.
- Idle input line condition When the WAKE bit is clear, an idle character on the RxD pin wakes the
  receiver from the standby state by clearing the RWU bit. The idle character that wakes the receiver
  does not set the receiver idle bit, IDLE, or the SCI receiver full bit, SCRF. The idle line type bit,
  ILTY, determines whether the receiver begins counting logic 1s as idle character bits after the start
  bit or after the stop bit.

### NOTE

With the WAKE bit clear, setting the RWU bit after the RxD pin has been idle may cause the receiver to wake up immediately.

### 11.4.3.7 Receiver Interrupts

The following sources can generate CPU interrupt requests from the SCI receiver:

- SCI receiver full (SCRF) The SCRF bit in SCS1 indicates that the receive shift register has transferred a character to the SCDR. SCRF can generate a receiver CPU interrupt request. Setting the SCI receive interrupt enable bit, SCRIE, in SCC2 enables the SCRF bit to generate receiver CPU interrupts.
- Idle input (IDLE) The IDLE bit in SCS1 indicates that 10 or 11 consecutive logic 1s shifted in from the RxD pin. The idle line interrupt enable bit, ILIE, in SCC2 enables the IDLE bit to generate CPU interrupt requests.

## 11.4.3.8 Error Interrupts

The following receiver error flags in SCS1 can generate CPU interrupt requests:

- Receiver overrun (OR) The OR bit indicates that the receive shift register shifted in a new character before the previous character was read from the SCDR. The previous character remains in the SCDR, and the new character is lost. The overrun interrupt enable bit, ORIE, in SCC3 enables OR to generate SCI error CPU interrupt requests.
- Noise flag (NF) The NF bit is set when the SCI detects noise on incoming data or break characters, including start, data, and stop bits. The noise error interrupt enable bit, NEIE, in SCC3 enables NF to generate SCI error CPU interrupt requests.
- Framing error (FE) The FE bit in SCS1 is set when a logic 0 occurs where the receiver expects a stop bit. The framing error interrupt enable bit, FEIE, in SCC3 enables FE to generate SCI error CPU interrupt requests.
- Parity error (PE) The PE bit in SCS1 is set when the SCI detects a parity error in incoming data. The parity error interrupt enable bit, PEIE, in SCC3 enables PE to generate SCI error CPU interrupt requests.



Infrared Serial Communications Interface Module (IRSCI)

| RT3, RT5, and RT7<br>Samples | Start Bit<br>Verification | Noise Flag |
|------------------------------|---------------------------|------------|
| 011                          | No                        | 0          |
| 100                          | Yes                       | 1          |
| 101                          | No                        | 0          |
| 110                          | No                        | 0          |
| 111                          | No                        | 0          |

Table 12-2. Start Bit Verification

If start bit verification is not successful, the RT clock is reset and a new search for a start bit begins.

To determine the value of a data bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. Table 12-3 summarizes the results of the data bit samples.

| RT8, RT9, and RT10<br>Samples | Data Bit<br>Determination | Noise Flag |
|-------------------------------|---------------------------|------------|
| 000                           | 0                         | 0          |
| 001                           | 0                         | 1          |
| 010                           | 0                         | 1          |
| 011                           | 1                         | 1          |
| 100                           | 0                         | 1          |
| 101                           | 1                         | 1          |
| 110                           | 1                         | 1          |
| 111                           | 1                         | 0          |

Table 12-3. Data Bit Recovery

### NOTE

The RT8, RT9, and RT10 samples do not affect start bit verification. If any or all of the RT8, RT9, and RT10 start bit samples are logic 1s following a successful start bit verification, the noise flag (NF) is set and the receiver assumes that the bit is a start bit.

To verify a stop bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. Table 12-4 summarizes the results of the stop bit samples.

| RT8, RT9, and RT10<br>Samples | Framing<br>Error Flag | Noise Flag |
|-------------------------------|-----------------------|------------|
| 000                           | 1                     | 0          |
| 001                           | 1                     | 1          |

Table 12-4. Stop Bit Recovery



| SCP1 and SCP0 | Prescaler Divisor (PD) |
|---------------|------------------------|
| 00            | 1                      |
| 01            | 3                      |
| 10            | 4                      |
| 11            | 13                     |

Table 12-7. SCI Baud Rate Prescaling

#### SCR2–SCR0 — SCI Baud Rate Select Bits

These read/write bits select the SCI baud rate divisor as shown in Table 12-8. Reset clears SCR2–SCR0.

| SCR2, SCR1, and SCR0 | Baud Rate Divisor (BD) |
|----------------------|------------------------|
| 000                  | 1                      |
| 001                  | 2                      |
| 010                  | 4                      |
| 011                  | 8                      |
| 100                  | 16                     |
| 101                  | 32                     |
| 110                  | 64                     |
| 111                  | 128                    |

Table 12-8. IRSCI Baud Rate Selection

Use this formula to calculate the SCI baud rate:

baud rate =  $\frac{\text{SCI clock source}}{16 \times \text{PD} \times \text{BD}}$ 

where:

SCI clock source = f<sub>BUS</sub> or CGMXCLK (selected by CKS bit) PD = prescaler divisor BD = baud rate divisor

Table 12-9 shows the SCI baud rates that can be generated with a 4.9152-MHz bus clock when  $f_{BUS}$  is selected as SCI clock source.



#### Multi-Master IIC Interface (MMIIC)

## 14.8.4 Write Byte/Word

| START          | Slave Address     | W  | ACK | Command Code | ACK | Data Byte     | ACK | STOP           |     |      |
|----------------|-------------------|----|-----|--------------|-----|---------------|-----|----------------|-----|------|
| (a) Write Byte | Protocol          |    |     |              |     |               |     |                |     |      |
| START          | Slave Address     | W  | ACK | Command Code | ACK | Data Byte     | ACK | PEC            | ACK | STOP |
| (b) Write Byte | Protocol with PEC |    |     |              |     |               |     |                |     |      |
| START          | Slave Address     | W  | ACK | Command Code | ACK | Data Byte Low | ACK | Data Byte High | ACK | STOP |
| (c) Write Word | Protocol          |    |     |              |     |               |     |                |     |      |
| START          | Slave Address     | W  | ACK | Command Code | ACK | Data Byte Low | ACK | Data Byte High | ACK |      |
| PEC            | ACK               | ST | OP  |              |     |               |     |                |     |      |
| (d) Write Word | Protocol with PEC | ;  |     |              |     |               |     |                |     |      |



## 14.8.5 Read Byte/Word

| START         | Slave Address     | W ACK | Command Code | ACK | START | Slave Address | R | ACK | Data Byte     | NAK | STOP |
|---------------|-------------------|-------|--------------|-----|-------|---------------|---|-----|---------------|-----|------|
| (a) Read Byte | Protocol          |       |              |     |       |               |   |     |               | -   |      |
| 07107         | 0                 |       |              |     | OTADT | 0             | - |     | Data Data     |     |      |
| START         | Slave Address     | WACK  | Command Code | ACK | START | Slave Address | R | ACK | Data Byte     | ACK |      |
| PEC           | NAK               | STOP  |              |     |       |               |   |     |               |     |      |
| (b) Read Byte | Protocol with PEC |       |              |     |       |               |   |     |               |     |      |
|               |                   |       |              |     |       |               | _ |     |               | 1   |      |
| START         | Slave Address     | W ACK | Command Code | ACK | START | Slave Address | R | ACK | Data Byte Low | ACK |      |
| Data Byte     | High NAK          | STOP  |              |     |       |               |   |     |               |     |      |
| (c) Read Word | Protocol          |       |              |     |       |               |   |     |               |     |      |
|               |                   |       |              |     |       |               | - |     |               | 1   |      |
| START         | Slave Address     | W ACK | Command Code | ACK | START | Slave Address | R | ACK | Data Byte Low | ACK |      |
| Data Byte     | High ACK          | PEC   | NAK ST       | OP  |       |               |   |     |               |     |      |

(d) Read Word Protocol with PEC





#### Analog-to-Digital Converter (ADC)

|        | ADC Data Degister Law 0 | Read:  | AD9 | AD8        | AD7   | AD6 | AD5 | AD4        | AD3   | AD2   |
|--------|-------------------------|--------|-----|------------|-------|-----|-----|------------|-------|-------|
| \$005C | ADC Data Register Low 2 | Write: | R   | R          | R     | R   | R   | R          | R     | R     |
|        |                         | Reset: | 0   | 0          | 0     | 0   | 0   | 0          | 0     | 0     |
|        | ADC Data Bagistar Law 2 | Read:  | AD9 | AD8        | AD7   | AD6 | AD5 | AD4        | AD3   | AD2   |
| \$005D | ADC Data negister Low 3 | Write: | R   | R          | R     | R   | R   | R          | R     | R     |
|        |                         | Reset: | 0   | 0          | 0     | 0   | 0   | 0          | 0     | 0     |
|        | ADC Auto-scan Control   | Read:  | 0   | 0          | 0     | 0   | 0   |            |       |       |
| \$005E | Register                | Write: |     |            |       |     |     | AUTOT      | AUTOU | AGUAN |
|        | (ADASCR)                | Reset: | 0   | 0          | 0     | 0   | 0   | 0          | 0     | 0     |
|        |                         |        |     | = Unimplem | ented |     | R   | = Reserved |       |       |

Figure 15-1. ADC I/O Register Summary

# **15.3 Functional Description**

The ADC provides eight pins for sampling external sources at pins PTA0/ADC0–PTA7/ADC7. An analog multiplexer allows the single ADC converter to select one of eight ADC channels as ADC voltage in  $(V_{ADIN})$ .  $V_{ADIN}$  is converted by the successive approximation register-based analog-to-digital converter. When the conversion is completed, ADC places the result in the ADC data register, high and low byte (ADRH0 and ADRL0), and sets a flag or generates an interrupt.

An additional three ADC data registers (ADRL1–ADRL3) are available to store the individual converted data for ADC channels ADC1–ADC3 when the auto-scan mode is enabled. Data from channel ADC0 is stored in ADRL0 in the auto-scan mode.

Figure 15-2 shows the structure of the ADC module.

## 15.3.1 ADC Port I/O Pins

PTA0–PTA7 are general-purpose I/O pins that are shared with the ADC channels. The channel select bits, ADCH[4:0], define which ADC channel/port pin will be used as the input signal. The ADC overrides the port I/O logic by forcing that pin as input to the ADC. The remaining ADC channels/port pins are controlled by the port I/O logic and can be used as general-purpose I/O. Writes to the port data register or data direction register will not have any affect on the port pin that is selected by the ADC. Read of a port pin which is in use by the ADC will return the pin condition if the corresponding DDR bit is at logic 0. If the DDR bit is at logic 1, the value in the port data latch is read.

## 15.3.2 Voltage Conversion

When the input voltage to the ADC equals  $V_{REFH}$ , the ADC converts the signal to \$3FF (full scale). If the input voltage equals  $V_{REFL}$ , the ADC converts it to \$000. Input voltages between  $V_{REFH}$  and  $V_{REFL}$  are a straight-line linear conversion. All other input voltages will result in \$3FF if greater than  $V_{REFH}$  and \$000 if less than  $V_{REFL}$ .

### NOTE

Input voltage should not exceed the analog supply voltages.



| Addr.  | Register Name            |        | Bit 7 | 6   | 5   | 4   | 3   | 2   | 1   | Bit 0 |
|--------|--------------------------|--------|-------|-----|-----|-----|-----|-----|-----|-------|
|        | ADC Data Degister Ligh 0 | Read:  | AD9   | AD8 | AD7 | AD6 | AD5 | AD4 | AD3 | AD2   |
| \$0059 |                          | Write: | R     | R   | R   | R   | R   | R   | R   | R     |
|        |                          | Reset: | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |
|        | ADC Data Degister Low 0  | Read:  | AD1   | AD0 | 0   | 0   | 0   | 0   | 0   | 0     |
| \$005A |                          | Write: | R     | R   | R   | R   | R   | R   | R   | R     |
|        | (ADHLO)                  | Reset: | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0     |

Figure 15-8 ADRH0 and ADRL0 in Left Justified Sign Data Mode

## 15.7.4 ADC Auto-Scan Mode Data Registers (ADRL1–ADRL3)

The ADC data registers 1 to 3 (ADRL1–ADRL3), are 8-bit registers for conversion results in 8-bit truncated mode, for channels ADC1 to ADC3, when the ADC is operating in auto-scan mode (MODE[1:0] = 00).

| Addrose.  | ADRI 1 | \$005B | ADRI 2   | \$0050 | and | ADRI 3 | \$005D |
|-----------|--------|--------|----------|--------|-----|--------|--------|
| luui 000. |        | ψυυυυ, | , שוובב, | ψυυυυ, | unu | / נבו, | ψυυυυ  |

| Read:  | AD9 | AD8        | AD7 | AD6 | AD5 | AD4 | AD3 | AD2 |
|--------|-----|------------|-----|-----|-----|-----|-----|-----|
| Write: | R   | R          | R   | R   | R   | R   | R   | R   |
| Reset: | 0   | 0          | 0   | 0   | 0   | 0   | 0   | 0   |
|        | R   | = Reserved |     |     |     |     |     |     |

### Figure 15-9. ADC Data Register Low 1 to 3 (ADRL1–ADRL3)

## 15.7.5 ADC Auto-Scan Control Register (ADASCR)

The ADC auto-scan control register (ADASCR) enables and controls the ADC auto-scan function.



Figure 15-10. ADC Scan Control Register (ADASCR)

### AUTO[1:0] — Auto-Scan Mode Channel Select Bits

AUTO1 and AUTO0 form a 2-bit field which is used to define the number of auto-scan channels used when in auto-scan mode. Reset clears these bits.

| Table 15-4. | Auto-scan | Mode | Channel | Select |
|-------------|-----------|------|---------|--------|
|-------------|-----------|------|---------|--------|

| AUTO1 | AUTO0 | Auto-Scan Channels |  |  |  |
|-------|-------|--------------------|--|--|--|
| 0     | 0     | ADC0 only          |  |  |  |
| 0     | 1     | ADC0 to ADC1       |  |  |  |
| 1     | 0     | ADC0 to ADC2       |  |  |  |
| 1     | 1     | ADC0 to ADC3       |  |  |  |



#### Analog-to-Digital Converter (ADC)

#### ASCAN — Auto-scan Mode Enable Bit

This bit enable/disable the auto-scan mode. Reset clears this bit.

- 1 = Auto-scan mode is enabled
- 0 = Auto-scan mode is disabled

Auto-scan mode should not be enabled when ADC continuous conversion is enabled; i.e. when ADCO=1.



Keyboard Interrupt Module (KBI)







#### Figure 18-2. Keyboard Interrupt Block Diagram

Writing to the KBIE7–KBIE0 bits in the keyboard interrupt enable register independently enables or disables each port D pin as a keyboard interrupt pin. Enabling a keyboard interrupt pin in port D also enables its internal pull-up device. A logic 0 applied to an enabled keyboard interrupt pin latches a keyboard interrupt request.

A keyboard interrupt is latched when one or more keyboard pins goes low after all were high. The MODEK bit in the keyboard status and control register controls the triggering mode of the keyboard interrupt.

- If the keyboard interrupt is edge-sensitive only, a falling edge on a keyboard pin does not latch an interrupt request if another keyboard pin is already low. To prevent losing an interrupt request on one pin because another pin is still low, software can disable the latter pin while it is low.
- If the keyboard interrupt is falling edge- and low level-sensitive, an interrupt request is present as long as any keyboard pin is low.

If the MODEK bit is set, the keyboard interrupt pins are both falling edge- and low level-sensitive, and both of the following actions must occur to clear a keyboard interrupt request:

- Vector fetch or software clear A vector fetch generates an interrupt acknowledge signal to clear the interrupt request. Software may generate the interrupt acknowledge signal by writing a logic 1 to the ACKK bit in the keyboard status and control register KBSCR. The ACKK bit is useful in applications that poll the keyboard interrupt pins and require software to clear the keyboard interrupt request. Writing to the ACKK bit prior to leaving an interrupt service routine can also prevent spurious interrupts due to noise. Setting ACKK does not affect subsequent transitions on the keyboard interrupt pins. A falling edge that occurs after writing to the ACKK bit latches another interrupt request. If the keyboard interrupt mask bit, IMASKK, is clear, the CPU loads the program counter with the vector address at locations \$FFE0 and \$FFE1.
- Return of all enabled keyboard interrupt pins to logic 1 As long as any enabled keyboard interrupt pin is at logic 0, the keyboard interrupt remains set.

The vector fetch or software clear and the return of all enabled keyboard interrupt pins to logic 1 may occur in any order.