



FEUL66577-01

# MSM66577 FAMILY

User's Manual

**CMOS 16-bit microcontroller** 

Issue Date: Jun. 2002

### **NOTICE**

- 1. The information contained herein can change without notice owing to product and/or technical improvements. Before using the product, please make sure that the information being referred to is up-to-date.
- 2. The outline of action and examples for application circuits described herein have been chosen as an explanation for the standard action and performance of the product. When planning to use the product, please ensure that the external conditions are reflected in the actual circuit, assembly, and program designs.
- 3. When designing your product, please use our product below the specified maximum ratings and within the specified operating ranges including, but not limited to, operating voltage, power dissipation, and operating temperature.
- 4. Oki assumes no responsibility or liability whatsoever for any failure or unusual or unexpected operation resulting from misuse, neglect, improper installation, repair, alteration or accident, improper handling, or unusual physical or electrical stress including, but not limited to, exposure to parameters beyond the specified maximum ratings or operation outside the specified operating range.
- 5. Neither indemnity against nor license of a third party's industrial and intellectual property right, etc. is granted by us in connection with the use of the product and/or the information and drawings contained herein. No responsibility is assumed by us for any infringement of a third party's right which may result from the use thereof.
- 6. The products listed in this document are intended for use in general electronics equipment for commercial applications (e.g., office automation, communication equipment, measurement equipment, consumer electronics, etc.). These products are not authorized for use in any system or application that requires special or enhanced quality and reliability characteristics nor in any system or application where the failure of such system or application may result in the loss or damage of property, or death or injury to humans. Such applications include, but are not limited to, traffic and automotive equipment, safety devices, aerospace equipment, nuclear power control, medical equipment, and life-support systems.
- 7. Certain products in this document may need government approval before they can be exported to particular countries. The purchaser assumes the responsibility of determining the legality of export of these products and will take appropriate and necessary steps at their own expense for these.
- 8. No part of the contents contained herein may be reprinted or reproduced without our prior permission.

Copyright 2002 Oki Electric Industry Co., Ltd.

### **Preface**

This user's manual describes the hardware of Oki-original CMOS 16-bit microcontrollers MSM66577 family. In addition to this manual, Oki also provides the following manuals which should be read with regard to the MSM66577 family.

#### nX-8/500S Core Instruction Manual

- nX-8/500S core instruction set
- Addressing modes

### CC665S User's Manual

- Optimized compiler CC665S operation
- C-language specifications in CC665S

#### CL665S User's Manual

Compiler loader CL665S operation

### RTL665S Run Time Library Reference

· C run time library explanation

### MAC66K Assembler Package User's Manual

- · Package overview
- RAS66K (relocatable assembler) operation
- RAS66K assembly language explanation
- RL66K (linker) operation
- · LIB66K (librarian) operation
- OH66K (object converter) operation

### Macroprocessor MP User's Manual

- MP operation
- · Macro language

#### Ultra-66K/E502 User's Manual

- Ultra-66K (Emulator) explanation
- PathFinder-66K (Debugger) explanation

### PW66K Flash Writer System User's Manual

PW66K Flash Writer System operation

This document is subject to change without notice.

### **Notation**

| Classification  | Notation                                                                                          | Description                                                                                                                                                                                                                                                                                             |
|-----------------|---------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ■ Numeric value | xxH, xxhex<br>xxb                                                                                 | Represents a hexadecimal number<br>Represents a binary number                                                                                                                                                                                                                                           |
| ■ Unit          | Word, W byte, B nibble, N mega-, M kilo-, K kilo-, k milli-, m micro-, µ nano-, n second, s KB MB | 1 word = 16 bits<br>1 byte = 2 nibbles = 8 bits<br>1 nibble = 4 bits<br>106<br>2 <sup>10</sup> = 1024<br>10 <sup>3</sup> = 1000<br>10 <sup>-3</sup><br>10 <sup>-6</sup><br>10 <sup>-9</sup><br>second<br>1KB = 1 kilobyte = 1024 bytes<br>1MB = 1 megabyte = 2 <sup>20</sup> bytes<br>= 1,048,576 bytes |
| ■ Terminology   | "H" level<br>"L" level                                                                            | The signal level of the high side of the voltage; indicates the voltage level of $V_{IH}$ and $V_{OH}$ described in the electrical characteristics. The signal level of the low side of the voltage; indicates voltage level of $V_{IL}$ and $V_{OL}$ described in the electrical characteristics.      |
|                 | Opcode trap                                                                                       | Operation code trap. Occurs when an empty area that has not been assigned an instruction is fetched, or when an instruction code combination that does not contain an instruction is addressed.                                                                                                         |

### ■ Register description



Invalid bit : Indicates that the bit does not exist. Writing into this bit is invalid. Fixed bit : When writing, always write the specified value. If read, the specified

value will be read. Values of fixed bits are specified as "0" or "1."

Read/write attribute: R indicates that reading is possible and W indicates that writing is

possible.

## **Contents**

| Chapter 1 | Overview                             |      |
|-----------|--------------------------------------|------|
| 1.1 Ove   | erview                               | 1-1  |
| 1.2 Fea   | atures                               | 1-1  |
| 1.3 Blo   | ck Diagram                           | 1-4  |
| 1.4 Pin   | Configuration                        | 1-5  |
| 1.5 Pin   | Descriptions                         | 1-6  |
| 1.5.1     | Description of Each Pin              | 1-6  |
| 1.5.2     | Pin Configuration                    | 1-9  |
| 1.5.3     | Connections for Unused Pins          | 1-11 |
| 1.6 Bas   | sic Operational Timing               | 1-12 |
| Chapter 2 | CPU Architecture                     |      |
| 2.1 Ove   | erview                               | 2-1  |
| 2.2 Me    | mory Space                           | 2-1  |
| 2.2.1     | Memory Space Expansion               | 2-1  |
| 2.2.2     | Program Memory Space                 | 2-3  |
| (1)       | Accessing program memory space       | 2-5  |
| (2)       | Vector table area                    | 2-5  |
| (3)       | VCAL table area                      | 2-8  |
| (4)       | ACAL area                            | 2-9  |
| 2.2.3     | Data Memory Space                    | 2-10 |
| (1)       | Special function register (SFR) area | 2-12 |
| (2)       | Reserved area                        | 2-12 |
| (3)       | Internal RAM area                    | 2-12 |
| (4)       | Fixed page (FIX) area                | 2-12 |
| (5)       | Local register setting area          | 2-14 |
| (6)       | External data memory area            | 2-14 |
| (7)       | Common area                          |      |
| 2.2.4     | Data Memory Access                   | 2-15 |
| (1)       | Byte operations                      | 2-15 |
| (2)       | Word operations                      | 2-16 |
| 2.3 Re    | gisters                              | 2-17 |
| 2.3.1     | Arithmetic Register (ACC)            | 2-17 |
| 2.3.2     | Control Registers                    | 2-18 |
| (1)       | Program status word (PSW)            | 2-18 |
| (2)       | Program counter (PC)                 | 2-22 |

| (3)                                                                         | Local register base (LRB)                            | 2-22                                     |
|-----------------------------------------------------------------------------|------------------------------------------------------|------------------------------------------|
| (4)                                                                         | System stack pointer (SSP)                           | 2-23                                     |
| 2.3.3                                                                       | Pointing Register (PR)                               | 2-24                                     |
| 2.3.4                                                                       | Local Registers (R0 to R7, ER0 to ER3)               | 2-25                                     |
| 2.3.5                                                                       | Segment Registers                                    | 2-26                                     |
| (1)                                                                         | Code segment register (CSR)                          | 2-26                                     |
| (2)                                                                         | Table segment register (TSR)                         | 2-26                                     |
| (3)                                                                         | Data segment register (DSR)                          | 2-27                                     |
| 2.4 Add                                                                     | dressing Modes                                       | 2-27                                     |
| 2.4.1                                                                       | RAM Addressing                                       | 2-27                                     |
| (1)                                                                         | Register addressing                                  | 2-28                                     |
| (2)                                                                         | Page addressing                                      | 2-30                                     |
| (3)                                                                         | Direct data addressing                               | 2-33                                     |
| (4)                                                                         | Pointing register indirect addressing                | 2-34                                     |
| (5)                                                                         | Special bit area addressing                          | 2-41                                     |
| 2.4.2                                                                       | ROM Addressing                                       | 2-43                                     |
| (1)                                                                         | Immediate addressing                                 | 2-43                                     |
| (2)                                                                         | Table data addressing                                | 2-43                                     |
| (3)                                                                         | Program code addressing                              | 2-45                                     |
| (-)                                                                         | •                                                    |                                          |
| (4)                                                                         | ROM window addressing                                |                                          |
| ` ,                                                                         |                                                      |                                          |
| ` ,                                                                         |                                                      |                                          |
| (4) Chapter 3                                                               | ROM window addressing                                | 2-46                                     |
| (4)  Chapter 3  3.1 Ove                                                     | ROM window addressing  CPU Control Functions         | 2-46                                     |
| (4)  Chapter 3  3.1 Ove                                                     | ROM window addressing  CPU Control Functions  erview | 3-1                                      |
| (4)  Chapter 3  3.1 Ove 3.2 Sta                                             | ROM window addressing  CPU Control Functions erview  | 3-1<br>3-1<br>3-3                        |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1                                       | CPU Control Functions erview                         | 3-1<br>3-1<br>3-3                        |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1 3.2.2                                 | CPU Control Functions  erview                        | 3-1<br>3-1<br>3-3<br>3-3                 |
| (4)  Chapter 3  3.1 Ove 3.2 Sta  3.2.1  3.2.2  (1)                          | CPU Control Functions erview                         |                                          |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2)                         | CPU Control Functions  erview                        | 2-463-13-33-33-33-4                      |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2) 3.2.3                   | CPU Control Functions erview                         | 2-463-13-33-33-43-6                      |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1  3.2.2  (1)  (2)  3.2.3               | CPU Control Functions  erview                        | 2-463-13-33-33-43-63-6                   |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1  3.2.2  (1)  (2)  3.2.3               | CPU Control Functions  erview                        | 2-463-13-33-33-63-63-6                   |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2) 3.2.3                   | CPU Control Functions  erview                        | 2-463-13-33-33-63-63-63-63-6             |
| (4)  Chapter 3 3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2) 3.2.3 • • • 3.2.4        | CPU Control Functions  erview                        | 2-463-13-33-33-63-63-63-63-63-6          |
| (4)  Chapter 3  3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2) 3.2.3  • • • 3.2.4 (1)  | CPU Control Functions  erview                        | 2-463-13-33-33-63-63-63-63-63-63-7       |
| (4)  Chapter 3 3.1 Ove 3.2 Sta 3.2.1 3.2.2 (1) (2) 3.2.3  3.2.4 (1) (2) (3) | CPU Control Functions  erview                        | 2-463-13-33-33-63-63-63-63-63-63-63-73-8 |

| Chapter | r 4 Memory Control Functions                                             |      |
|---------|--------------------------------------------------------------------------|------|
| 4.1     | Overview                                                                 | 4-1  |
| 4.2     | Memory Control Function Registers                                        | 4-1  |
| 4.3     | ROM Window Function                                                      | 4-2  |
| 4.4     | READY Function                                                           | 4-4  |
| 4.4     | 1.1 ROM Ready Control Register (ROMRDY)                                  | 4-4  |
| 4.4     | 1.2 RAM Ready Control Register (RAMRDY)                                  | 4-5  |
| 4.5     | WAIT Function                                                            | 4-7  |
| Chapter | r 5 Port Functions                                                       |      |
| 5.1     | Overview                                                                 | 5-1  |
| 5.2     | Hardware Configuration of Each Port                                      | 5-3  |
| 5.2     | 2.1 Type A (P0)                                                          | 5-3  |
| 5.2     | 2.2 Type B (P1, P2, P3_0, P3_1, P4)                                      | 5-4  |
| 5.2     | 2.3 Type C (P3_2, P3_3)                                                  | 5-5  |
| 5.2     | 2.4 Type D                                                               |      |
|         | (P5, P6, P7, P8, P9, P10, P11, P14_0 to P14_2, P15)                      | 5-6  |
|         | 2.5 Type E (P14_6, P14_7)                                                |      |
|         | 2.6 Type F (P12)                                                         |      |
|         | Port Registers                                                           |      |
|         | 3.1 Port Data Registers (Pn:n = 0 to 12, 14, 15)                         |      |
|         | 3.2 Port Mode Registers (PnIO:n = 0 to 11, 14, 15)                       |      |
|         | 3.3 Port Secondary Function Control Registers (PnSF:n = 0 to 11, 14, 15) |      |
| 5.4     | Port 0 (P0)                                                              |      |
| 5.5     | Port 1 (P1)                                                              |      |
| 5.6     | Port 2 (P2)                                                              |      |
| 5.7     | Port 3 (P3)                                                              |      |
| 5.8     | Port 4 (P4)                                                              |      |
| 5.9     | Port 5 (P5)                                                              |      |
|         | Port 6 (P6)                                                              |      |
|         | Port 7 (P7)                                                              |      |
|         | Port 8 (P8)                                                              |      |
|         | Port 9 (P9)                                                              |      |
|         | Port 10 (P10)                                                            |      |
|         | Port 11 (P11)                                                            |      |
|         | Port 12 (P12)                                                            |      |
|         | Port 14 (P14)                                                            |      |
| 5 1Ω    | Port 15 (P15)                                                            | 5-30 |

| Chapter 6 | Clock Oscillation Circuit                                |     |
|-----------|----------------------------------------------------------|-----|
| 6.1 Ove   | erview                                                   | 6-1 |
| 6.2 Clo   | ck Oscillation Circuit Configuration                     | 6-1 |
|           | ck Oscillation Circuit Registers                         |     |
| 6.4 OS    | C Oscillation Circuit                                    | 6-2 |
| 6.5 XT    | Oscillation Circuit                                      | 6-5 |
|           |                                                          |     |
| Chapter 7 | Time Base Counter (TBC)                                  |     |
| 7.1 Ove   | erview                                                   | 7-1 |
| 7.2 Tim   | e Base Counter (TBC) Configuration                       | 7-1 |
| 7.3 Tim   | e Base Counter Registers                                 | 7-2 |
| 7.4 1/n   | Counter                                                  | 7-2 |
| 7.4.1     | Description of 1/n Counter Registers                     | 7-2 |
| (1)       | TBC clock dividing counter (TBCKDV upper 8 bits)         | 7-2 |
| (2)       | TBC clock divider register (TBCKDVR)                     | 7-3 |
| 7.4.2     | Example of 1/n Counter-related Register Settings         | 7-4 |
| 7.5 Tim   | e Base Counter (TBC) Operation                           | 7-4 |
|           |                                                          |     |
| Chapter 8 | General-Purpose 8/16 Bit Timers                          |     |
| 8.1 Ove   | erview                                                   | 8-1 |
| 8.2 Ger   | neral-purpose 8-bit/16-bit Timer Configurations          | 8-1 |
|           | neral-purpose 8-bit/16-bit Timer Registers               |     |
| 8.4 Tim   | er 0                                                     | 8-3 |
| 8.4.1     | Timer 0 Configuration                                    | 8-3 |
| 8.4.2     | Description of Timer 0 Registers                         | 8-4 |
| (1)       | General-purpose 16-bit timer 0 counter (TM0C)            | 8-4 |
| (2)       | General-purpose 16-bit timer 0 register (TM0R)           | 8-4 |
| (3)       | General-purpose 16-bit timer 0 control register (TM0CON) | 8-4 |
| 8.4.3     | Example of Timer 0-related Register Settings             | 8-6 |
| (1)       | Port 5 mode register (P5IO)                              | 8-6 |
| (2)       | Port 5 secondary function control register (P5SF)        | 8-6 |
| (3)       | General-purpose 16-bit timer 0 counter (TM0C)            | 8-6 |
| (4)       | General-purpose 16-bit timer 0 register (TM0R)           | 8-6 |
| (5)       | General-purpose 16-bit timer 0 control register (TM0CON) | 8-6 |
| 8.4.4     | Timer 0 Operation                                        | 8-7 |
| 8.4.5     | Timer 0 Interrupt                                        | 8-8 |
| 8.5 Tim   | ers 1 and 2                                              | 8-9 |
| 8.5.1     | Timers 1 and 2 Configurations                            | 8-9 |

| 8.5.2 | Description of Timer 1 and 2 Registers                     | 8-10 |
|-------|------------------------------------------------------------|------|
| (1)   | General-purpose 8-bit timer 1 and 2 counters (TM1C, TM2C)  | 8-10 |
| (2)   | General-purpose 8-bit timer 1 and 2 registers (TM1R, TM2R) | 8-10 |
| (3)   | General-purpose 8-bit timer 1 control register (TM1CON)    | 8-10 |
| (4)   | General-purpose 8-bit timer 2 control register (TM2CON)    | 8-11 |
| 8.5.3 | Example of Timer 1- and 2-related Register Settings        | 8-13 |
| •     | 8-bit auto-reload timer mode (Timer 1)                     | 8-13 |
| (1)   | Port 6 mode register (P6IO)                                | 8-13 |
| (2)   | Port 6 secondary function control register (P6SF)          | 8-13 |
| (3)   | General-purpose 8-bit timer 1 counter (TM1C)               | 8-13 |
| (4)   | General-purpose 8-bit timer 1 register (TM1R)              | 8-13 |
| (5)   | General-purpose 8-bit timer 1 control register (TM1CON)    | 8-13 |
| •     | 8-bit auto-reload timer mode (Timer 2)                     | 8-13 |
| (1)   | Port 6 mode register (P6IO)                                | 8-13 |
| (2)   | Port 6 secondary function control register (P6SF)          | 8-13 |
| (3)   | General-purpose 8-bit timer 2 counter (TM2C)               |      |
| (4)   | General-purpose 8-bit timer 2 register (TM2R)              | 8-14 |
| (5)   | General-purpose 8-bit timer 2 control register (TM2CON)    | 8-14 |
| •     | 16-bit auto-reload timer mode                              | 8-14 |
| (1)   | Port 6 mode register (P6IO)                                | 8-14 |
| (2)   | Port 6 secondary function control register (P6SF)          | 8-14 |
| (3)   | General-purpose 16-bit timer 12 counter (TM12C)            | 8-14 |
| (4)   | General-purpose 16-bit timer 12 register (TM12R)           | 8-14 |
| (5)   | General-purpose 8-bit timer 1 control register (TM1CON)    | 8-14 |
| (6)   | General-purpose 8-bit timer 2 control register (TM2CON)    | 8-14 |
| •     | PWM mode                                                   | 8-15 |
| (1)   | Port 6 mode register (P6IO)                                | 8-15 |
| (2)   | Port 6 secondary function control register (P6SF)          | 8-15 |
| (3)   | General-purpose 16-bit timer 12 counter (TM12C)            | 8-15 |
| (4)   | General-purpose 16-bit timer 12 register (TM12R)           | 8-15 |
| (5)   | General-purpose 8-bit timer 1 control register (TM1CON)    | 8-15 |
| (6)   | General-purpose 8-bit timer 2 control register (TM2CON)    | 8-15 |
| 8.5.4 | Timer 1 and 2 Operation                                    | 8-16 |
| •     | 8-bit auto-reload timer mode                               | 8-16 |
| •     | 16-bit auto-reload timer mode                              | 8-17 |
| •     | PWM mode                                                   | 8-18 |
| 8.5.5 | Timer 1 and 2 Interrupts                                   | 8-19 |
| •     | Timer 1 interrupt                                          | 8-19 |
| •     | Timer 2 interrupt                                          | 8-20 |

| 8.6 Tim | er 3                                                    | 8-21 |
|---------|---------------------------------------------------------|------|
| 8.6.1   | Timer 3 Configuration                                   | 8-21 |
| 8.6.2   | Description of Timer 3 Registers                        | 8-22 |
| (1)     | General-purpose 8-bit timer 3 counter (TM3C)            | 8-22 |
| (2)     | General-purpose 8-bit timer 3 register (TM3R)           |      |
| (3)     | General-purpose 8-bit timer 3 control register (TM3CON) | 8-22 |
| 8.6.3   | Example of Timer 3-related Register Settings            | 8-24 |
| (1)     | General-purpose 8-bit timer 3 counter (TM3C)            | 8-24 |
| (2)     | General-purpose 8-bit timer 3 register (TM3R)           | 8-24 |
| (3)     | General-purpose 8-bit timer 3 control register (TM3CON) | 8-24 |
| 8.6.4   | Timer 3 Operation                                       | 8-25 |
| 8.6.5   | Timer 3 Interrupt                                       | 8-26 |
| 8.7 Tim | er 4                                                    | 8-27 |
| 8.7.1   | Timer 4 Configuration                                   | 8-27 |
| 8.7.2   | Description of Timer 4 Registers                        | 8-28 |
| (1)     | General-purpose 8-bit timer 4 counter (TM4C)            | 8-28 |
| (2)     | General-purpose 8-bit timer 4 register (TM4R)           | 8-28 |
| (3)     | General-purpose 8-bit timer 4 control register (TM4CON) | 8-28 |
| 8.7.3   | Example of Timer 4-related Register Settings            | 8-30 |
| (1)     | Port 8 mode register (P8IO)                             | 8-30 |
| (2)     | Port 8 secondary function control register (P8SF)       | 8-30 |
| (3)     | General-purpose 8-bit timer 4 counter (TM4C)            | 8-30 |
| (4)     | General-purpose 8-bit timer 4 register (TM4R)           | 8-30 |
| (5)     | General-purpose 8-bit timer 4 control register (TM4CON) | 8-30 |
| 8.7.4   | Timer 4 Operation                                       | 8-31 |
| 8.7.5   | Timer 4 Interrupt                                       | 8-32 |
| 8.8 Tim | er 5                                                    | 8-33 |
| 8.8.1   | Timer 5 Configuration                                   | 8-33 |
| 8.8.2   | Description of Timer 5 Registers                        |      |
| (1)     | General-purpose 8-bit timer 5 counter (TM5C)            | 8-34 |
| (2)     | General-purpose 8-bit timer 5 register (TM5R)           | 8-34 |
| (3)     | General-purpose 8-bit timer 5 control register (TM5CON) | 8-34 |
| 8.8.3   | Example of Timer 5-related Register Settings            | 8-36 |
| (1)     | General-purpose 8-bit timer 5 counter (TM5C)            | 8-36 |
| (2)     | General-purpose 8-bit timer 5 register (TM5R)           | 8-36 |
| (3)     | General-purpose 8-bit timer 5 control register (TM5CON) | 8-36 |
| 8.8.4   | Timer 5 Operation                                       |      |
| 8.8.5   | Timer 5 Interrupt                                       | 8-38 |
| 8.9 Tim | er 6                                                    | 8-39 |
| 891     | Timer 6 Configuration                                   | 8-39 |

| 8.9.2     | Description of Timer 6 Registers                        | 8-40         |
|-----------|---------------------------------------------------------|--------------|
| (1)       | General-purpose 8-bit timer 6 counter (TM6C)            | 8-40         |
| (2)       | General-purpose 8-bit timer 6 register (TM6R)           | 8-40         |
| (3)       | General-purpose 8-bit timer 6 control register (TM6CON) | 8-41         |
| 8.9.3     | Example of Timer 6-related Register Settings            | 8-43         |
| •         | Auto-reload timer mode settings                         | 8-43         |
| (1)       | General-purpose 8-bit timer 6 counter (TM6C)            | 8-43         |
| (2)       | General-purpose 8-bit timer 6 register (TM6R)           | 8-43         |
| (3)       | General-purpose 8-bit timer 6 control register (TM6CON) | 8-43         |
| •         | Watchdog timer (WDT) mode settings                      | 8-43         |
| (1)       | General-purpose 8-bit timer 6 register (TM6R)           | 8-43         |
| (2)       | General-purpose 8-bit timer 6 control register (TM6CON) | 8-43         |
| (3)       | General-purpose 8-bit timer 6 counter (TM6C)            | 8-43         |
| 8.9.4     | Timer 6 Operation                                       | 8-44         |
| •         | Auto-reload timer mode                                  | 8-44         |
| •         | Watchdog timer (WDT) mode                               | 8-44         |
| 8.9.5     | Timer 6 Interrupt (During Auto-Reload Timer Mode)       | 8-47         |
| 8.10 Tir  | mer 9                                                   | 8-48         |
| 8.10.1    | Timer 9 Configuration                                   | 8-48         |
|           | Description of Timer 9 Registers                        |              |
| (1)       | General-purpose 8-bit timer 9 counter (TM9C)            | 8-49         |
| (2)       | General-purpose 8-bit timer 9 register (TM9R)           |              |
| (3)       | General-purpose 8-bit timer 9 control register (TM9CON) | 8-49         |
| 8.10.3    | Example of Timer 9-related Register Settings            | 8-51         |
| (1)       | General-purpose 8-bit timer 9 counter (TM9C)            | 8-51         |
| (2)       | General-purpose 8-bit timer 9 register (TM9R)           |              |
| (3)       | General-purpose 8-bit timer 9 control register (TM9CON) | 8-51         |
| 8.10.4    | Timer 9 Operation                                       | 8-52         |
| 8.10.5    | Timer 9 Interrupt                                       | 8-53         |
| Chapter 9 | Capture/Compare Timer                                   |              |
| -         | erview                                                  | 0_1          |
|           | sture/Compare Timer Configuration                       |              |
| •         | oture/Compare Timer Registers                           |              |
|           | Bit Free Running Counter (FRC)                          |              |
| 9.4.1     | 16-Bit Free Running Counter Configuration               |              |
| 9.4.2     | Description of 16-bit Free Running Counter Register     |              |
| (1)       | 16-bit free running counter (FRC)                       |              |
| (2)       | Free running counter control register (FRCON)           |              |
| (2)       | Ties running counter control register (FNCON)           | 9 <b>-</b> 4 |

| 9.5 Cap    | oture/Compare Out Modules                                  | 9-5  |
|------------|------------------------------------------------------------|------|
| 9.5.1      | Capture/Compare Out Module Configuration                   | 9-5  |
| 9.5.2      | Description of Capture/Compare Out Module Registers        | 9-6  |
| (1)        | Capture/compare registers (CPCMR0, CPCMR1)                 | 9-6  |
| (2)        | Capture/compare control registers (CPCMCON0, CPCMCON1)     | 9-6  |
| (3)        | Capture control register (CAPCON)                          | 9-7  |
| (4)        | Capture/compare buffer registers (CPCMBFR0, CPCMBFR1)      | 9-8  |
| 9.6 Exa    | ample of Capture/Compare Timer-related Register Settings   | 9-8  |
| 9.6.1      | Capture Mode Settings                                      | 9-8  |
| (1)        | Port 5 mode register (P5IO)                                | 9-8  |
| (2)        | Port 5 secondary function control register (P5SF)          | 9-8  |
| (3)        | Capture control register (CAPCON)                          | 9-8  |
| (4)        | Free running counter (FRC)                                 | 9-8  |
| (5)        | Free running counter control register (FRCON)              | 9-8  |
| 9.6.2      | Compare Out Mode Settings                                  | 9-9  |
| (1)        | Port 5 mode register (P5IO)                                |      |
| (2)        | Port 5 secondary function control register (P5SF)          | 9-9  |
| (3)        | Capture/compare control registers (CPCMCON0, CPCMCON1)     | 9-9  |
| (4)        | Free running counter (FRC)                                 |      |
| (5)        | Capture/compare registers (CPCMR0, CPCMR1)                 |      |
| (6)        | Capture/compare buffer registers (CPCMBFR0, CPCMBFR1)      |      |
| (7)        | Free running counter control register (FRCON)              |      |
|            | oture/Compare Timer Operation                              |      |
|            | Capture Mode Operation                                     |      |
|            | Compare Out Mode Operation                                 |      |
|            | ample Timings for Changing the Output Level of Compare Out |      |
| 9.9 Cap    | oture/Compare Timer Interrupt                              | 9-14 |
| Chapter 10 |                                                            |      |
|            | verview                                                    | 10-1 |
|            | eal-Time Counter Configuration                             |      |
|            | eal-Time Counter Control Register (RTCCON)                 |      |
|            | cample of Real-Time Counter Register Settings              |      |
|            | eal-Time Counter Operation                                 |      |
| 10.6 Re    | eal-Time Counter Interrupt                                 | 10-4 |
| Chapter 11 | PWM Function                                               |      |
|            | /erview                                                    |      |
| 11.2 P\    | VM Configuration                                           | 11-1 |

| 11.3 PV    | VM Register                                       | 11-2  |
|------------|---------------------------------------------------|-------|
| 11.3.1     | Description of PWM Registers                      | 11-3  |
| (1)        | PWM counters (PWC0, PWC1)                         | 11-3  |
| (2)        | PWM cycle registers (PWCY0, PWCY1)                | 11-3  |
| (3)        | PWM registers (PWR0 to PWR3)                      | 11-4  |
| (4)        | PWM control register 0 (PWCON0)                   | 11-4  |
| (5)        | PWM control register 1 (PWCON1)                   | 11-6  |
| 11.3.2     | Example of PWM-related Register Settings          | 11-7  |
| •          | 8-bit PWM settings                                | 11-7  |
| (1)        | Port 7 mode register (P7IO)                       | 11-7  |
| (2)        | Port 8 mode register (P8IO)                       | 11-7  |
| (3)        | Port 7 secondary function control register (P7SF) | 11-7  |
| (4)        | Port 8 secondary function control register (P8SF) | 11-7  |
| (5)        | PWM counters (PWC0, PWC1)                         | 11-7  |
| (6)        | PWM cycle registers (PWCY0, PWCY1)                | 11-7  |
| (7)        | PWM registers (PWR0 to PWR3)                      | 11-7  |
| (8)        | PWM control register 0 (PWCON0)                   | 11-8  |
| •          | 16-bit PWM settings                               | 11-8  |
| (1)        | Port 7 mode register (P7IO)                       | 11-8  |
| (2)        | Port 8 mode register (P8IO)                       | 11-8  |
| (3)        | Port 7 secondary function control register (P7SF) | 11-8  |
| (4)        | Port 8 secondary function control register (P8SF) | 11-8  |
| (5)        | PWM counters (PWC0, PWC1)                         | 11-8  |
| (6)        | PWM cycle register (PWCY)                         | 11-8  |
| (7)        | PWM registers (PWR01, PWR23)                      | 11-8  |
| (8)        | PWM control register 0 (PWCON0)                   | 11-9  |
| (9)        | PWM control register 1 (PWCON1)                   | 11-9  |
| 11.4 PV    | VM Operation                                      | 11-9  |
| 11.4.1     | PWM Operation During 8-bit Mode                   | 11-9  |
| 11.4.2     | PWM Operation During 16-bit Mode                  | 11-10 |
| 11.4.3     | PWM Operation During High-Speed Mode              | 11-12 |
| 11.5 PV    | VM Interrupts                                     | 11-14 |
| Chapter 12 | Serial Port Functions                             |       |
| •          | verview                                           | 12-1  |
|            | rial Port Configuration                           |       |
|            | rial Port Registers                               |       |
|            | D1                                                |       |
|            | SIO1 Configuration                                |       |

| 12.4.2  | Description of SIO1 Registers                           | 12-4  |
|---------|---------------------------------------------------------|-------|
| (1)     | SIO1 transmit control register (ST1CON)                 | 12-4  |
| (2)     | SIO1 receive control register (SR1CON)                  | 12-6  |
| (3)     | SIO1 status register (S1STAT)                           | 12-8  |
| (4)     | SIO1 transmit-receive buffer register (S1BUF)           | 12-10 |
| (5)     | SIO1 transmit shift register, receive shift register    | 12-10 |
| 12.4.3  | Example of SIO1-related Register Settings               | 12-11 |
| 12.     | 4.3.1 UART Mode Settings                                | 12-11 |
| •       | Transmit settings                                       | 12-11 |
| (1)     | Port 8 mode register (P8IO)                             | 12-11 |
| (2)     | Port 8 secondary function control register (P8SF)       | 12-11 |
| (3)     | SIO1 transmit control register (ST1CON)                 | 12-11 |
| (4)     | SIO1 receive control register (SR1CON)                  | 12-11 |
| (5)     | SIO1 transmit-receive buffer register (S1BUF)           | 12-11 |
| •       | Receive settings                                        | 12-11 |
| (1)     | Port 8 mode register (P8IO)                             | 12-11 |
| (2)     | Port 8 secondary function control register (P8SF)       | 12-11 |
| (3)     | SIO1 receive control register (SR1CON)                  | 12-12 |
| 12.     | 4.3.2 Synchronous Mode Settings                         | 12-12 |
| •       | Transmit settings                                       | 12-12 |
| (1)     | Port 8 mode register (P8IO)                             | 12-12 |
| (2)     | Port 8 secondary function control register (P8SF)       | 12-12 |
| (3)     | SIO1 transmit control register (ST1CON)                 | 12-12 |
| (4)     | SIO1 transmit-receive buffer register (S1BUF)           | 12-12 |
| •       | Receive settings                                        | 12-13 |
| (1)     | Port 8 mode register (P8IO)                             | 12-13 |
| (2)     | Port 8 secondary function control register (P8SF)       | 12-13 |
| (3)     | SIO1 receive control register (SR1CON)                  | 12-13 |
| 12.     | 4.3.3 Baud Rate Generator (Timer 4) Settings            | 12-13 |
| (1)     | General-purpose 8-bit timer 4 counter (TM4C)            | 12-13 |
| (2)     | General-purpose 8-bit timer 4 control register (TM4CON) | 12-13 |
| 12.4.4  | SIO1 Interrupt                                          | 12-14 |
| 12.5 SI | 06                                                      | 12-15 |
| 12.5.1  | SIO6 Configuration                                      | 12-15 |
| 12.5.2  | Description of SIO6 Registers                           | 12-16 |
| (1)     | SIO6 transmit control register (ST6CON)                 | 12-16 |
| (2)     | SIO6 receive control register (SR6CON)                  | 12-18 |
| (3)     | SIO6 status register (S6STAT)                           | 12-20 |
| (4)     | SIO6 transmit-receive buffer register (S6BUF)           | 12-22 |
| (5)     | SIO6 transmit shift register, receive shift register    | 12-22 |

| 12.5.3  | Example of SIO6-related Register Settings               | 12-23 |
|---------|---------------------------------------------------------|-------|
| 12.5    | 5.3.1 UART Mode Settings                                | 12-23 |
| •       | Transmit settings                                       | 12-23 |
| (1)     | Port 15 mode register (P15IO)                           | 12-23 |
| (2)     | Port 15 secondary function control register (P15SF)     | 12-23 |
| (3)     | SIO6 transmit control register (ST6CON)                 | 12-23 |
| (4)     | SIO6 receive control register (SR6CON)                  | 12-23 |
| (5)     | SIO6 transmit-receive buffer register (S6BUF)           | 12-23 |
| •       | Receive settings                                        | 12-23 |
| (1)     | Port 15 mode register (P15IO)                           | 12-23 |
| (2)     | Port 15 secondary function control register (P15SF)     | 12-23 |
| (3)     | SIO6 receive control register (SR6CON)                  | 12-24 |
| 12.     | 5.3.2 Synchronous Mode Settings                         | 12-24 |
| •       | Transmit settings                                       | 12-24 |
| (1)     | Port 15 mode register (P15IO)                           | 12-24 |
| (2)     | Port 15 secondary function control register (P15SF)     | 12-24 |
| (3)     | SIO6 transmit control register (ST6CON)                 | 12-24 |
| (4)     | SIO6 transmit-receive buffer register (S6BUF)           | 12-24 |
| •       | Receive settings                                        | 12-25 |
| (1)     | Port 15 mode register (P15IO)                           | 12-25 |
| (2)     | Port 15 secondary function control register (P15SF)     | 12-25 |
| (3)     | SIO6 receive control register (SR6CON)                  | 12-25 |
| 12.     | 5.3.3 Baud Rate Generator (Timer 3) Settings            | 12-25 |
| (1)     | General-purpose 8-bit timer 3 counter (TM3C)            | 12-25 |
| (2)     | General-purpose 8-bit timer 3 control register (TM3CON) | 12-25 |
| 12.5.4  | SIO6 Interrupt                                          | 12-26 |
| 12.6 SI | O1, SIO6 Operation                                      | 12-27 |
| 12.6.1  | Transmit Operation                                      | 12-27 |
| •       | UART mode                                               | 12-27 |
| •       | Synchronous mode                                        | 12-28 |
| 12.6.2  | Receive Operation                                       | 12-35 |
| •       | UART mode                                               | 12-35 |
| •       | Synchronous mode                                        | 12-36 |
| 12.7 SI | 04                                                      | 12-40 |
| 12.7.1  | SIO4 Configuration                                      | 12-40 |
| 12.7.2  | Description of SIO4 Registers                           | 12-41 |
| (1)     | SIO4 control register (SIO4CON)                         | 12-41 |
| (2)     | FIFO control register (FIFOCON)                         | 12-43 |
| (3)     | Serial input FIFO data register (SIN4)                  | 12-45 |
| (4)     | Serial output FIFO data register (SOLIT4)               | 12-45 |

| 12.7.3     | Example of SIO4-related Register Settings           | 12-46 |
|------------|-----------------------------------------------------|-------|
| •          | Master mode settings                                | 12-46 |
| (1)        | Port 10 mode register (P10IO)                       | 12-46 |
| (2)        | Port 10 secondary function control register (P10SF) | 12-46 |
| (3)        | Serial output FIFO data register (SOUT4)            |       |
| (4)        | SIO4 control register (SIO4CON)                     | 12-46 |
| •          | Slave mode settings                                 | 12-47 |
| (1)        | Port 10 mode register (P10IO)                       | 12-47 |
| (2)        | Port 10 secondary function control register (P10SF) | 12-47 |
| (3)        | Sserial output FIFO data register (SOUT4)           | 12-47 |
| (4)        | SIO4 control register (SIO4CON)                     | 12-47 |
| 12.7.4     | SIO4 Interrupt                                      | 12-48 |
| 12.7.5     | SIO4 Operation                                      | 12-49 |
| 12.8 SI    | 05                                                  | 12-51 |
| 12.8.1     | SIO5 Configuration                                  | 12-51 |
| 12.8.2     | Description of SIO5 Registers                       | 12-52 |
| (1)        | SIO5 control register (SIO5CON)                     | 12-52 |
| (2)        | Serial input FIFO data register (SIN5)              | 12-54 |
| (3)        | Serial output FIFO data register (SOUT5)            | 12-54 |
| (4)        | FIFO mode control register (FIFOMOD)                | 12-54 |
| 12.8.3     | Example of SIO5-related Register Settings           | 12-57 |
| •          | Master mode settings                                | 12-57 |
| (1)        | Port 14 mode register (P14IO)                       | 12-57 |
| (2)        | Port 14 secondary function control register (P14SF) | 12-57 |
| (3)        | Serial output FIFO data register (SOUT5)            | 12-57 |
| (4)        | SIO5 control register (SIO5CON)                     | 12-57 |
| •          | Slave mode settings                                 | 12-58 |
| (1)        | Port 14 mode register (P14IO)                       | 12-58 |
| (2)        | Port 14 secondary function control register (P14SF) | 12-58 |
| (3)        | Serial output FIFO data register (SOUT5)            | 12-58 |
| (4)        | SIO5 control register (SIO5CON)                     | 12-58 |
| 12.8.4     | SIO5 Interrupt                                      | 12-59 |
| 12.8.5     | SIO5 Operation                                      | 12-60 |
|            |                                                     |       |
|            |                                                     |       |
| Chapter 13 |                                                     |       |
| 13.1 O     | /erview                                             | 13-1  |
| 13.2 A/    | D Converter Configuration                           | 13-1  |
| 13.3 A/    | D Converter Registers                               | 13-2  |
| 13.3.1     | Description of A/D Converter Registers              | 13-3  |
| (1)        | A/D control register 0L (ADCON0L)                   | 13-3  |

| (2)        | A/D control register 0H (ADCON0H)                   | 13-5  |
|------------|-----------------------------------------------------|-------|
| (3)        | A/D interrupt control register (ADINT0)             | 13-7  |
| (4)        | A/D result registers (ADR00 to ADR07)               | 13-8  |
| 13.3.2     | Example of A/D Converter-related Register Settings  | 13-9  |
| •          | Scan mode setting                                   | 13-9  |
| (1)        | A/D control register 0H (ADCON0H)                   | 13-9  |
| (2)        | A/D interrupt control register (ADINT0)             | 13-9  |
| (3)        | A/D control register 0L (ADCON0L)                   | 13-9  |
| •          | Select mode setting                                 | 13-9  |
| (1)        | A/D interrupt control register (ADINT0)             | 13-9  |
| (2)        | A/D control register 0H (ADCON0H)                   | 13-9  |
| 13.4 A/    | D Converter Operation                               | 13-10 |
| 13.5 No    | otes Regarding Usage of A/D Converter               | 13-11 |
| 13.5.1     | Considerations When Setting the Conversion Time     | 13-11 |
|            | Noise-Suppression Measures                          |       |
| 13.6 A/    | D Converter Interrupt                               | 13-14 |
|            |                                                     |       |
| Chapter 14 | D/A Converter Functions                             |       |
|            | verview                                             |       |
|            | A Converter Configuration                           |       |
|            | A Converter Registers                               |       |
| 14.3.1     | Description of D/A Converter Registers              |       |
| (1)        | 3 ( , , ,                                           |       |
| (2)        | DA control register (DACON)                         |       |
| 14.3.2     | Example of D/A Converter-related Register Settings  |       |
| (1)        | Port 14 mode register (P14IO)                       |       |
| (2)        | Port 14 secondary function control register (P14SF) |       |
| (3)        | DA registers (DAR0, DAR1)                           |       |
| (4)        | DA control register (DACON)                         |       |
| 14.3.3     | 3 D/A Converter Operation                           | 14-4  |
| Chapter 15 | 5 Peripheral Functions                              |       |
| -          | /erview                                             | 15_1  |
|            | escription of Each Peripheral Function              |       |
|            | Clock Out Function                                  |       |
|            | External XTCLK Input Control Function               |       |
|            | B HOLD Input Control Function                       |       |
|            | WAIT Input Control Function                         |       |
|            | eripheral Control Register (PRPHCON)                |       |
| 10.0 1 6   | inplication togotor (FRI 110014)                    | 13-2  |

| Chapter 16 | External Interrupt Functions                             |       |
|------------|----------------------------------------------------------|-------|
| 16.1 Ov    | erview                                                   | 16-1  |
| 16.2 Ex    | ternal Interrupt Registers                               | 16-1  |
| 16.2.1     | Description of External Interrupt Registers              | 16-2  |
| (1)        | External interrupt control register 0 (EXI0CON)          | 16-2  |
| (2)        | External interrupt control register 1 (EXI1CON)          | 16-3  |
| (3)        | External interrupt control register 2 (EXI2CON)          | 16-4  |
| 16.2.2     | Example of External Interrupt-related Register Settings. | 16-5  |
| (1)        | Port 6 mode register (P6IO)                              | 16-5  |
| (2)        | Port 9 mode register (P9IO)                              | 16-5  |
| (3)        | Port 6 secondary function control register (P6SF)        | 16-5  |
| (4)        | Port 9 secondary function control register (P9SF)        | 16-5  |
| (5)        | External interrupt control register 0 (EXI0CON)          | 16-5  |
| (6)        | External interrupt control register 1 (EXI1CON)          | 16-5  |
| (7)        | External interrupt control register 2 (EXI2CON)          |       |
| 16.3 EX    | INT0 to EXINT7 Interrupts                                | 16-6  |
|            |                                                          |       |
| Chapter 17 | Interrupt Processing Functions                           |       |
| 17.1 Ov    | erview                                                   | 17-1  |
| 17.2 Int   | errupt Function Registers                                | 17-2  |
| 17.3 De    | scription of Interrupt Processing                        | 17-3  |
| 17.3.1     | Non-Maskable Interrupt (NMI)                             | 17-3  |
| 17.3.2     | Maskable Interrupts                                      | 17-5  |
| (1)        | Interrupt request registers (IRQ0 to IRQ4)               | 17-5  |
| (2)        | Interrupt enable registers (IE0 to IE4)                  | 17-5  |
| (3)        | Master interrupt enable flag (MIE)                       | 17-5  |
| (4)        | Master interrupt priority flag (MIPF)                    | 17-5  |
| (5)        | Interrupt priority control registers (IP0 to IP9)        | 17-6  |
| 17.3.3     | Priority Control of Maskable Interrupts                  | 17-10 |
| (1)        | Basic interrupt control                                  | 17-10 |
| (2)        | Multiple interrupt control                               |       |
|            | Q, IE and IP Register Configurations for Each Interrupt  |       |
| 17.4.1     | Interrupt Request Registers (IRQ0 to IRQ4)               |       |
| (1)        | Interrupt request register 0 (IRQ0)                      |       |
| (2)        | Interrupt request register 1 (IRQ1)                      |       |
| (3)        | Interrupt request register 2 (IRQ2)                      |       |
| (4)        | Interrupt request register 3 (IRQ3)                      |       |
| (5)        | Interrupt request register 4 (IRQ4)                      |       |
|            | Interrupt Enable Registers (IE0 to IE4)                  |       |
| (1)        | Interrupt enable register 0 (IE0)                        | 17-17 |

| (2)        | Interrupt enable register 1 (IE1)                 | 17-18 |
|------------|---------------------------------------------------|-------|
| (3)        | Interrupt enable register 2 (IE2)                 | 17-19 |
| (4)        | Interrupt enable register 3 (IE3)                 | 17-20 |
| (5)        | Interrupt enable register 4 (IE4)                 | 17-21 |
| 17.4.3     | Interrupt Priority Control Registers (IP0 to IP9) | 17-22 |
| (1)        | Interrupt priority control register 0 (IP0)       | 17-22 |
| (2)        | Interrupt priority control register 1 (IP1)       | 17-23 |
| (3)        | Interrupt priority control register 2 (IP2)       | 17-24 |
| (4)        | Interrupt priority control register 3 (IP3)       | 17-25 |
| (5)        | Interrupt priority control register 4 (IP4)       | 17-26 |
| (6)        | Interrupt priority control register 5 (IP5)       | 17-27 |
| (7)        | Interrupt priority control register 6 (IP6)       | 17-28 |
| (8)        | Interrupt priority control register 7 (IP7)       | 17-29 |
| (9)        | Interrupt priority control register 8 (IP8)       | 17-30 |
| (10)       | Interrupt priority control register 9 (IP9)       | 17-31 |
| Chapter 18 | Bus Port Functions                                |       |
| 18.1 Ov    | erview                                            | 18-1  |
| 18.2 Po    | rt Operation                                      | 18-1  |
| 18.2.1     | Port Operation When Accessing Program Memory      | 18-1  |
| 18.2.2     | Port Operation When Accessing Data Memory         | 18-4  |
| 18.3 Ex    | ternal Memory Access                              | 18-6  |
| 18.3.1     | External Program Memory Access                    | 18-6  |
| 18.3.2     | External Data Memory Access                       | 18-8  |
| 18.4 Ex    | ternal Memory Access Timing                       | 18-10 |
| 18.4.1     | External Program Memory Access Timing             | 18-10 |
| 18.4.2     | External Data Memory Access Timing                | 18-12 |
| 18.5 No    | tes Regarding Usage of Bus Port Function          | 18-16 |
| 18.5.1     | Dummy Read Strobe Output                          | 18-16 |
| 18.5.2     | External Bus Access Timing                        | 18-18 |
| Chapter 19 | Flash Memory                                      |       |
| 19.1 Ov    | erview                                            | 19-1  |
| 19.2 Fe    | atures                                            | 19-1  |
| 19.3 Pro   | ogramming Modes                                   | 19-2  |
|            | rallel Mode                                       |       |
| 19.4.1     | Overview of the Parallel Mode                     | 19-4  |
|            | PROM Writer Setting                               |       |
| 19.4.3     | Flash Memory Programming Conversion Adapter       | 19-4  |

| 19.5 Ser   | al Mode                                                        | 19-5  |
|------------|----------------------------------------------------------------|-------|
| 19.5.1     | Overview of the Serial Mode                                    | 19-5  |
| 19.5.2     | Serial Mode Settings                                           | 19-5  |
| (1)        | Pins used in serial mode                                       | 19-5  |
| (2)        | Serial mode connection circuit                                 | 19-6  |
| (3)        | Serial mode programming method                                 | 19-8  |
| (4)        | Setting of security function                                   | 19-8  |
| (5)        | Notes on use of serial mode                                    | 19-8  |
| 19.6 Use   | r Mode                                                         | 19-9  |
| 19.6.1     | Overview of the User Mode                                      | 19-9  |
| 19.6.2     | Jser Mode Programming Registers                                | 19-10 |
| 19.6.3     | Description of User Mode Registers                             | 19-11 |
| (1)        | Flash memory address register (FLAADRS)                        | 19-11 |
| (2)        | Flash memory acceptor (FLAACP)                                 | 19-11 |
| (3)        | Flash memory control register (FLACON)                         | 19-12 |
| 19.6.4     | Jser Mode Programming Example                                  | 19-15 |
| (1)        | Jser mode programming flowchart example                        | 19-15 |
| (2)        | Jser mode programming program example                          | 19-16 |
| 19.6.5     | Notes on Use of User Mode                                      | 19-16 |
| 19.7 Not   | es on Program                                                  | 19-17 |
| (1)        | Programming of flash memory immediately after power-on         | 19-17 |
| (2)        | Note on STOP mode release                                      | 19-17 |
| (3)        | Supply voltage sense reset function                            | 19-17 |
| Chapter 20 | Electrical Characteristics                                     |       |
| 20.1 Abs   | olute Maximum Ratings                                          | 20-1  |
|            | commended Operating Conditions                                 |       |
| 20.3 Allo  | wable Output Current Values                                    | 20-2  |
| 20.4 Inte  | rnal Flash ROM Programming Conditions                          | 20-2  |
| 20.5 DC    | Characteristics                                                | 20-3  |
| 20.5.1     | DC Characteristics (V <sub>DD</sub> = 4.5 to 5.5 V)            | 20-3  |
| 20.5.2     | DC Characteristics (V <sub>DD</sub> = 2.4 to 3.6 V)            | 20-5  |
| 20.6 AC    | Characteristics                                                | 20-7  |
| 20.6.1     | AC Characteristics (V <sub>DD</sub> = 4.5 to 5.5 V)            | 20-7  |
| 20.6.2     | AC Characteristics (V <sub>DD</sub> = 2.4 to 3.6 V)            | 20-15 |
| 20.7 A/D   | Converter Characteristics                                      | 20-23 |
| 20.7.1     | A/D Converter Characteristics (V <sub>DD</sub> = 4.5 to 5.5 V) | 20-23 |
| 20.7.2     | A/D Converter Characteristics (V <sub>DD</sub> = 2.4 to 3.6 V) | 20-23 |
| 20.8 D/A   | Converter Characteristics                                      | 20-25 |
|            |                                                                |       |

| Chapter  | 21         | Special Function Registers (SFRs) |
|----------|------------|-----------------------------------|
| 21.1     | Overview   | 21-                               |
| 21.2     | List of SF | Rs21-                             |
| Chapter  | 22         | Package Dimensions22-             |
| Note on  | Program    | ming A-                           |
| Revision | n History  | R-                                |

## Chapter 1

## Overview

### 1. Overview

### 1.1 Overview

The MSM66577 family of highly functional CMOS 16-bit single chip microcontrollers utilizes the nX-8/500S, Oki's proprietary CPU core.

Four channels of serial ports, consisting of two channels of synchronous serial ports with 32-byte FIFO registers and two channels of UART/synchronous serial ports, enable easy interfacing with external peripheral LSI devices such as an encoder/decoder or servocontroller.

A switching function permits selection of separate address and data lines or multiplexed lines for the bus interface to correspond to various peripheral LSI devices.

With features such as a dual clock function, programmable pull-up ports in which individual bits can be programmed, and a small, thin package, the MSM66577 family of microcontrollers is optimally suited for the system control of small-sized devices.

Reprogrammable Flash ROM versions (MSM66Q577LY/MSM66Q577) that operate on a single power supply ( $V_{DD} = 3.0$  to 3.6 V/4.5 to 5.5 V) are available.

### 1.2 Features

The MSM66577 family has the following features.

- Instruction set with a wide variety of instructions
  - Dual instruction set
  - · 8- and 16-bit arithmetic instructions
  - Multiply and divide instructions (High speed multiplier is not provided)
  - · Bit manipulate instructions
  - · Bit logical instructions
  - ROM table reference instructions
- Variety of addressing modes
  - · Register addressing
  - · Page addressing
  - · Pointing register indirect addressing
  - Stack addressing
  - · Immediate addressing
- Minimum instruction cycles
  - 67 ns at 30 MHz (4.5 to 5.5 V)
  - 143 ns at 14 MHz (2.4 to 3.6 V)
  - 61 μs at 32.768 kHz (2.4 to 3.6 V/4.5 to 5.5 V)
- Clock oscillation circuits
  - Main clock: 30 MHz (max.) crystal oscillator or ceramic resonator oscillator circuit
  - Subclock : 32.768 kHz crystal oscillator circuit

## MSM66577 Family User's Manual Chapter 1 Overview

- Program memory (ROM)
  - Internal 128KB
  - External 1MB (in the case of EA pin activated)
- Data memory (RAM)
  - Internal 4KB
  - External 1020KB
- I/O ports
  - Input ports
    I/O ports
    8 ports (secondary function is an analog input port)
    T4 ports max. (with programmable pull-up resistors)
- Timers
  - Free-running counter 16 bits × 1
  - General-purpose auto reload timer 16 bits × 1, 8 bits × 1
  - 8-bit auto reload timer × 2

Also functions as a 16-bit auto reload timer × 1

- Baud rate generator and 8-bit auto reload timer  $\times$  3
- Watchdog timer × 1

Also functions as an 8-bit auto reload timer

8-bit PWM × 4

(can also be used as two 16-bit PWMs)

- 8-bit serial ports
  - UART/Synchronous × 2
  - Synchronous, with 32-byte FIFO × 2
- A/D converter
  - 10-bit resolution, 8 channels
- D/A converter
  - 8-bit resolution, 2 channels
- Interrupts
  - Non-maskable: 1
  - Maskable: 8 external, 30 internal (29 vectors)
  - Three levels of priority
- ROM window function
- Standby modes
  - HALT mode
  - HOLD mode
  - STOP mode

### Package

• 100-pin plastic TQFP (TQFP100-P-1414-0.50-K) (For external dimensions, refer to Chapter 22)

Table 1-1 MSM66577 Family of Products

| Parameter                   | MSM66577L                                                  | MSM66577                                  |  |  |
|-----------------------------|------------------------------------------------------------|-------------------------------------------|--|--|
| Operating temperature range | -30°C to +70°C                                             |                                           |  |  |
| Power supply voltage/       | $V_{DD} = 2.4 \text{ to } 3.6 \text{ V/}$                  | $V_{DD} = 4.5 \text{ to } 5.5 \text{ V/}$ |  |  |
| maximum operating frequency | f = 14 MHz                                                 | f = 30 MHz                                |  |  |
| Minimum instruction         | 143 ns at 14 MHz                                           | 67 ns at 30 MHz                           |  |  |
| execution time              | (2.4 to 3.6 V)                                             | (4.5 to 5.5 V)                            |  |  |
|                             | 61 μs at 32.768 kHz (2                                     | 2.4 to 3.6/4.5 to 5.5 V)                  |  |  |
| Internal ROM size           | M size 128KB                                               |                                           |  |  |
| (max. external)             | (1M                                                        | MB)                                       |  |  |
| Internal RAM size           | 4k                                                         | (B                                        |  |  |
| (max. external)             | (1N                                                        | ИВ)                                       |  |  |
|                             | 74 I/C                                                     | ) pins                                    |  |  |
| I/O ports                   | (with programmabl                                          | e pull-up resistors)                      |  |  |
|                             | 8 input-c                                                  | only pins                                 |  |  |
|                             | 16-bit free runn                                           | ing timer × 1 ch                          |  |  |
|                             | Compare out/capture input × 2 ch                           |                                           |  |  |
|                             | 16-bit timer (auto reload/timer out) × 1 ch                |                                           |  |  |
|                             | 8-bit auto reload timer $\times$ 2 ch                      |                                           |  |  |
|                             | (can also be used as 16-bit timer × 1 ch)                  |                                           |  |  |
| Timers                      | 8-bit auto reloa                                           | ad timer × 1 ch                           |  |  |
| Timers                      | 8-bit auto reload timer × 3 ch                             |                                           |  |  |
|                             | (also functions as serial comm                             | unication baud rate generator)            |  |  |
|                             | Watchdog timer (also functions as 8-bit auto reload timer) |                                           |  |  |
|                             | Watch timer (Real-time counter) × 1 ch                     |                                           |  |  |
|                             | 8-bit PWM × 4 ch                                           |                                           |  |  |
|                             | (can also be used as 16-bit PWM × 2 ch)                    |                                           |  |  |
| Carial part                 | UART/Synchronous × 2 ch                                    |                                           |  |  |
| Serial port                 | Synchronous, with 32-byte FIFO × 2 ch                      |                                           |  |  |
| A/D converter               | 10-bit A/D c                                               | onverter × 8                              |  |  |
| D/A converter               | 8-bit D/A co                                               | onverter × 2                              |  |  |
| External interrupt          | Non-maska                                                  | able × 1 ch                               |  |  |
| External interrupt          | Maskable × 8 ch                                            |                                           |  |  |
| Interrupt priority          | 3 le                                                       | vels                                      |  |  |
|                             | External bus interface                                     |                                           |  |  |
| Others                      | (separate address/data bus type/multiplexed bus type)      |                                           |  |  |
|                             | Bus release function                                       |                                           |  |  |
|                             | Dual clock function                                        |                                           |  |  |
|                             | Clock gear function                                        |                                           |  |  |
| FLASH ROM version           | MSM66Q577LY (3.0 to 3.6 V)                                 | MSM66Q577                                 |  |  |
|                             | •                                                          |                                           |  |  |

### 1.3 Block Diagram



Figure 1-1 MSM66577 Family Block Diagram

### 1.4 Pin Configuration (Top View)



[Note] When selecting a multiplexed bus

Figure 1-2 MSM66577 Family Pin Configuration (100-pin TQFP package)

\* For the external dimensions of the package, refer to Chapter 22, "Package Dimensions". For the connections of unused pins, refer to Section 1.5.3.

## 1.5 Pin Descriptions

### 1.5.1 Description of Each Pin

Table 1-2 lists the function of each pin in the MSM66577 family. In the I/O column, "I" indicates an input pin, "O" indicates an output pin, and "I/O" indicates an I/O pin.

Table 1-2 Pin Descriptions (1/3)

| 01!fiti        | Di            |     | Function                          |     |                                        |  |
|----------------|---------------|-----|-----------------------------------|-----|----------------------------------------|--|
| Classification | on Pin name   |     | Primary function                  | I/O | Secondary function                     |  |
| Port           | P0_0/D0 (AD0) | I/O | 8-bit I/O port                    | I/O | External memory access                 |  |
|                | to            |     | 10 mA sink capability             |     | Data I/O port                          |  |
|                | P0_7/D7 (AD7) |     | Pull-up resistors can be          |     | (Address output/data I/O port          |  |
|                |               |     | specified for each individual bit |     | when a multiplexed bus is selected)    |  |
|                | P1_0/A8       | I/O | 8-bit I/O port                    | 0   | External memory access                 |  |
|                | to            |     | Pull-up resistors can be          |     | Address output port                    |  |
|                | P1_7/A15      |     | specified for each individual bit |     |                                        |  |
|                | P2_0/A16      | I/O | 4-bit I/O port                    | 0   | External memory access                 |  |
|                | to            |     | Pull-up resistors can be          |     | Address output port                    |  |
|                | P2_3/A19      |     | specified for each individual bit |     |                                        |  |
|                | P3_0/ALE      | I/O | 4-bit I/O port                    | 0   | External memory access                 |  |
|                |               |     | 10 mA sink capability             |     | Address latch enable signal output pin |  |
|                | P3_1/PSEN     |     | Pull-up resistors can be          | 0   | External program memory access         |  |
|                |               |     | specified for each individual bit |     | Read strobe output pin                 |  |
|                | P3_2/RD       |     |                                   | 0   | External memory access                 |  |
|                |               |     |                                   |     | Read strobe output pin                 |  |
|                | P3_3/WR       |     |                                   | 0   | External memory access                 |  |
|                |               |     |                                   |     | Write strobe output pin                |  |
|                | P4_0/A0       | I/O | 8-bit I/O port                    | 0   | External memory access                 |  |
|                | to            |     | Pull-up resistors can be          |     | Address output port                    |  |
|                | P4_7/A7       |     | specified for each individual bit |     | (when a separate bus is selected)      |  |
|                | P5_4/CPCM0    | I/O | 4-bit I/O port                    | I/O | Capture 0 input/ Compare               |  |
|                |               |     | Pull-up resistors can be          |     | 0 output pin                           |  |
|                | P5_5/CPCM1    |     | specified for each individual bit | I/O | Capture 1 input/ Compare               |  |
|                |               |     |                                   |     | 1 output pin                           |  |
|                | P5_6/TM0OUT   |     |                                   | 0   | Timer 0 timer output pin               |  |
|                | P5_7/TM0EVT   |     |                                   | ı   | Timer 0 external event input pin       |  |
|                | P6_0/EXINT0   | I/O | 8-bit I/O port                    | I   | External interrupt 0 input pin         |  |
|                | P6_1/EXINT1   |     | Pull-up resistors can be          | I   | External interrupt 1 input pin         |  |
|                | P6_2/EXINT2   |     | specified for each individual bit | I   | External interrupt 2 input pin         |  |
|                | P6_3/EXINT3   |     |                                   | ı   | External interrupt 3 input pin         |  |
|                | P6_4/TM1EVT   |     |                                   | I   | Timer 1 external event input pin       |  |
|                | P6_5/TM1OUT   |     |                                   | 0   | Timer 1 timer output pin               |  |
|                | P6_6/TM2EVT   |     |                                   | ı   | Timer 2 external event input pin       |  |
|                | P6_7/TM2OUT   |     |                                   | 0   | Timer 2 timer output pin               |  |

## Table 1-2 Pin Descriptions (2/3)

| Classification | Din name     |     | Function                          |     |                                     |  |
|----------------|--------------|-----|-----------------------------------|-----|-------------------------------------|--|
| Classification | Pin name     | I/O | Primary function                  | 1/0 | Secondary function                  |  |
| Port           | P7_6/PWM0OUT | I/O | 2-bit I/O port                    | 0   | PWM0 output pin                     |  |
|                | P7_7/PWM1OUT |     | Pull-up resistors can be          | 0   | PWM1 output pin                     |  |
|                |              |     | specified for each individual bit |     |                                     |  |
|                | P8_0/RXD1    | I/O | 7-bit I/O port                    | ı   | SIO1 receive data input pin         |  |
|                | P8_1/TXD1    |     | Pull-up resistors can be          | 0   | SIO1 transmit data output pin       |  |
|                | P8_2/RXC1    |     | specified for each individual bit | I/O | SIO1 receive clock I/O pin          |  |
|                | P8_3/TXC1    |     |                                   | I/O | SIO1 transmit clock I/O pin         |  |
|                | P8_4/TM4OUT  |     |                                   | 0   | Timer 4 timer output pin            |  |
|                | P8_6/PWM2OUT |     |                                   | 0   | PWM2 output pin                     |  |
|                | P8_7/PWM3OUT |     |                                   | 0   | PWM3 output pin                     |  |
|                | P9_0/EXINT4  | I/O | 5-bit I/O port                    | ı   | External interrupt 4 input pin      |  |
|                | P9_1/EXINT5  |     | Pull-up resistors can be          | ı   | External interrupt 5 input pin      |  |
|                | P9_2/EXINT6  |     | specified for each individual bit | ı   | External interrupt 6 input pin      |  |
|                | P9_3/EXINT7  |     |                                   | ı   | External interrupt 7 input pin      |  |
|                | P9_7/HLDACK  |     |                                   | 0   | HOLD mode output pin                |  |
|                | P10_3/SIOCK4 | I/O | 3-bit I/O port                    | I/O | SIO4 transmit-receive clock I/O pin |  |
|                | P10_4/SIOO4  |     | Pull-up resistors can be          | Ι   | SIO4 receive data input pin         |  |
|                | P10_5/SIOI4  |     | specified for each individual bit | 0   | SIO4 transmit data output pin       |  |
|                | P11_0/WAIT   | I/O | 4-bit I/O port                    | ı   | External data memory access         |  |
|                |              |     | 10 mA sink capability             |     | wait input pin                      |  |
|                | P11_1/HOLD   |     | Pull-up resistors can be          | ı   | HOLD mode request input pin         |  |
|                | P11_2/CLKOUT |     | specified for each individual bit | 0   | Main clock pulse output pin         |  |
|                | P11_3/XTOUT  |     |                                   | 0   | Subclock pulse output pin           |  |
|                | P12_0/AI0    | ı   | 8-bit input port                  | 1   | A/D converter analog input port     |  |
|                | to           |     |                                   |     |                                     |  |
|                | P12_7/AI7    |     |                                   |     |                                     |  |
|                | P14_0/SIOCK5 | I/O | 5-bit I/O port                    | I/O | SIO5 transmit-receive clock I/O pin |  |
|                | P14_1/SIOO5  |     | Pull-up resistors can be          | 0   | SIO5 transmit data output pin       |  |
|                | P14_2/SIOI5  |     | specified for each individual bit | ı   | SIO5 receive data input pin         |  |
|                | P14_6/AO0    |     |                                   | 0   | D/A converter analog output port    |  |
|                | P14_7/AO1    |     |                                   | 0   | D/A converter analog output port    |  |
|                | P15_0/RXD6   | I/O | 4-bit I/O port                    | ı   | SIO6 receive data input pin         |  |
|                | P15_1/TXD6   |     | Pull-up resistors can be          | 0   | SIO6 transmit data output pin       |  |
|                | P15_2/RXC6   |     | specified for each individual bit | I/O | SIO6 receive clock I/O pin          |  |
|                | P15_3/TXC6   |     |                                   | I/O | SIO6 transmit clock I/O pin         |  |

Table 1-2 Pin Descriptions (3/3)

| Classification | Pin name         | I/O                                                     | Function                                                                  |  |  |
|----------------|------------------|---------------------------------------------------------|---------------------------------------------------------------------------|--|--|
| Power          | $V_{DD}$         | T                                                       | Power supply pin                                                          |  |  |
| supply         |                  |                                                         | Connect all V <sub>DD</sub> pins to the power supply. *                   |  |  |
|                | GND              | ı                                                       | GND pin                                                                   |  |  |
|                |                  |                                                         | Connect all GND pins to GND. *                                            |  |  |
|                | V <sub>REF</sub> | 1                                                       | Analog reference voltage pin                                              |  |  |
|                | AGND             | 1                                                       | Analog GND pin                                                            |  |  |
| Oscillation    | XT0              | 1                                                       | Subclock oscillation input pin                                            |  |  |
|                |                  |                                                         | Connect to a crystal oscillator of f = 32.768 kHz.                        |  |  |
|                | XT1              | 0                                                       | Subclock oscillation output pin                                           |  |  |
|                |                  |                                                         | Connect to a crystal oscillator of f = 32.768 kHz.                        |  |  |
|                |                  |                                                         | The clock output is opposite in phase to XT0.                             |  |  |
|                | OSC0             | I Main clock oscillation input pin                      |                                                                           |  |  |
|                |                  |                                                         | Connect to a crystal or ceramic oscillator.                               |  |  |
|                |                  |                                                         | When an external clock is used, this pin is configured to be clock input. |  |  |
|                | OSC1             | 0                                                       | Main clock oscillation output pin                                         |  |  |
|                |                  |                                                         | Connect to a crystal or ceramic oscillator.                               |  |  |
|                |                  |                                                         | The clock output is opposite in phase to OSC0.                            |  |  |
|                |                  |                                                         | Leave this pin unconnected when an external clock is used.                |  |  |
| Reset          | RES              | ı                                                       | Reset input pin                                                           |  |  |
| Others         | NMI              | ı                                                       | Non-maskable interrupt input pin                                          |  |  |
|                | EA               | 1                                                       | External program memory access input pin                                  |  |  |
|                |                  |                                                         | If the EA pin is enabled (low level), the internal program memory is      |  |  |
|                |                  | masked and the CPU executes the program code in externa |                                                                           |  |  |
|                |                  |                                                         | memory through all address space.                                         |  |  |
|                | SELMBUS          | 1                                                       | External bus interface setting input pin                                  |  |  |
|                |                  |                                                         | SELMBUS = H: Address/data separate bus type                               |  |  |
|                |                  |                                                         | SELMBUS = L: Multiplexed bus type                                         |  |  |

<sup>\*</sup> Each of the family devices has unique pattern routes for the internal power and ground. Connect the power supply voltage to all V<sub>DD</sub> pins and the ground potential to all GND pins. If a device may have one or more V<sub>DD</sub> or GND pins to which the power supply voltage or the ground potential is not connected, it cannot be guaranteed for normal operation.

## 1.5.2 Pin Configuration

A simplified pin configuration for each pin of the MSM66577 family is shown in Table 1-3 and Figure 1-3.

**Table 1-3 Configuration of Each Pin** 

| Pin name                 | Туре | Pin name           | Туре |
|--------------------------|------|--------------------|------|
| P0_0 to P0_7             | 6    | P9_0 to P9_3, P9_7 | 5    |
| P1_0 to P1_7             | 5    | P10_3 to P10_5     | 5    |
| P2_0 to P2_3             | 5    | P11_0 to P11_3     | 5    |
| P3_0, P3_1               | 4    | P12_0 to P12_7     | 3    |
| P3_2, P3_3               | 5    | P14_0 to P14_2     | 5    |
| P4_0 to P4_7             | 5    | P14_6, P14_7       | 7    |
| P5_4 to P5_7             | 5    | P15_0 to P15_3     | 5    |
| P6_0 to P6_7             | 5    | RES                | 2    |
| P7_6, P7_7               | 5    | SELMBUS, NMI, EA   | 1    |
| P8_0 to P8_4, P8_6, P8_7 | 5    |                    |      |



Figure 1-3 Types of Pin Configurations

### 1.5.3 Connections for Unused Pins

Table 1-4 lists the pin connections for unused pins.

**Table 1-4 Connections for Unused Pins** 

| Pin                         | Pin connection                                    |
|-----------------------------|---------------------------------------------------|
| P0_0 to 0_7                 |                                                   |
| P1_0 to 1_7                 |                                                   |
| P2_0 to 2_3                 |                                                   |
| P3_0 to 3_3                 |                                                   |
| P4_0 to 4_7                 |                                                   |
| P5_4 to 5_7                 | When a programmable pull-up resistor is set: Open |
| P6_0 to 6_7                 | When input is set: High or Low level              |
| P7_6, P7_7                  | When output is set: Open                          |
| P8_0 to P8_4, P8_6, P8_7    |                                                   |
| P9_0 to 9_3, P9_7           |                                                   |
| P10_3 to 10_5               |                                                   |
| P11_0 to 11_3               |                                                   |
| P14_0 to 14_2, P14_6, P14_7 |                                                   |
| P15_0 to 15_3               |                                                   |
| P12_0 to 12_7               | VREF or AGND                                      |
| VREF                        | VDD                                               |
| AGND                        | GND                                               |
| NMI                         | High or Low level                                 |
| ĒĀ                          | High level                                        |
| XT0                         | GND*                                              |
| OSC1, XT1                   | Open                                              |
| SELMBUS                     | GND or V <sub>DD</sub> (Note)                     |

<sup>\*</sup> If the subclock (XT0, XT1) is not used, in addition to connecting the XT0 pin to GND and leaving XT1 unconnected, the peripheral control register (PRPHCON) must be set. For details refer to Chapter 6, "Clock Oscillation Circuit."

[Note] For SELMBUS,

0: Multiplexed bus1: Separate bus

### 1.6 Basic Operational Timing

The MSM66577 family is configured such that one pulse of the main clock (CLK) is one state. In other words, one state is 33.3 ns (at 30 MHz). One instruction cycle consists of more than one state (S1, S2, ..., Sn).

The number of states required for program execution differs depending upon the instruction. The minimum is 2 states and the maximum is 48 states. (For details, refer to the nX-8/500S Core Instruction Manual.)

To achieve high-speed execution of instructions, one byte of the instruction is pre-fetched. While one instruction is being executed, the next instruction will be fetched.

Figure 1-4 through Figure 1-7 show basic timing examples.

If program memory is accessed externally, a number of wait cycles (0 to 3 cycles) specified by the ROM ready control register (ROMRDY) are inserted. If data memory is accessed externally, 2 or 3 cycles (1 cycle = 1 state) are automatically inserted for a 1 byte read or write. In addition, the number of wait cycles (0 to 7 cycles) specified by the RAM ready control register (RAMRDY) will also be inserted.

For external memory access timings, refer to Chapter 18, "Bus Port Functions."



Figure 1-4 Basic Operation Timing Example (Reading Port Data)



Figure 1-5 Basic Operation Timing Example (Writing Port Data)



# [Note]

- The timing when the TM0RUN bit becomes "1" differs depending upon the instruction used.
- The timing for reading TM0C differs depending upon the instruction used.
- The TM0C count timing differs depending upon the selected TM0C clock.

Figure 1-6 Timer 0 Operation Timing Example



# [Note]

- There are 14 interrupt transfer cycles. However, if the program memory space has been extended 1MB, then there will be 17 cycles.
- IRQ is reset to "0" at the 3rd interrupt transfer cycle.

Figure 1-7 Interrupt Transfer Timing Example

# **CPU Architecture**

# 2. CPU Architecture

#### 2.1 Overview

The MSM66577 microcontroller family utilize the nX-8/500S, Oki's proprietary 16-bit CPU core.

The nX-8/500S performs various operations mainly by using an accumulator and register set. Almost all instructions and addressing modes are applicable both to byte-format and word-format data. And it also has bit processing functions.

Program memory space and data memory space are separated and provided respectively. Each can be expanded up to 1MB. In addition, special dedicated addressing modes are provided for some specific portion of data space such as Special Function Registers area, fixed page area, and current page area and so on, for the purpose of efficient programming.

For further details, refer to the "nX-8/500S CPU Core Instruction Manual".

## 2.2 Memory Space

Program memory space and data memory space are set independently. At reset, up to 64 KB (max.) can be accessed for each. By changing settings of the memory size control register (MEMSCON), located in the SFR area, the program memory space and the data memory space can each be expanded up to 1MB.

## 2.2.1 Memory Space Expansion

The memory size control register (MEMSCON) is located in the SFR register and specifies the size of the memory space. The program memory space can be expanded to 1MB by setting the LROM bit (bit 1) to "1". The data memory space can be expanded to 1MB by setting the LRAM bit (bit 0) to "1".



"—" indicates a nonexistent bit. When read, its value will be "1."

Figure 2-1 MEMSCON Configuration

To write to the LROM bit of MEMSCON, write "5H" and then "0AH" to the upper 4 bits of the memory size acceptor (MEMSACP) register located in the SFR area. Likewise, to write to the LRAM bit of MEMSCON, first write "5H" and then "0AH" to the lower 4 bits of the memory size acceptor (MEMSACP).



Figure 2-2 MEMSACP Configuration

Note: If the FJ, FCAL, or FRT instruction is executed while the LROM bit is being reset to "0", the op code trap is generated and system reset will be executed.

If the LROM or LRAM bits are set to "1", the memory space expansion is actually enabled after execution of the instruction that follows the LROM or LRAM bit write instruction. Programming examples to expand the program memory space are listed below.

• SMALL memory space (64KB program memory space, 64KB data memory space)

MOVB MEMSACP, #05H

MOVB MEMSACP, #0AH

MOVB MEMSCON, #00H (initial value)

COMPACT memory space (64KB program memory space, 1MB data memory space)

MOVB MEMSACP, #05H

MOVB MEMSACP, #0AH

MOVB MEMSCON, #01H

MEDIUM memory space (1MB program memory space, 64KB data memory space)

MOVB MEMSACP, #50H

MOVB MEMSACP, #0A0H

MOVB MEMSCON, #02H

LARGE memory space (1MB program memory space, 1MB data memory space)

MOVB MEMSACP, #55H

MOVB MEMSACP, #0AAH

MOVB MEMSCON, #03H

MEMSCON can be written only once after reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap). Therefore, to change the memory space model once set to the other, reset and write again to the MEMSCON.

#### 2.2.2 Program Memory Space

The program memory space is also called "ROM space".

The MSM66577 family can access a maximum of 1MB (1,048,576 bytes) of program memory in 64KB (65,536 bytes) unit segments from segment 0 to 15. However, if more than 64KB (segments 1 to 15) are to be accessed, the LROM bit of the MEMSCON (memory size control register) SFR must be set to "1".

The code segment register (CSR) specifies the segment to be used, and the program counter (PC) specifies the address in the segment. However, the segment to be used in the execution of ROM table reference instructions (such as LC A, obj) and the ROM window function is specified by the table segment register (TSR).

The 128KB (131,072 bytes) area in segments 0 and 1 constitutes the internal ROM area and the 64KB areas in segments 2 to 15 form the external ROM area.

The following areas are assigned to segment 0:

- Vector table area (84 bytes)
- VCAL table area (32 bytes)

In addition, the following area is assigned to each segment.

• ACAL area (2,048 bytes)

Figure 2-3 shows a memory map of the program memory space.



Figure 2-3 Memory Map of Program Memory Space

## (1) Accessing program memory space

Program memory space is accessed by the program counter (PC) and the code segment register (CSR). However, when a ROM table reference instruction (such as LC A, obj) or a ROM window function (refer to Section 4.3) is executed, program memory space is accessed according to the contents of the table segment register (TSR) and the register specified by the instruction.

Access of the internal ROM area and the external memory area of the program memory space is automatically switched by internal device operation depending on the status of the EA pin and program addresses.

When a high level is input to the  $\overline{EA}$  pin, the internal ROM area is accessed if the program address is between 0000H and 1FFFFH, and the external ROM area is accessed if the address is between 20000H to FFFFFH. When the external ROM area is to be accessed, the secondary functions of the external memory control pins (port 0, 1, 2, 3 and 4) must be set.

The area from 0000H to 1FFFDH can be fetched by the internal program. Be careful that the final address of instruction code does not exceed 1FFFDH. The final address of the table data is 1FFFFH.

When a low level is input to the  $\overline{EA}$  pin, the external program memory area is accessed for all program addresses.

If the external memory area of the program memory space is accessed in a separate bus type, Port 0 (data input), Port 4 (addresses A0 to A7 outputs), Port 1 (addresses A8 to A15 outputs) and Port 2 (addresses A16 to A19 outputs) operate as bus ports, and the P3\_1/PSEN pin becomes active.

If the external memory area of the program memory space is accessed in a multiplexed bus type, Port 0 (address output and data input),Port 1 (addresses A8 to A15 outputs) and Port 2 (addresses A16 to A19 outputs) operate as bus ports, and P3\_0/ALE pin and P3\_1/PSEN pin become active.

#### (2) Vector table area

The 74-byte area of addresses from 0000H to 0049H and the 10-byte area of addresses from 006AH to 0073H in segment 0 of program memory space are used as the vector table area that stores branch addresses for all types of resets and interrupts (29 types) as shown in Table 2-1.

If a reset or interrupt occurs, the corresponding 2-byte branch address, stored in the vector table, is loaded into the PC. (The even address contains the lower order data and the odd address contains the upper order data.) At the same time, "0" is loaded into the Code Segment Register (CSR) and program execution starts from the loaded segment 0 address. Therefore, if a reset or interrupt occurs during execution of an instruction in segment 1 (or segment other than 0), program control will branch to an address in segment 0.

With reasons described above, reset routine and interrupt routines must be located in segment 0. This fact is important for medium and large memory model programming. Proper alignment attribute must be applied to your relocatable interrupt routines.

In medium and large memory model you specified by MEMSCON setting, CPU automatically provides extra stack area for the CSR contents. When RTI instruction is executed, CSR contents in stack are re-stored into CSR and program execution is continued in the same program segment.

If this area is not used as a vector table area, it can be used as a normal program area.

Table 2-1 lists the vector table addresses for each type of reset or interrupt.

# [Example] Program starting address of 0200H due to RES pin input

| Program address | <u>Data code</u> |                                              |
|-----------------|------------------|----------------------------------------------|
| 0000H           | 00H              | (lower order data for program start address) |
| 0001H           | 02H              | (upper order data for program start address) |

# **Table 2-1 Vector Table List**

| Vector table     |                                                                                  |  |
|------------------|----------------------------------------------------------------------------------|--|
| starting address | Interrupt or reset factor                                                        |  |
| [H]              |                                                                                  |  |
| 0000             | Reset by RES pin input                                                           |  |
| 0002             | Reset by execution of BRK instruction                                            |  |
| 0004             | Reset by overflow of watchdog timer                                              |  |
| 0006             | Reset by opcode trap                                                             |  |
| 8000             | Interrupt by NMI pin input (non-maskable interrupt)                              |  |
| 000A             | Interrupt by EXINT0 pin input (external interrupt 0)                             |  |
| 000C             | Interrupt by overflow of free running counter                                    |  |
| 0016             | Interrupt by CPCM0 event input, compare match                                    |  |
| 0018             | Interrupt by CPCM1 event input, compare match                                    |  |
| 001A             | Interrupt by overflow of timer 0                                                 |  |
| 001C             | Interrupt by EXINT1 pin input (external interrupt 1)                             |  |
| 001E             | Interrupt by EXINT2 pin input (external interrupt 2)                             |  |
| 0020             | Interrupt by EXINT3 pin input (external interrupt 3)                             |  |
| 0022             | Interrupt by overflow of timer 1                                                 |  |
| 0024             | Interrupt by overflow of timer 2                                                 |  |
| 0026             | Interrupt by overflow of timer 3                                                 |  |
| 0028             | Interrupt by SIO0 transmit buffer empty, transmit completion, receive completion |  |
| 002A             | Interrupt by EXINT4 pin input (external interrupt 4)                             |  |
| 002C             | Interrupt by EXINT5 pin input (external interrupt 5)                             |  |
| 002E             | Interrupt by EXINT6 pin input (external interrupt 6)                             |  |
| 0030             | Interrupt by EXINT7 pin input (external interrupt 7)                             |  |
| 0036             | Interrupt by overflow of timer 4                                                 |  |
| 0038             | Interrupt by SIO1 transmit buffer empty, transmit completion, receive completion |  |
| 003A             | Interrupt by overflow of timer 5                                                 |  |
| 003C             | Interrupt by SIO5 transfer completion                                            |  |
| 003E             | Interrupt by SIO6 transmit buffer empty, transmit completion, receive completion |  |
| 0040             | Interrupt by SIO4 transfer completion                                            |  |
| 0042             | Interrupt by overflow of timer 6                                                 |  |
| 0044             | Interrupt by A/D conversion scan channel cycle completion/select mode completion |  |
| 0048             | Interrupt by real-time counter output (interval: 0.125 to 1 s)                   |  |
| 006A             | Interrupt by PWC0 overflow, PWC0 and PWR0 match                                  |  |
| 006C             | Interrupt by PWC1 overflow, PWC1 and PWR1 match                                  |  |
| 006E             | Interrupt by PWC0 and PWR2 match                                                 |  |
| 0070             | Interrupt by PWC1 and PWR3 match                                                 |  |
| 0072             | Interrupt by overflow of timer 9                                                 |  |

#### (3) VCAL table area

The VCAL table area is assigned to the 32-byte area of program memory space in segment 0 from address 004AH to 0069H and stores branch addresses for 1-byte call instructions (VCAL: 16 types).

If a VCAL instruction is executed, the next address after the VCAL instruction is saved onto the system stack, the system stack pointer (SSP) is decremented by 2, and the corresponding 2-byte address stored in the vector table is loaded into the PC. (The even address contains the lower data and the odd address contains the upper data). The program begins execution from the loaded address.

However, if the program memory space has been expanded to 1MB, the SSP is decremented by 4 because the CSR value is also saved at the same time that the PC is saved. Also, the CSR is loaded with "0" at the same time as the branch address is loaded into the PC. Therefore, if a VCAL instruction is executed in segment 1, program control will branch to a branch address in segment 0.

If the program memory space is up to 64KB (the LROM bit of MEMSCON is "0"), execution of a RT instruction will return program control from the subroutine branched to by the VCAL instruction. If the program memory space is 1MB (the LROM bit is "1"), execution of a FRT instruction returns program control from the subroutine branched to by the VCAL instruction.

If this area is not used as the VCAL table area, it can be used as a normal program area.

Table 2-2 lists the VCAL vector addresses.

## [Example] Program starting address of 0400H due to VCAL 4AH instruction

| Program address | <u>Data code</u> |                                                 |
|-----------------|------------------|-------------------------------------------------|
| 004AH           | 00H              | (lower order data for subroutine start address) |
| 004BH           | 04H              | (upper order data for subroutine start address) |

**Table 2-2 VCAL Vector Address List** 

| VCAL table starting address [H] | VCAL instruction |
|---------------------------------|------------------|
| 004A                            | VCAL 4AH         |
| 004C                            | VCAL 4CH         |
| 004E                            | VCAL 4EH         |
| 0050                            | VCAL 50H         |
| 0052                            | VCAL 52H         |
| 0054                            | VCAL 54H         |
| 0056                            | VCAL 56H         |
| 0058                            | VCAL 58H         |
| 005A                            | VCAL 5AH         |
| 005C                            | VCAL 5CH         |
| 005E                            | VCAL 5EH         |
| 0060                            | VCAL 60H         |
| 0062                            | VCAL 62H         |
| 0064                            | VCAL 64H         |
| 0066                            | VCAL 66H         |
| 0068                            | VCAL 68H         |

## (4) ACAL area

The 2KB area from 1000H to 17FFH of each program segment is called ACAL area. The subroutines located in this area can be called by 2-byte call instruction (ACAL). ACAL is an in-segment call instruction which does not rewrite the CSR contents.

If an ACAL instruction is executed, the address following the next address after the ACAL instruction is saved onto the system stack, the system stack pointer (SSP) is decremented by 2, and 11-bit data included in the ACAL instruction code is loaded into the PC. Program execution begins at the loaded address (1000H to 17FFH).

#### 2.2.3 Data Memory Space

A maximum of 1MB (1,048,576 bytes) of data memory can be accessed.

The following areas are assigned to the data memory space: a special function register area (SFR: 256 bytes), a reserved area (256 bytes), a fixed page area (FIX: 256 bytes), an internal RAM area (4,096 bytes), a local register setting area (2,048 bytes) and an external memory area (1,043,968 bytes).

A pointing register area (PR: 64 bytes) and a special bit addressing area (sbafix: 64 bytes) are assigned to the fixed page area. The ROM window setting area (1200H to 0FFFFH of segment 0 and 1000H to 0FFFFH of segments 1 to 15) is assigned to the external data memory area.

So that data can be exchanged between two or more data segments without changing DSR, there is a common area that starts at data memory address 0H. The SFR area, reserved area and fixed page area always belong to the common area.

Figure 2-4 shows a memory map of the data memory space.



Figure 2-4 Memory Map of Data Memory Space

## (1) Special function register (SFR) area

The group of registers with special functions such as mode registers for internal peripheral hardware, control registers and counters are assigned to the 256-byte area in data memory space from 0000H to 00FFH. Refer to Chapter 21, "Special Function Registers (SFRs)" for a more detailed description.

#### (2) Reserved area

The 256-byte data memory space from 0100H to 01FFH is reserved for future use as an expanded SFR area. This area cannot be used.

#### (3) Internal RAM area

Internal RAM is assigned to the 4,096-byte area in data memory space from 0200H to 11FFH.

#### (4) Fixed page (FIX) area

A pointing register (PR) area and a special bit addressing (sbafix) area are assigned to the 256-byte area in data memory from 0200H to 02FFH.

The pointing register area is assigned to addresses 0200H to 023FH and contains 8 sets of the following 4 registers.

- Index register (X1, X2)
- Data pointer (DP)
- User stack pointer (USP)

All of the above are 16-bit registers. Even addresses contain lower order data and odd addresses contain higher order data.

The special bit address area is assigned to addresses 02C0H to 02FFH. SB, RB, JBR and JBS instructions to this area can be implemented in a small number of bytes.

Figure 2-5 shows the map of the fixed page area.



Figure 2-5 Map of Fixed Page Area

## (5) Local register setting area

The local register setting area is the 2KB area of data memory from 0200H to 09FFH. Local registers are set in 8-byte units, as specified by the lower 8 bits of LRB (LRBL).

Figure 2-6 shows the map of the local register setting area.



Figure 2-6 Map of Local Register Setting Area

#### (6) External data memory area

The external data memory area is the 1,043,968-byte area of data memory from 1200H to 0FFFFH (Note 1). If this external data memory is to be accessed, the secondary functions of memory related pins (ports 0, 1, 2, 3 and 4) must be set. In a separate bus type, the external data memory is accessed by Port 0 (data I/O: D0 to D7), Port 4 (address output: A0 to A7), Port 1 (address output: A8 to A15), Port 2 (address output: A16 to A19), P3\_3/WR (write strobe output function) and P3\_2/RD (read strobe output function) signals.

In a multiplexed bus type, the external data memory is accessed by Port 0 (combined I/O of data input and address output: AD0 to AD7), Port 1 (address output: A8 to A15), Port 2 (address output: A16 to A19), P3\_0/ALE (address latch enable output function), P3\_2/RD (read strobe output function) and P3\_3/WR (write strobe output function) signals.

The 1,043,968-byte area from 1200H to 0FFFFFH of data memory is the external data memory area. However, the ROM window function can be set by the ROM window setting register. If the ROM window function is used in the specified area (address 1200H and above), instead of accessing data in the data memory space, instructions (read operations) will access data in the program memory space at the same address.

The ROM window function is valid if the register (ROMWIN) that enables the ROM window function is set and the accessed (read) address is in external data memory.

## (7) Common area

There is a common area in the data memory space to enable the exchange of data between two or more data segments. The common area is located at the bottom of data memory, beginning at offset address 0H in each segment. The range of the common area is determined by the value of BCB in the PSW.

| ВСВ |   | BCB range of |
|-----|---|--------------|
| 1   | 0 | common area  |
| 0   | 0 | 0H to 03FFH  |
| 0   | 1 | 0H to 1FFFH  |
| 1   | 0 | 0H to 3FFFH  |
| 1   | 1 | 0H to 7FFFH  |

## 2.2.4 Data Memory Access

Examples of memory access are presented below for the cases when an instruction performs a byte operation and a word operation in the data memory space.

## (1) Byte operations

In the case of a byte operation, the address obtained from the instruction points to the targeted 8-bit data.

[Example] LB A, [DP]: where the contents of DP are 0335H



## (2) Word operations

In the case of a word operation, corresponding to the address obtained from the instruction, the address with least significant bit (LSB) set to "0" (even address) points to the lower order 8-bit data and the address with LSB set to "1" (odd address) points to the upper order 8-bit data to form the targeted 16-bit data.

Therefore, a targeted 16-bit data formed with upper oder 8-bit data for the odd address and lower oder 8-bit for the even address can not be accessed. (The boundary exists between two bytes in word operation.)

Yet such a boundary limit does not exist for the program memory space.

[Example] L A, [DP]: where the contents of DP are 0334H (or 0335H)



#### 2.3 Registers

Registers are classified by function as the arithmetic register, control registers, pointing registers, special function registers, local registers and segment registers.

Figure 2-7 shows the configuration of each register.



Figure 2-7 Register Configurations

#### 2.3.1 Arithmetic Register (ACC)

The arithmetic register is a 16-bit accumulator (ACC), central to all type of arithmetic operations.

If a transfer or arithmetic operation is:

- a word operation, all 16 bits (bits 15 to 0) are accessed,
- a byte operation, the lower 8 bits (bits 7 to 0) are accessed, or
- a nibble operation, the lower 4 bits (bits 3 to 0) are accessed.

If the targeted bit in a bit instruction is specified by ACC (such as SBR, RBR, etc.), the upper 5 bits (bits 7 to 3) within the lower 8 bits specify the address offset, and the lower 3 bits (bits 2 to 0) specify the bit position.

ACC is assigned to the SFR area. At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), the contents of ACC become 0000H.

## 2.3.2 Control Registers

Control registers are a group of four 16-bit registers with dedicated functions for program status, program sequence, local registers and stack control.

## (1) Program status word (PSW)

PSW is a 16-bit register consisting of the following.

- A flag (DD) that is referenced when executing instructions
- Flags (CY, ZF, HC, S, OV) that are set to "1" or reset to "0" depending upon instruction execution results
- Flags (SCB0 to SCB2) that specify the pointing register setting
- A flag (MIE) that enables ("1") or disables ("0") all maskable interrupts
- Flags (BCB0, BCB1) that specify the segment 0 common area
- Flags (F0 to F2) that the user can freely utilize
- A flag for use with future expanded CPU core functions. This flag (MAB) can be freely utilized by the user.

In addition to 16-bit PSW operations, 8-bit operations can also be performed with the PSW divided into the 8-bit units of PSWH (bits 15 to 8) and PSWL (bits 7 to 0).

Figure 2-8 shows the PSW configuration.



Figure 2-8 PSW Configuration

The upper 8 bits of the PSW (PSWH) contain:

- a flag (DD) that is referenced when executing instructions and
- flags (CY, ZF, HC, S, OV) that are set to "1" or reset to "0" depending upon instruction execution results.

Therefore, if the following instructions are performed on PSW or PSWH, flag operation may change from its original function.

- (i) Instructions that load the contents of PSW or PSWH into ACC (contents of ZF become undefined)
- (ii) Bit operation instructions on ZF
   (ZF changes depending on its value immediately before execution of the bit operation instruction.)
- (iii) Increment, decrement, arithmetic, logic and compare instructions on PSW or PSWH (The contents of PSW or PSWH immediately after instruction execution are undefined.)

If an interrupt occurs, PSW is automatically saved during interrupt processing and automatically restored by execution of a RTI instruction.

PSW is assigned to the SFR area. At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), the contents of PSW become 0000H.

Each bit in the PSW is described below.

Bit 15: Carry flag (CY)

The carry flag is set to "1" if:

- carry from bit 7 occurs in a byte operation,
- borrow to bit 7 occurs in a byte operation,
- carry from bit 15 occurs in a word operation, or
- borrow to bit 15 occurs in a word operation

as the result of executing an arithmetic or comparison instruction. Otherwise it is reset to "0". The carry flag can be set or reset directly by instructions and can be used to transmit or receive data for bits specified by registers. In addition, the carry flag can be tested by conditional branch instructions.

Bit 14: Zero flag (ZF)

The zero flag is set to "1" when:

- the result of an arithmetic instruction is zero,
- an instruction to load the ACC is executed and the load contents are zero, or
- a bit operation instruction is executed and the target bit is zero.

Otherwise, it is reset to "0". The zero flag can be tested by conditional branch instructions.

## Bit 13: Half carry flag (HC)

The half carry flag is set to "1" if a carry or borrow from bit 3 occurs as a result of executing an arithmetic or comparison instruction (either a byte and word instruction). Otherwise, it is reset to "0".

#### Bit 12: Data descriptor (DD)

This flag indicates the attributes of data stored in ACC.

- When DD is "1", the 16 bits of data in ACC are determined to be valid.
- When DD is "0", the lower 8 bits of data in ACC are determined to be valid.

Instructions that reference DD when performing arithmetic or data transfer instructions with ACC are executed as follows.

- When DD is "1", the arithmetic or transfer operation is performed in word units.
- When DD is "0", the arithmetic or transfer operation is performed in byte units.

DD is set to "1" or reset to "0" when a data transfer instruction to ACC is executed and when dedicated set and reset instructions are executed.

- DD is set to "1" when executing a word-type load instruction to ACC and when executing a SDD instruction.
- DD is reset to "0" when executing a byte-type load instruction to ACC and when executing a RDD instruction.

If DD is modified (set or reset) while executing a load instruction to ACC or a dedicated set or reset instruction, and if the next instruction references DD, the modified DD will be referenced.

Since DD is assigned to PSW, DD can be overwritten by instructions other than those mentioned above. In this case, if the next instruction references DD, it will reference the state of DD prior to modification. If DD is to be used in this manner, insert a NOP instruction after the instruction that directly modifies the state of DD.

## Bit 11: Sign flag (S)

The sign flag is set to "1" if the MSB of the result of executing an arithmetic or logic instruction is "1". If the MSB of the result is "0", the sign flag is reset to "0".

Bit 10: User flag 2 (F2)

Bit 6: User flag 1 (F1)

Bit 3: User flag 0 (F0)

These flags can be set to "1" or reset to "0" by instructions.

## Bit 9: Overflow flag (OV)

The overflow flag is set to "1" if the result of executing an arithmetic instruction exceeds a range expressed in 2's compliment format (–128 to +127 for byte operations and –32,768 to +32,767 for word operations). Otherwise the overflow flag is reset to "0".

## Bit 8: Master interrupt enable flag (MIE)

The master interrupt enable flag enables ("1") or disables ("0") all maskable interrupts.

During a maskable interrupt transfer cycle, after this flag is saved onto the system stack as part of PSW, it is reset to "0", and then restored by execution of a RTI instruction. If MIE is set to "1", the generation of all maskable interrupts is enabled from the next instruction. If reset to "0", the generation of all maskable interrupts is disabled from the next instruction.

## Bit 7: Product-sum function bank flag (MAB)

The MSM66577 family does not have the product-sum function, so this can be utilized as a user flag.

Bit 5: Bank common base 1 (BCB1)

Bit 4: Bank common base 0 (BCB0)

These flags specify the last address of the common area between segments in data memory space. The table below shows the relation between BCB value and selected common area.

| ВСВ |   | BCB range of |
|-----|---|--------------|
| 1   | 0 | common area  |
| 0   | 0 | 0H to 03FFH  |
| 0   | 1 | 0H to 1FFFH  |
| 1   | 0 | 0H to 3FFFH  |
| 1   | 1 | 0H to 7FFFH  |

Bit 2: System control base 2 (SCB2)

Bit 1: System control base 1 (SCB1)

Bit 0: System control base 0 (SCB0)

These flags specify the pointing register (PR) set assigned to the fixed page area.

| SCB |   |   | SCB pointing register set |
|-----|---|---|---------------------------|
| 2   | 1 | 0 | SOB politing register set |
| 0   | 0 | 0 | PR0(0200H to 0207H)       |
| 0   | 0 | 1 | PR1(0208H to 020FH)       |
| 0   | 1 | 0 | PR2(0210H to 0217H)       |
| 0   | 1 | 1 | PR3(0218H to 021FH)       |
| 1   | 0 | 0 | PR4(0220H to 0227H)       |
| 1   | 0 | 1 | PR5(0228H to 022FH)       |
| 1   | 1 | 0 | PR6(0230H to 0237H)       |
| 1   | 1 | 1 | PR7(0238H to 023FH)       |

## (2) Program counter (PC)

The PC is a 16-bit counter that stores the next address to be executed in the program segment. The PC is normally incremented according to the number of bytes in the instruction to be executed. If a branch instruction or an instruction that requires a branch is executed, the PC is loaded with immediate data, register contents, etc. The CSR value does not change even if the PC is incremented so that it overflows.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), or when an interrupt is generated, a value from the vector table is loaded into the PC.

#### (3) Local register base (LRB)

LRB is a 16-bit register. The lower 8 bits (LRBL) specify the 2KB data memory space from 0200H to 09FFH in 8-byte units (local register addressing). The upper 8 bits (LRBH) specify the 64KB data memory space in 256-byte units of the segment (segments 0 to 15) arbitrarily specified by the data segment register (DSR) (current page addressing). SB, RB, JBR and JBS instructions whose object is sba.bit can be used in the 64-byte area of the current page from xxC0H to xxFFH.

Both LRBL (02H) and LRBH (03H) are assigned to the SFR area. At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), their value is undefined.



Figure 2-9 LRB Configuration

 The 8 bits of LRBL specify the 2KB data memory space from 0200H to 09FFH in 8-byte units.



• The 8 bits of LRBH specify 64KB of data memory space in 256-byte units.



# (4) System stack pointer (SSP)

SSP is a 16-bit register that indicates the stack address at which to save or restore the PC, registers, etc. while processing interrupts or executing call, push, return, or pop instructions. SSP is automatically incremented or decremented depending upon the process to be executed.

Since save and restore operations at the address indicated by the SSP are performed in word units, the least significant bit (LSB) of the SSP is addressed as "0". The SFR area and the Expanded SFR area can not be used as a stack area.

SSP (00H) is assigned to the SFR area. At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), the contents of SSP become 0FFFFH.

# 2.3.3 Pointing Register (PR)

The PR has 8 sets of registers. One set consists of the following four 16-bit registers.

- Index register 1 (X1)
- Index register 2 (X2)
- Data pointer (DP)
- User stack pointer (USP)

PR is assigned to the internal RAM space from 0200H to 023FH. One of the eight register sets is selected by SCB0 to SCB2 of PSWL.

If the PR function is not used, this area can be used as normal internal RAM.

For all X1, X2, DP and USP, even addresses are the lower 8 bits and the following odd addresses are the upper 8 bits.



## 2.3.4 Local Registers (R0 to R7, ER0 to ER3)

The local register Rn (n = 0 to 7) is an 8-bit register and the expanded local register ERm (m = 0 to 3) is a 16-bit register. The 2KB area in data memory space from 0200H to 09FFH is specified in 8-byte units by the lower 8 bits of local register base (LRBL). Rn accesses 1 byte of the specified 8 bytes according to the 3 bits of data included in the local register instruction. (ERm accesses 2 bytes according to the 2 bits of data included in the local register instruction.)



#### 2.3.5 Segment Registers

There are three 8-bit segment registers: the code segment register (CSR), the table segment register (TSR) and the data segment register (DSR). These registers select segments in the program memory space.

However, since the program memory space has only segments 0 to 15, only bits 0 to 3 are valid. Bits 4 to 7 are fixed to "0".

## (1) Code segment register (CSR)



CSR specifies the segment in program memory space to which the program code currently being executed belongs. CSR exists as an independent 8-bit register and is not assigned to the SFR area. The CSR contents can be overwritten by FJ, FCAL, VCAL, FRT and RTI instructions and interrupts. No other methods can be used to overwrite the contents of CSR. For FJ and FCAL instructions, use branch destination addresses that are within segments 0 to 15.

Each segment is assigned an internal segment offset address of 0 to 0FFFFH. The address calculation to determine the addressed target is performed with a 16-bit offset address and any resulting overflow or underflow is ignored so that CSR does not change. Similarly, overflow of the PC never updates the CSR. Therefore, without the use of the CSR overwrite method described above, program execution does not advance beyond the code segment boundary. The CSR value at reset is 00H.

When an interrupt occurs after program memory space has been expanded to 1MB, both the current CSR value and the PC are automatically saved on the stack. Executing a RTI instruction restores the saved value to CSR. (Refer to Section 2.2.1, "Memory Space Expansion".)

## (2) Table segment register (TSR)



TSR specifies the segment in program memory to which the table data belongs. TSR is an 8-bit register and is assigned to the SFR area. The contents of TSR can be overwritten by instructions that use SFR addressing. Data in the table segment can be accessed by using ROM reference instructions (LC, LCB, CMPC and CMPCB). If the ROM window function is used, RAM addressing can be utilized for this table segment. Only bits 0 to 3 of TSR are valid. If read, a value of "0" will be obtained for bits 4 to 7. If writing to TSR, "0" must be written to bits 4 to 7.

Each segment is assigned an internal segment offset address of 0 to 0FFFFH. The address calculation to determine the addressed target is performed with a 16-bit offset address and any resulting overflow or underflow is ignored, so TSR does not change. The TSR value at reset is 00H.

## (3) Data segment register (DSR)



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

DSR specifies the segment in data memory space to which the data currently in use belongs. DSR is an 8-bit register and is assigned to the SFR area. The contents of DSR can be overwritten by instructions that use SFR addressing. Only bits 0 to 3 of DSR are valid. If read, a value of "0" will be obtained for bits 4 to 7. If writing to DSR, "0" must be written to bits 4 to 7.

## 2.4 Addressing Modes

The MSM66577 family has two independent memory spaces, the data memory space and the program memory space. Addressing can be roughly classified into two modes, corresponding to each memory space.

The data memory space is referred to as "RAM space", since it normally consists of random access memory (RAM). The addressing for this space is referred to as "RAM addressing".

The program memory space is referred to as "ROM space", since it normally consists of read-only memory (ROM). The addressing for this space is referred to as "ROM addressing".

ROM addressing is classified as immediate addressing contained in instruction codes, table data addressing for data (normally read-only data) in a ROM space table, and program code addressing for programs in the ROM space.

ROM window addressing is a unique method of addressing. It involves accessing table data in the ROM space using the above RAM addressing methods. Data in a table segment is read through a data segment window specified and opened by the program.

#### 2.4.1 RAM Addressing

This addressing mode specifies addresses for program variables in the RAM space.

Available addressing formats include: register addressing, page addressing, direct addressing, pointing register indirect addressing and special bit area addressing.

## (1) Register addressing

A. Accumulator addressing A

B. Control register addressingC. Pointing register addressingPSW, LRB, SSPX1, X2, DP, USP

D. Local register addressing ERn, Rn

## A. Accumulator addressing

In the case of a word-format instruction, the contents of the accumulator (A) will be accessed. In the case of byte and bit-format instructions, the lower byte of the accumulator (AL) will be accessed.

#### [Word format]

L <u>A,</u> #1234H ST <u>A,</u> VAR

## [Byte format]

LB <u>A,</u> #12H STB A, VAR

#### [Bit format]

MB C, <u>A</u>.3 JBS <u>A</u>.3, LABEL

#### B. Control register addressing

The contents of the registers will be accessed.

SSP: System Stack Pointer LRB: Local Register Base PSW: Program Status Word

PSWH: Program Status Word High Byte PSWL: Program Status Word Low Byte

C: Carry Flag

#### [Word format]

FILL SSP

MOV LRB, #401H

CLR PSW

## [Byte format]

CLRB <u>PSWH</u> INCB <u>PSWL</u>

## [Bit format]

MB <u>C</u>, BITVAR

## C. Pointing register addressing

The contents of the pointing register are accessed.

There are 8 sets of pointing registers (PR0 to PR7: every 8 bytes from 200H to 23FH in data memory). The set addressed by this mode is specified by the value of the system control base (SCB) field in PSW.

X1: Index Register 1X2: Index Register 2DP: Data Pointer

The low byte of the data pointer is used only for a "JRNZ DP radr" instruction

(to maintain compatibility among nX-8/100 to nX-8/400 CPU cores).

USP: User Stack Pointer

X1L: Index Register 1 Low Byte
 X2L: Index Register 2 Low Byte
 DPL: Data Pointer Low Byte
 USPL: User Stack Pointer Low Byte

#### [Word format]

 $\begin{array}{lll} L & & A, \underline{X1} \\ ST & & A, \underline{X2} \\ MOV & & \underline{DP}, \#2000H \\ CLR & & USP \end{array}$ 

# [Byte format]

 DJNZ
 X1L, LOOP

 DJNZ
 X2L, LOOP

 DJNZ
 DPL, LOOP

 DJNZ
 USPL, LOOP

 JRNZ
 DP, LOOP

## D. Local register addressing

The contents of the local register are accessed.

There are 256 sets of local registers (every 8 bytes from 200H to 9FFH in data memory). The set addressed by this mode is specified by the value of the low byte of the local register base (LRB).

ER0 to ER3: Expanded Local Registers

R0 to R7: Local Registers

## [Word format]

L A, <u>ER0</u>
MOV <u>ER2</u>, ER1
CLR ER3

#### [Byte format]

LB A, <u>R0</u>
ADDB <u>R1</u>, A
CMPB <u>R2</u>, #12H
INCB <u>R3</u>
ROR <u>R4</u>
MOVB <u>R5</u>, <u>R6</u>

#### [Bit format]

SB R0.0 RB R1.7 JBRS R7.3, LABEL

#### (2) Page addressing

A. SFR page addressing sfr DadrB. FIXED page addressing fix DadrC. Current page addressing off Dadr

## A. SFR page addressing

One byte of the instruction code specifies an offset within a SFR page (data memory addresses 0 to 0FFH). Word-format, byte-format or bit-format data at the specified address is accessed.

The operand is described using a format that has a sfr addressing descriptor. The sfr descriptor can be omitted, however in that case, the assembler will use SFR page addressing only when it recognizes an address within the SFR page area.

The SFR has address symbols for each type of device. These symbols are normally used for addressing the SFR.



If an odd address is specified, word-format data is accessed starting at the following even address. (→word boundary) However, depending upon the SFR, there are some exceptions.

# [Byte format]



# [Bit format]



#### B. FIXED page addressing

One byte of the instruction code specifies an offset within a FIXED page (data memory addresses 200H to 2FFH). Word-format, byte-format or bit-format data at the specified address is accessed.

The operand is described using a format that has a fix addressing descriptor. The fix descriptor can be omitted, however in that case, the assembler will use FIXED page addressing only when it recognizes an address within the FIXED page area.



If an odd address is specified, word-format data is accessed starting at the following even address.

#### [Byte format]



# [Bit format]



# C. Current page addressing

One byte of the instruction code specifies an offset within the current page (one of the 256 pages in data memory specified by the LRBH value). Word-format, byte-format or bit-format data at the specified address is accessed.

The operand is described using a format that has an off addressing descriptor. \can be used instead of the off descriptor, however if bit-format data is accessed in the SBA area, operation will be slightly different. (sbaoff Badr)



If an odd address is specified, word-format data is accessed starting at the following even address.

# [Byte format]



# [Bit format]



#### (3) Direct data addressing

Two bytes of the instruction code specify an address in the current physical segment of data memory (address 0 to 0FFFFH: 64KB). Word-format, byte-format or bit-format data at the specified address is accessed.

The operand is described using a format that has a dir addressing descriptor. The dir descriptor can be omitted, however in this case, if an address in a SFR page or FIXED page is specified, the assembler may interpret direct data addressing as SFR page addressing or FIXED page addressing.



If an odd address is specified, word-format data is accessed starting at the following even address.

# [Byte format]



# [Bit format]



# (4) Pointing register indirect addressing

| A. | DP/X1 indirect addressing                               | [DP], [X1]       |
|----|---------------------------------------------------------|------------------|
| B. | DP indirect addressing with post increment              | [DP+]            |
| C. | DP indirect addressing with post decrement              | [DP-]            |
| D. | DP/USP indirect addressing with 7-bit displacement      | n7[DP], n7[USP]  |
| E. | X1/X2 indirect addressing with 16-bit base              | D16[X1], D16[X2] |
| F. | X1 indirect addressing with 8-bit register displacement | [X1+R0], [X1+A]  |

# A. DP/X1 indirect addressing

The contents of the pointing register specify an address in the current physical segment of data memory (address 0 to 0FFFFH: 64KB). Word-format, byte-format or bit-format data at the specified address is accessed.

[DP]: DP indirect addressing [X1]: X1 indirect addressing

# [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.

# [Byte format]





# B. DP indirect addressing with post increment

The contents of the pointing register specify an address in the current physical segment of data memory (address 0 to 0FFFFH: 64KB). Word-format, byte-format or bit-format data at the specified address is accessed.

After accessing the target, the contents of the pointing register are incremented. For word-format instructions, DP is incremented by two. For byte and bit instructions, DP is incremented by one.

This addressing mode is used primarily to consecutively access an array of elements.

[DP+]: DP indirect addressing with post increment

#### [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.

#### [Byte format]





# C. DP indirect addressing with post decrement

The contents of the pointing register specify an address in the current physical segment of data memory (addresses 0 to 0FFFFH: 64KB). Word-format, byte-format or bit-format data at the specified address is accessed.

After accessing the target, the contents of the pointing register are decremented. For word-format instructions, DP is decremented by two. For byte and bit instructions, DP is decremented by one.

[DP-]: DP indirect addressing with post decrement

# [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.

# [Byte format]





# D. DP/USP indirect addressing with 7-bit displacement

7 bits in the instruction code (bit 6 to bit 0) are used as a signed displacement (bit 6 is the sign bit) from the pointing register contents (the base value) to specify an address in the current physical data segment (address 0 to 0FFFFH: 64KB). The accessible range is -64 to +63 from the contents of the pointing register. Word-format, byte-format or bit-format data at the specified address is accessed.

Numerical expression[DP]: DP indirect addressing with 7-bit displacement Numerical expression[USP]: USP indirect addressing with 7-bit displacement The numerical expression has a value in the range of –64 to +63. DP and USP can be used as pointing registers.

#### [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.

#### [Byte format]





# E. X1/X2 indirect addressing with 16-bit base

The contents of an index register (X1 or X2) are added to a base of two bytes in the instruction code (D16). The value that is generated specifies an address in the current physical data segment (address 0 to 0FFFFH: 64KB). The addition operation to generate the address is performed in word-format (16-bit) and since overflow is ignored, the generated value is in the range from 0 to 0FFFFH. Word-format, byte-format or bit-format data at the specified address is accessed.

Address expression[X1]: X1 indirect addressing with 16-bit base Address expression[X2]: X2 indirect addressing with 16-bit base

The address expression has a value in the range of 0 to 0FFFFH. However, the assembler allows values in the range of –8000H to +0FFFFH. This means that D16 can also be regarded as a displacement, instead of a base address.

# [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.

# [Byte format]





# F. X1 indirect addressing with 8-bit register displacement

The contents of the low byte of the accumulator (AL) or local register 0 (R0) are added to the pointing register contents (the base value) to generate a value that specifies an address in the current physical data segment (address 0 to 0FFFFH: 64KB). The addition operation to generate the address is performed in word-format (16-bit). At this time, the 8-bit displacement obtained from the register is expanded unsigned. Since overflow resulting from the addition is ignored, the generated value is in the range from 0 to 0FFFFH. Wordformat, byte-format or bit-format data at the specified address is accessed.

[X1+A]: X1 indirect addressing with 8-bit register displacement (AL) [X1+R0]: X1 indirect addressing with 8-bit register displacement (R0)

#### [Word format]



If an odd address is specified, word-format data is accessed starting at the following even address.



#### [Byte format]



# (5) Special bit area addressing

A. FIXED page SBA area addressing sbafix Badr
B. Current page SBA area addressing sbaoff Badr

# A. FIXED page SBA area addressing

This addressing mode specifies a bit address in the 512-bit SBA area (2C0H.0 to 2FFH.7) located in a FIXED page. Bit format data at the specified address is accessed.

This addressing mode can be written by the following 4 instructions: SB, RB, JBS and JBR.

# [Bit format]

 SB
 sbafix 2C0H.0

 RB
 sbafix 1600H

 JBS
 sbafix VAR,LABEL

 JBR
 sbafix 2EFH.7

SB

 2C0H.0

 RB
 1600H

 JBS
 VAR,LABEL

JBR 2EFH.3,LABEL

# B. Current page SBA area addressing

This addressing mode specifies a bit address in the 512-bit SBA area (xxC0H.0 to xxFFH.7) located in the current page. Bit format data at the specified address is accessed.

This addressing mode can be written by the following 4 instructions: SB, RB, JBS and JBR.



#### 2.4.2 ROM Addressing

This addressing mode specifies addressing for program variables in the ROM space.

Available addressing formats include: immediate addressing, table data addressing and program code addressing.

#### (1) Immediate addressing

This addressing mode specifies access for immediate data included in the instruction code. For word-format instructions, 2 bytes (N16) of the instruction code are accessed. For byte-format instructions, 1 byte (N8) of the instruction code is accessed.

In the word-format, expressions have values in the range of 0 to 0FFFH. In the byte-format, expressions have values in the range of 0 to 0FFH. The assembler allows a range of signed and unsigned expressions for immediate addressing. The word-format range is from -8000H to +0FFFH and the byte-format range is from -80H to +0FFH.

# [Word format]

L A, #1234H

MOV X1, #WORD\_ARRAY\_BASE

# [Byte format]

LB A, <u>#12H</u>

MOV X1, #BYTE\_ARRAY\_BASE

# (2) Table data addressing

This addressing mode specifies access for 64KB in the table segment specified by TSR in ROM memory space. This mode is used with the operands of LC, LCB, CMPC and CMPCB instructions.

A. Direct table addressing
B. RAM addressing indirect table addressing
C. RAM addressing indirect addressing with 16-bit base
T16[\*\*]

# A. Direct table addressing

Two bytes of the instruction code specify an address (address 0 to 0FFFFH: 64KB) in the table segment specified by TSR. Word-format or byte-format data at the specified address is accessed.

This addressing mode can be written by the following 4 instructions: LC, LCB, CMP and CMPCB.

# MSM66577 Family User's Manual Chapter 2 CPU Architecture

[Word format]

LC A, <u>VAR</u> CMPC A, <u>VAR</u>

[Byte format]

LCB A, <u>VAR</u> CMPCB A, <u>VAR</u>

#### B. RAM addressing indirect table addressing

This indirect addressing mode uses the word-format data specified by RAM addressing as a pointer to the table segment specified by TSR. Table memory can be accessed by placing a pointer to table memory in a register or in data memory.

This addressing mode can be written by the following 4 instructions: LC, LCB, CMPC and CMPCB.

[Word format]

LC A, [<u>A</u>]

CMPC A, [1234[X1]]

[Byte format]

LCB A, [<u>ER0</u>] CMPCB A, [<u>VAR</u>]

# C. RAM addressing indirect addressing with 16-bit base

The contents of word-format data specified by RAM addressing are added to a base of two bytes of the instruction code (D16). The value that is generated specifies an address in the table segment specified by TSR (address 0 to 0FFFFH: 64KB). The addition operation to generate the address is performed in word-format (16-bit) and since overflow is ignored, the generated value is in the range from 0 to 0FFFFH. Word-format or byte-format data at the specified address is accessed.

This addressing mode can be written by the following 4 instructions: LC, LCB, CMPC and CMPCB.

[Word format]

LC A, <u>2000H[A]</u>

CMPC A, 2000H[1234[X1]]

[Byte format]

LCB A, <u>2000H[ER0]</u>
CMPCB A, <u>2000H[VAR]</u>

# (3) Program code addressing

This mode specifies access for the current program code in ROM space.

Program code addressing is used with operands for branch instructions.

A. NEAR code addressing Cadr
B. FAR code addressing Fadr
C. Relative code addressing radr
D. ACAL code addressing Cadr11
E. VCAL code addressing Vadr
F. RAM addressing indirect code addressing [\*\*]

#### A. NEAR code addressing

Two bytes of the instruction code specify an address (address 0 to 0FFFFH: 64KB) in the current code segment.

This addressing mode can be written by two instructions, J and CAL.

# [Usage example]

J <u>3000H</u> CAL <u>LABEL</u>

#### B. FAR code addressing

Three bytes of the instruction code specify an address (0:0 to F:0FFFFH: 1MB) in the program memory space.

This addressing mode can be written by two instructions, FJ and FCAL.

#### [Usage example]

FJ <u>1:3000H</u> FCAL <u>FARLABEL</u>

#### C. Relative code addressing

The sign extended value of 8 bits or 7 bits of the instruction code is added to the base value of the current program counter (PC). The generated value specifies an address in the current code segment (0 to 0FFFFH: 64KB). The addition operation to generate the address is performed in word-format (16-bit) and since overflow is ignored, the generated value is in the range from 0 to 0FFFFH. This addressing mode can be written by an SJ instruction, conditional branch instructions, etc.

# [Usage example]

SJ <u>LABEL</u>
DJNZ R0, <u>LABEL</u>
JC LT, <u>LABEL</u>

#### D. ACAL code addressing

11 bits of the instruction code specify the ACAL area (1000H to 17FFH: 2KB) in the current code segment.

This addressing mode can be written only by an ACAL instruction.

# [Usage example]

ACAL 1000H

ACAL ACALLABEL

#### E. VCAL code addressing

4 bits of the instruction code specify the vector table address for a VCAL instruction (word-format data). The vector table is located at even addresses in the range of 004AH to 0069H.

This addressing mode can be written only by a VCAL instruction.

#### [Usage example]

VCAL <u>4AH</u> VCAL <u>0:4AH</u> VCAL VECTOR

#### F. RAM addressing indirect code addressing

This indirect addressing mode uses the word-format data specified by RAM addressing as a pointer to the code segment. Indirect jumps and calls can be performed by placing a pointer to code memory in a register or in data memory.

This addressing mode can be written by two instructions, J and CAL.

#### [Usage example]

J [A]

CAL [1234[X1]]

# (4) ROM window addressing

This addressing mode uses RAM addressing to access table data in the ROM space. In this mode, data in the table segment specified by TSR is read through a data segment window specified and opened by the program.

The ROM window area allows addressing of the data memory, however, <u>results cannot be</u> guaranteed if an instruction that writes to the ROM window area is executed.

# **CPU Control Functions**

# 3. CPU Control Functions

#### 3.1 Overview

The MSM66577 family has two CPU control functions, a standby function and a reset function.

The standby function consists of the three functions of HALT mode, HOLD mode, and STOP mode. These functions can be used to reduce the amount of power consumed during operation. The HOLD mode has a bus release function, and the STOP mode has a quick activating STOP mode in which the main clock continues oscillation.

The reset function is activated by the RES signal input, BRK (break) instruction execution, or execution of an invalid instruction (opcode trap). In addition, reset is also activated by overflow of the watchdog timer. Reset can minimize the effect of program errors on the system.

# 3.2 Standby Functions

The standby functions have three types:

- HALT mode: activated by software, clock supply to CPU is terminated
- HOLD mode: activated by hardware, clock supply to CPU is terminated
- STOP mode: activated by software, clock supply to CPU and internal peripheral modules is terminated

Corresponding to each of dual clocks, each of these functions has a high-speed and low-speed mode.

Figure 3-1 shows a transition diagram of the CPU operating states. Table 3-1 lists a summary of the standby modes.



Figure 3-1 Transition Diagram of CPU Operating States

**Table 3-1 Standby Mode Summary** 

| Standby mode                    |                         | HALT mode        | HOLD mode             | STOP r              | node *1             |
|---------------------------------|-------------------------|------------------|-----------------------|---------------------|---------------------|
|                                 |                         | Bit 1 (HLT) of   | Bit 5 (HOLD) of       | Bit 2 (FLT) of      | Bit 2 (FLT) of      |
|                                 |                         | SBYCON is set to | PRPHCON is set to     | SBYCON is set to    | SBYCON is reset to  |
|                                 | Set conditions          | "1"              | "1" and the HOLD      | "1" and bit 0 (STP) | "0" and bit 0 (STP) |
|                                 |                         |                  | input pin has a high- | of SBYCON is set to | of SBYCON is set to |
|                                 |                         |                  | level input           | "1"                 | "1"                 |
|                                 |                         | Interrupt        | HOLD pin low-level    | Interrupt           | Interrupt           |
|                                 | Release conditions      | RES pin input    | input                 | RES pin input       | RES pin input       |
|                                 |                         | WDT              | RES pin input         |                     |                     |
|                                 | P0 to P2, P4            | No change        | No change             | High impedance      | No change           |
|                                 | (primary function)      |                  |                       |                     |                     |
|                                 | P0 to P2, P4            | Pull-up          | Pull-up *2            | Pull-up             | Pull-up             |
|                                 | (secondary function)    |                  |                       |                     |                     |
|                                 | P3_0 (primary function) | No change        | No change             | High impedance      | No change           |
| es                              | P3_0                    | Low level        | Low level             | High impedance      | Low level           |
| stat                            | (secondary function)    |                  |                       |                     |                     |
| Output pin states               | P3_1 (primary function) | No change        | No change             | High impedance      | No change           |
| tbut                            | P3_1                    | High level       | Pull-up *2            | High impedance      | High level          |
| On                              | (secondary function)    |                  |                       |                     |                     |
|                                 | P3_2, P3_3              | No change        | No change             | High impedance      | No change           |
|                                 | (primary function)      |                  |                       |                     |                     |
|                                 | P3_2, P3_3              | Pull-up          | Pull-up *2            | High impedance      | Pull-up             |
|                                 | (secondary function)    |                  |                       |                     |                     |
|                                 | P5 to P11               | No change        | No change             | High impedance      | No change           |
|                                 | P14, P15                | No change        | No change             | High impedance      | No change           |
| ons                             | Time base counter (TBC) | Operate          | Operate               | Terminate           |                     |
| ncti                            | Capture/compare timer   | Operate          | Operate               | Terminate           |                     |
| al fu                           | 8/16-bit timers         | Operate          | Operate               | Terminate           |                     |
| tern                            | (including WDT)         |                  | (terminate WDT)       |                     |                     |
| Operation of internal functions | SIO1, SIO6              | Operate          | Operate               | Terminate           |                     |
| ion                             | Real-time counter       | Operate          | Operate               | Operate             |                     |
| erati                           | A/D converter           | Operate          | Operate               | Terminate           |                     |
| do                              | PWM                     | Operate          | Operate               | Terminate           |                     |

<sup>\*1</sup> The condition for setting the STOP mode is that the stop code acceptor (STPACP) has already been set to "1".

<sup>\*2</sup> During the HOLD mode, if P0 to P4 are to be used as bus ports (output setting of secondary function), the bus will be released.

# 3.2.1 Standby Function Registers

Table 3-2 lists a summary of the SFRs for standby function control.

Table 3-2 Summary of SFRs for Standby Function Control

| Address | Name                        | Symbol  | Symbol | R/W | 8/16      | Initial   | Reference |
|---------|-----------------------------|---------|--------|-----|-----------|-----------|-----------|
| [H]     |                             | (byte)  | (word) |     | Operation | value [H] | page      |
| 000E    | Stop code acceptor          | STPACP  | _      | W   | 8         | "0"       | 3-3       |
| 000F    | Standby control register    | SBYCON  | _      | R/W | 8         | 08        | 3-4       |
| 0015☆   | Peripheral control register | PRPHCON | _      | R/W | 8         | 8C        | 15-2      |

# [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (☆) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

# 3.2.2 Description of Standby Function Registers

# (1) Stop code acceptor (STPACP)

The stop code acceptor (STPACP) is configured from 8 bits and is an acceptor used to set the STOP mode.

STPACP is set to "1" when the program writes n5H and nAH (n = 0 to F) consecutively. After STPACP is set to "1", setting bit 0 (STP) of the standby control register (SBYCON) to "1" will change the mode to the STOP mode. At the same time the mode changes to the STOP mode, STPACP is reset to "0".

STPACP is write-only.

At reset (due to a  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), STPACP is reset to "0".

# (2) Standby control register (SBYCON)

The standby control register (SBYCON) is an 8-bit register that sets the standby mode and the CPU operating clock (CPUCLK).

The program can read from and write to SBYCON.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), SBYCON is 08H.

Figure 3-2 shows the configuration of SBYCON.

#### [Description of each bit]

• STP (bit 0)

Setting the stop code acceptor (STPACP) to "1", and then setting STP to "1" will change the mode to the STOP mode. When an interrupt is generated or the RES input causes a reset, STP is reset to "0" and the STOP mode is released.

#### • HLT (bit 1)

Setting HLT to "1" changes the mode to the HALT mode. When an interrupt is generated, the  $\overline{RES}$  input causes a reset, or overflow of the watchdog timer causes a reset, HLT is reset to "0" and the HALT mode is released.

#### • FLT (bit 2)

Setting FLT to "1" will cause the output ports (all pins set to output mode) to go to a high impedance state when the STOP mode is entered.

At the input ports, a circuit operates to prevent current flow between the power supply and GND, even if the inputs are left unconnected. Therefore, it is not necessary to fix the input pin levels during the STOP mode. However, if the following pins are used as inputs (regardless of whether they are primary or secondary functions), the circuit to prevent current flow will not operate. Thus, to prevent undefined input states, use either pull-up or pull-down resistors (to fix the input levels) during the STOP mode.

P6 0 to P6 3, P9 0 to P9 3: External interrupt pins (EXINT0 to EXINT7)

Using the above pins as secondary function inputs, even if the STOP mode is entered with FLT set ("1"), the STOP mode can be released by an external interrupt input. For details, refer to Section 3.2.4, "Operation of Each Standby Mode," (3) STOP Mode.

#### • OSCS (bit 3)

During the STOP mode and when the subclock (XTCLK) has been selected as the CPU operating clock (CPUCLK), OSCS specifies whether to terminate or continue oscillation of the main clock (OSCCLK).

#### • OST0, OST1 (bits 4 and 5)

In the cases when an interrupt causes the STOP mode to be released, and when the clock has been changed from the subclock (XTCLK) to the main clock (OSCCLK), OST0 and OST1 specify the oscillation stabilization time from the oscillation start of the main clock (OSCCLK) until clock supply to the CPU. During the STOP mode, even if oscillation of the main clock (OSCCLK) is not terminated, the settings of these bits are valid.

#### [Note]

Do not set OST0 or OST1 to "1", in the case of changing to the operation mode in which oscillation of the main clock (OSCCLK) is terminated.

For the Flash ROM version, set the oscillation stabilization time of 50  $\mu$ s or more when the STOP mode (only when oscillation of the main clock is terminated) is released.

CLK0, CLK1 (bits 6 and 7)
 CLK0 and CLK1 specify the clock to be used as the CPU operating clock (CPUCLK). With consideration of the operating speed requirements of product applications, an appropriate speed for the internal CPU clock that runs the microcontroller is selected to reduce power consumption.



Figure 3-2 SBYCON Configuration

#### 3.2.3 Examples of Standby Function Register Settings

#### HALT mode setting

(1) Standby control register (SBYCON)
Setting bit 1 (HLT) to "1" changes the mode to the HALT mode.

#### HOLD mode setting

(1) Port 9 mode register (P9IO)

If HLDACK (HOLD mode transfer output pin) is to be used, set bit 7 (P9IO7) to "1" to configure that port as an output.

(2) Port 9 secondary function control register (P9SF)

If HLDACK (HOLD mode transfer output pin) is to be used, set bit 7 (P9SF7) to "1" to configure that port as a secondary function output.

(3) Peripheral control register (PRPHCON)

Set bit 5 (HOLD) to "1" to enable the HOLD pin input. The mode changes to the HOLD mode when an external device inputs a high level to the HOLD pin. After the transfer to the HOLD mode is complete, the HLDACK output is set to "1" as an acknowledge signal.

#### STOP mode setting

(1) Stop code acceptor (STPACP)
Write n5H, nAH (n = 0 to F) consecutively.

(2) Standby control register (SBYCON)

If output ports are to be high impedance during the STOP mode, set bit 2 (FLT) to "1". If oscillation of the main clock (OSCCLK) is not to be terminated during the STOP mode, reset bit 3 (OSCS) to "0". To terminate oscillation of the main clock (OSCCLK), set bit 3 (OSCS) to "1" and specify with bits 4 and 5 (OST0 and OST1) the oscillation stabilization time after the main clock resumes. Setting bit 0 (STP) to "1" changes the mode to the STOP mode.

# 3.2.4 Operation of Each Standby Mode

#### (1) HALT mode

Setting bit 1 (HLT) of the standby control register (SBYCON) to "1" changes the mode to the HALT mode.

In the HALT mode, the clock (CPUCLK) supply to the CPU is terminated, but the clock (CPUCLK) is supplied to internal peripheral modules (TBC, WDT, general-purpose 8/16-bit timers, serial ports, etc.) so their operation continues. Because the CPU is halted, instructions are not executed. Instruction execution stops at the beginning of the next instruction (following the instruction that set bit 1 (HLT) of SBYCON to "1").

HALT mode is released when any of the following occur: an interrupt request, reset by the RES pin input, or reset by overflow of the watchdog timer.

When HALT mode is released due to an interrupt request, if the interrupt is non-maskable, the HALT mode is released unconditionally, and the CPU processes the non-maskable interrupt. In the case of a maskable interrupt, the interrupt is released when both the interrupt request flag (IRQ bit) and the interrupt enable flag (IE bit) have been set to "1". After the HALT mode is released, if the master interrupt enable flag (MIE in PSW) has been set to "1", processing of the requested maskable interrupt is performed. If the master interrupt enable flag (MIE in PSW) has been reset to "0", the next instruction (following the instruction that set the HALT mode (that set bit 1 (HLT) of SBYCON to "1") is executed.

If the HALT mode is released by reset due to the  $\overline{RES}$  pin input or overflow of the watchdog timer, the CPU will perform the reset processing.

#### (2) HOLD mode

When a high level is input to the HOLD pin after bit 5 (HOLD) of the peripheral control register (PRPHCON) is set to "1", the mode will change to the HOLD mode after the completion of the current instruction execution. Figure 3-3 shows the HOLD mode timing diagram.

In the HOLD mode, the clock (CPUCLK) supply to the CPU is terminated, but the clock (CPUCLK) is supplied to internal peripheral modules (TBC, general-purpose 8/16-bit timers, serial ports, etc.) so their operation continues. However, operation of the watchdog timer (WDT) is terminated. Because the CPU is halted, instructions are not executed. Instruction execution stops at the beginning of the next instruction (following the instruction that changed the mode to the HOLD mode).

If bus port functions (P0 to P4 set as secondary function outputs) are being used, the bus will be released during the HOLD mode.

If an interrupt occurs during the HOLD mode, because instructions are not being executed, interrupt processing will be suspended until the HOLD mode is released.

The HOLD mode is released when either a low level is input to the HOLD pin or the RES pin input causes a reset.

If a low level is input to the HOLD pin, instruction execution will resume starting from the next instruction (following the instruction that changed the mode to the HOLD mode). When an interrupt request occurs during the HOLD mode, if the interrupt is non-maskable, the non-maskable interrupt will be processed immediately after the HOLD mode is released. In the case of a maskable interrupt, if the corresponding interrupt enable flag (IE bit) and the master interrupt enable flag (MIE in PSW) have been set to "1", the maskable interrupt will be processed immediately after the HOLD mode is released. If multiple interrupt requests are generated, they are processed in order of priority.

If the HOLD mode is released by reset due to the  $\overline{\text{RES}}$  pin input, the CPU will perform the reset processing.



Figure 3-3 HOLD Mode Timing Diagram

#### (3) STOP mode

Setting the stop code acceptor (STPACP) to "1" by consecutively writing n5H, nAH (where n=0 to F) and then setting bit 0 (STP) of the standby control register (SBYCON) to "1" will change the mode to the STOP mode.

In the STOP mode, the CPU and internal peripheral modules (TBC, WDT, general-purpose 8/16-bit timers, serial ports, etc.) are halted. However, when dual clocks are being used, the real-time counter (RTC) will operate as usual.

Because the clock supply to the CPU is halted, instructions are not executed. Instruction execution stops at the beginning of the next instruction (following the instruction that set bit 0 (STP) of SBYCON to "1").

The STOP mode is released when either an interrupt occurs or input to the  $\overline{\text{RES}}$  pin causes a reset.

When the STOP mode is released due to an interrupt request, if the interrupt is non-maskable, the STOP mode is released unconditionally, and the CPU processes the non-maskable interrupt.

In the case of a maskable interrupt, the interrupt is released if the interrupt request flag (IRQ bit) and the interrupt enable flag (IE bit) have been set to "1".

During the STOP mode, the following factors generate maskable interrupt requests.

- Interrupt caused by input of the valid edge to an external interrupt pin (EXINT0 to EXINT5)
- Interrupt caused by real-time counter output (when dual clocks are used)

After the STOP mode is released, if the master interrupt enable flag (MIE in PSW) has been set to "1", processing of the requested maskable interrupt is performed.

If the master interrupt enable flag (MIE in PSW) has been reset to "0", the next instruction (following the instruction that set the STOP mode (that set bit 0 (STP) of SBYCON to "1") is executed. However, if the STOP mode has been set during the processing of a non-maskable interrupt routine, the STOP mode can be released by an interrupt request. After being released, the next instruction in the non-maskable interrupt routine (following the instruction that changed the mode to the STOP mode) will be executed. If interrupt priority is set (bit 7 (MIPF) of EXI2CON set to "1") and the STOP mode is set during a high priority interrupt routine, a low priority interrupt request can release the STOP mode. However, after release the low priority interrupt is suspended and the next instruction in the high priority interrupt routine will be executed.

If an interrupt request from the high-speed STOP mode (main clock oscillation terminated) causes the STOP mode to be released, operation will continue after waiting for the oscillation stabilization time of the main clock (OSCCLK) as set by SBYCON. The STOP mode can also be entered while the main clock continues to oscillate (quick activating STOP mode). In this case, when returning from the STOP mode, activation is possible without waiting for the oscillation stabilization time of the main clock.

Figure 3-4 shows the STOP mode timing diagram.

If the STOP mode is released by reset due to the  $\overline{\text{RES}}$  pin input, the CPU will perform the reset processing. If the  $\overline{\text{RES}}$  pin input is to be used to release the STOP mode with main clock oscillation halted, apply a low level to the  $\overline{\text{RES}}$  pin until the main clock oscillation stabilizes.

For the Flash ROM version products, apply a low level to the RES pin for at least 50 μs.



\* Oscillation stabilization time is the time until the main clock starts oscillating, plus the time of the number of clocks set by OST0 and OST1.

Figure 3-4 STOP Mode Timing Diagram (When released by an interrupt)

#### 3.3 Reset Function

The MSM66577 family is reset by the following four factors.

- Low-level input to the RES input pin
- Execution of a break (BRK) instruction
- Overflow of the watchdog timer (WDT)

Reset caused by opcode trap

Opcode trap (OPTRP) due to execution of invalid instruction

Resets caused to the above four factors are processed in the same way except that the address of the vector address to be loaded in the program counter is different.

Table 3-3 lists the vector addresses for each reset factor.

Reset factor

Reset caused by low level input to the RES input pin

Reset caused by execution of BRK instruction

Reset caused by overflow of watchdog timer

O004

**Table 3-3 Vector Address for Each Reset Factor** 

During the reset processing, arithmetic registers, control registers, mode registers, etc. are initialized, and the contents of the address pointed to by the vector address is loaded into the program counter.

0006

For the initial values of different registers, refer to Chapter 21, "Special Function Registers (SFRs)".

Reset has priority over all other processing (interrupt processing and instruction execution). Since all processing is aborted, register and RAM contents at that time cannot be guaranteed.

#### [Notes]

- 1. If the RES pin input is to be used to for reset, apply a low level at the RES pin until the main clock oscillation stabilizes.
- 2. Because the internal state and output state at power-on reset are undefined, be sure to reset the CPU after power is turned on.
- 3. When applying power to, or disconnecting power from, the V<sub>DD</sub> and V<sub>REF</sub> pins, apply or disconnect the power at the same time for these pins.

The Flash ROM version is reset by the supply voltage sense reset function when the power supply voltage is dropped, in the same way that the MSM66577 family is reset by low level input to the  $\overline{\text{RES}}$  input pin. The supply voltage sense reset function is implemented when the supply voltage for the version operating in the range of 4.5 to 5.5 V is 3.0 V or less and the supply voltage for the version operating in the range of 3.0 to 3.6 V is 1.5 V or less. The reset function is not implemented during the STOP mode (only when oscillation clock is terminated).

Figure 3-5 shows an example of reset pin connection. Table 3-4 lists that status of I/O ports during reset.



Figure 3-5 Reset Pin Connection Example

Table 3-4 I/O Port Status During Reset

| Name   | Low level EA pin<br>P3_0, P3_1 | High level EA pin<br>P3_0, P3_1 | Other ports    |  |
|--------|--------------------------------|---------------------------------|----------------|--|
| Status | Pulled-up                      | High impedance                  | High impedance |  |

# [Note]

If the  $\overline{EA}$  pin is at a low level, after reset P0, P1, P2, P3\_0, P3\_1 and P4 automatically change to secondary function output states (bus port function).

# **Memory Control Functions**

# 4. Memory Control Functions

#### 4.1 Overview

There are two independent memory spaces, the program memory space and the data memory space. The following three functions make the memory functions easier to use.

• ROM Window Function: This function enables various instructions that have been

stored in the data memory space to also be used by the

program in the program memory space.

READY Function:
 If both memory spaces are to be used as external memory,

this function allows the program to insert wait cycles into the external memory timing, according to the access times of the

external memory.

WAIT Function: This function enables an external device to control the

insertion of wait cycles.

# 4.2 Memory Control Function Registers

Table 4-1 lists a summary of the SFRs for memory control functions.

Table 4-1 Summary of SFRs for Memory Control Functions

| Address | Name                        | Symbol  | Symbol | R/W  | 8/16      | Initial   | Reference |
|---------|-----------------------------|---------|--------|------|-----------|-----------|-----------|
| [H]     | name                        | (byte)  | (word) | H/VV | Operation | value [H] | page      |
| 000B    | ROM Window Register         | ROMWIN  | _      | R/W  | 8         | Undefined | 4-2       |
| 000C☆   | ROM Ready Control Register  | ROMRDY  | _      | R/W  | 8         | 8B        | 4-4       |
| 000D☆   | RAM Ready Control Register  | RAMRDY  | _      | R/W  | 8         | FF        | 4-5       |
| 0015☆   | Peripheral Control Register | PRPHCON | _      | R/W  | 8         | 8C        | 15-2      |

# [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (☆) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

#### 4.3 ROM Window Function

The ROM window function reads the contents of the program memory space specified by the ROM window register (ROMWIN), located in the SFR area, by using the same address in the data memory space as a window.

In other words, when the ROM window function is enabled and an instruction that accesses (reads) the data memory space is executed, instead of accessing (reading) data in the data memory space, data will be accessed (read) at the same addresses in the segment that is specified by TSR in the program memory space.

Compared to the number of instruction cycles to be required to access normal data memory, accessing the ROM window once requires additional 3 cycles for a byte instruction and additional 6 cycles for a word instruction.

#### [Note]

If the ROM window function is enabled and a write instruction is executed, that result will not be guaranteed. However, in this case additional cycles will not be added.

# • ROM Window Register (ROMWIN)

The ROM window register (ROMWIN) is an 8-bit register. The lower 4 bits indicate the start address of the ROM window and the upper 4 bits indicate the end address of the ROM window. (Bits 4 and 5 of the upper 4 bits must be written as "1"s.) When 64KB of the program memory space is represented in hexadecimal number (HEX), each of above 4-bit registers specifies the upper 1 digit of 4 digits. If the value of the lower 4 bits is all zeros, the ROM window function will not operate.

Figure 4-1 shows the configuration of ROMWIN.



Figure 4-1 ROMWIN Configuration

If internal RAM is located in the data memory area specified as the ROM window, the data memory's internal RAM will have priority.

The data memory space specified as the ROM window area cannot be used as normal external data memory.

The ROM window start address is 1200H or above for segment 0, and 1000H or above for segments 1 to 15. The end address can be selected among the four end addresses listed in Table 4-2.

Table 4-2 End Address List

| ROMWIN |       | End address [H] |  |
|--------|-------|-----------------|--|
| Bit 7  | Bit 6 | End address [H] |  |
| 0      | 0     | 3FFF            |  |
| 0      | 1     | 7FFF            |  |
| 1      | 0     | BFFF            |  |
| 1      | 1     | FFFF            |  |

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ROMWIN is undefined and the ROM window function does not operate.

ROMWIN can be written to once after reset. Additional writing attempts will be ignored. Therefore, after the ROM window function has been set it can only be modified after a reset. ROMWIN can be read as many times as desired.

#### [Note]

The relative sizes of the start address "X" and the end address "Y" written to ROMWIN are not evaluated by the hardware. Therefore, be sure that  $X \le Y$  within the program.

#### 4.4 READY Function

So that memory and general-purpose ICs with slow access speeds can be connected externally, wait cycles can be specified to be inserted during external memory accesses. There are two registers that specify the number of wait cycles, the ROM ready control register (ROMRDY) and the RAM ready control register (RAMRDY).

ROMRDY specifies wait cycles when the external ROM mode is used for the program memory space. By setting the IRORDY flag to "1", the same wait cycles specified for the external ROM are also applied to the internal ROM.

RAMRDY specifies wait cycles when the data memory space is extended externally. Memory can be divided into the two areas of address 0000H to 7FFFH and 8000H to FFFFH, and wait cycles can be specified for each area.

Table 4-3 lists the number of wait cycles that can be specified for RAMRDY and ROMRDY.

Table 4-3 Wait Cycles

| Control register | Number of wait cycles to be inserted |
|------------------|--------------------------------------|
| ROMRDY           | 0 to 3                               |
| RAMRDY           | 0 to 7                               |

# 4.4.1 ROM Ready Control Register (ROMRDY)

The ROM ready control register (ROMRDY) consists of two bits. ROMRDY specifies the number of wait cycles with bits 0 and 1 (ORDY0 and ORDY1) and insertion or no insertion of READY to the internal ROM with bit 2 (IRORDY).

ROMRDY can be read from and written to by the program. However, write operations are invalid for bits 3 and 7. Also, if writing to bits 4 to 6, they must be written as "0". When read, bits 3 and 7 are always "1" and bits 4 to 6 are "0".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ROMRDY becomes 8BH and the largest number of wait cycles are set. Therefore, three wait cycles will be added and inserted when external program memory is accessed.

Figure 4-2 shows the configuration of ROMRDY.



"—" indicates a nonexistent bit. When read, its value will be "1".

"0" indicates that the value "0" must always be written to this bit. When read, its value will be "0".

1 cycle is 1 CPUCLK.

Figure 4-2 ROMRDY Configuration

### 4.4.2 RAM Ready Control Register (RAMRDY)

The RAM ready control register (RAMRDY) consists of 6 bits. Bits 0 to 2 (ARDY00 to ARDY02) of RAMRDY specify the number of wait cycles for the external RAM area from 0000H to 7FFFH. Bits 4 to 6 (ARDY10 to ARDY12) specify the number of wait cycles for the external RAM area from 8000H to FFFFH. The number of wait cycles is uniform for all segments and settings are divided into the two areas of 0000H to 7FFFH (segment 0 is 1200H to 7FFFH) and 8000H to FFFFH.

RAMRDY can be read from and written to by the program. However, write operations are invalid for bits 3 and 7. When read, bits 3 and 7 are always "1".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), RAMRDY becomes FFH and the largest number of wait cycles are set. Therefore, seven wait cycles will be added and inserted when external data memory is accessed.

Figure 4-3 shows the configuration of RAMRDY.

#### [Note]

In contrast to an internal data memory access, when external data memory is accessed, 2 or 3 cycles are automatically inserted for each 1 byte access. RAMRDY specifies the number of cycles to be inserted in addition to the 2 or 3 cycles that are inserted automatically inserted.



1 cycle is 1 CPUCLK.

Figure 4-3 RAMRDY Configuration

#### 4.5 WAIT Function

When accessing the external data memory area, in addition to the READY function that inserts wait cycles from the CPU, there is a WAIT function that can insert wait cycles via control from the external device. (This is applicable only to the data memory space.)

At the falling edge of CPUCLK shown in Figure 4-4 and 4-5, the high level of pin P11\_0/WAIT is sampled and wait cycles are inserted into WR and RD strobe signals.

As shown in the sample timing of Figure 4-4, the WAIT function is released 1 tφw after pin P11 0/WAIT is sample twice consecutively at a low level.

If the WAIT function is used with the READY function, the wait time that is largest will be valid.

In order to use the WAIT function, set bit 6 (WAIT) of the peripheral control register (PRPHCON) to "1". (Refer to Chapter 15, "Peripheral Functions".)



Figure 4-4 Sample Timing When Using the WAIT Function (Separate Bus Type)



Figure 4-5 Sample Timing When Using the WAIT Function (Multiplexed Bus Type)

## Chapter 5

# **Port Functions**

5

## 5. Port Functions

#### 5.1 Overview

The MSM66577 family has 14 sets of I/O port from P0 to P11, P14 and P15 (74 ports) and 1 set of input-only port at P12 (8 ports).

Each individual bit of all the I/O ports can be specified as input or output. All I/O ports have internal pull-up resistors that can be programmed for each individual bit.

The 3 sets of P0, P3 and P11 (16 ports) are capable of providing the sink current of 10 mA for driving LEDs.

If configured as inputs, the pins are high impedance inputs. If configured as outputs, they are push-pull outputs. In addition to the port function, some ports are assigned an internal function (secondary function).

Table 5-1 shows Port Function Summary.

**Table 5-1 Port Function Summary** 

| Port name | Pin            | Туре | Number | I/O | Secondary function                                       |
|-----------|----------------|------|--------|-----|----------------------------------------------------------|
| Port 0*   | P0_0 to P0_7   | Α    | 8      | I/O | External memory access address data bus AD0 to AD7 (I/O) |
| Port 1    | P1_0 to P1_7   | В    | 8      | I/O | External memory access A8 to A15 (output)                |
| Port 2    | P2_0 to P2_3   | В    | 4      | I/O | External memory access A16 to A19 (output)               |
| Port 3*   | P3_0           | В    | 1      | I/O | External memory access ALE (output)                      |
|           | P3_1           | В    | 1      | I/O | External program memory access PSEN (output)             |
|           | P3_2           | С    | 1      | I/O | External data memory access RD (output)                  |
|           | P3_3           | С    | 1      | I/O | External data memory access WR (output)                  |
| Port 4    | P4_0 to P4_7   | В    | 8      | I/O | External memory access A0 to A7 (output)                 |
| Port 5    | P5_4, P5_5     | D    | 2      | I/O | Capture/compare CPCM0, CPCM1 (I/O)                       |
|           | P5_6           | D    | 1      | I/O | Timer 0 timer output TM0OUT (output)                     |
|           | P5_7           | D    | 1      | I/O | Timer 0 external event input TM0EVT (input)              |
| Port 6    | P6_0 to P6_3   | D    | 4      | I/O | External interrupt EXINT0 to EXINT3 (input)              |
|           | P6_4           | D    | 1      | I/O | Timer 1 external event input TM1EVT (input)              |
|           | P6_5           | D    | 1      | I/O | Timer 1 timer output TM1OUT (output)                     |
|           | P6_6           | D    | 1      | I/O | Timer 2 external event input TM2EVT (input)              |
|           | P6_7           | D    | 1      | I/O | Timer 2 timer output TM2OUT (output)                     |
| Port 7    | P7_6, P7_7     | D    | 2      | I/O | PWM output PWM0OUT, PWM1OUT (output)                     |
| Port 8    | P8_0           | D    | 1      | I/O | SIO1 receive data input RXD1 (input)                     |
|           | P8_1           | D    | 1      | I/O | SIO1 transmit data output TXD1 (output)                  |
|           | P8_2           | D    | 1      | I/O | SIO1 receive clock RXC1 (I/O)                            |
|           | P8_3           | D    | 1      | I/O | SIO1 transmit clock TXC1 (I/O)                           |
|           | P8_4           | D    | 1      | I/O | Timer 4 timer output TM4OUT (output)                     |
|           | P8_6, P8_7     | D    | 2      | I/O | PWM output PWM2OUT, PWM3OUT (output)                     |
| Port 9    | P9_0 to P9_3   | D    | 4      | I/O | External interrupt EXINT4 to EXINT7 (input)              |
|           | P9_7           | D    | 1      | I/O | HOLD mode transfer output HLDACK (output)                |
| Port 10   | P10_3          | D    | 1      | I/O | SIO4 transmit-receive clock SIOCK4 (I/O)                 |
|           | P10_4          | D    | 1      | I/O | SIO4 receive data output SIOO4 (output)                  |
|           | P10_5          | D    | 1      | I/O | SIO4 transmit data input SIOI4 (input)                   |
| Port 11*  | P11_0          | D    | 1      | I/O | External data memory access WAIT (input)                 |
|           | P11_1          | D    | 1      | I/O | HOLD mode request input HOLD (input)                     |
|           | P11_2          | D    | 1      | I/O | Main clock pulse output CLKOUT (output)                  |
|           | P11_3          | D    | 1      | I/O | Subclock pulse output XTOUT (output)                     |
| Port 12   | P12_0 to P12_7 | F    | 8      | I   | A/D converter analog input AI0 to AI7 (input)            |
| Port 14   | P14_0          | D    | 1      | I/O | SIO5 transmit-receive clock SIOCK5 (I/O)                 |
|           | P14_1          | D    | 1      | I/O | SIO5 transmit data output SIOO5 (output)                 |
|           | P14_2          | D    | 1      | I/O | SIO5 receive data input SIOI5 (input)                    |
|           | P14_6, P14_7   | Е    | 2      | I/O | D/A converter analog output AO0, AO1 (output)            |
| Port 15   | P15_0          | D    | 1      | I/O | SIO6 transmit-receive data input RXD6 (input)            |
|           | P15_1          | D    | 1      | I/O | SIO6 transmit data output TXD6 (output)                  |
|           | P15_2          | D    | 1      | I/O | SIO6 receive clock RXC6 (I/O)                            |
|           | P15_3          | D    | 1      | I/O | SIO6 transmit clock TXC6 (I/O)                           |

<sup>\*</sup>Ports marked with an asterisk are capable of providing the sink current of 10 mA.

## 5.2 Hardware Configuration of Each Port

Ports (P0 to P12, P14, and P15) are divided into six categories, corresponding to each function.

#### 5.2.1 Type A (P0)

The type A port has a secondary function and functions as an I/O pin. Depending on the state of the port mode registers (P0IOn) and the port secondary function control registers (P0SFn), the port configuration is switched between input, pulled-up input, output, and secondary function I/O (external memory data I/O in a separate bus type, and external memory data I/O and address output in a multiplexed bus type).

Because type A ports access external program memory as a secondary function, the port status is determined by the status of the  $\overline{EA}$  pin (that specifies external memory access).

When reset (due to RES input, BRK instruction execution, watchdog timer overflow or an opcode trap), the pin status will be as follows:

| EA pin status | Port initial status         |
|---------------|-----------------------------|
| Н             | High impedance input port   |
| L             | Secondary function I/O port |

Figure 5-1 shows the type A configuration.



Figure 5-1 Type A Configuration

## 5.2.2 Type B (P1, P2, P3\_0, P3\_1, P4)

The type B port has a secondary function and functions as an I/O pin. Depending on the state of the port mode registers (PmIOn) and the port secondary function control registers (PmSFn), the port configuration is switched between input, pulled-up input, output, and secondary function output (external memory access).

Because type B ports access external program memory as a secondary function, the port status is determined by the status of the  $\overline{EA}$  pin (that specifies external memory access).

When reset (due to RES input, BRK instruction execution, watchdog timer overflow or an opcode trap), the pin status will be as follows:

| EA pin status | Port initial status         |
|---------------|-----------------------------|
| Н             | High impedance input port   |
| L             | Secondary function I/O port |

Figure 5-2 shows the type B configuration.



Figure 5-2 Type B Configuration

## 5.2.3 Type C (P3\_2, P3\_3)

The type C port has a secondary function. Depending on the state of the port mode registers (P3IOn) and the port secondary function control registers (P3SFn), the port configuration is switched between input, pulled-up input, output, and secondary function output (external memory access).

When reset (due to  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow or an opcode trap), the initial value of P3IOn and P3SFn is "0" and the port will be configured as a high impedance input port.

Figure 5-3 shows the type C configuration.



Figure 5-3 Type C Configuration

#### 5.2.4 Type D (P5, P6, P7, P8, P9, P10, P11, P14\_0 to P14\_2, P15)

The type D port has a secondary function. Depending on the state of the port mode registers (PmIOn) and the port secondary function control registers (PmSFn), the port configuration is switched between input (primary/secondary function), pulled-up input (primary/secondary function), output, and secondary function output.

When reset (due to  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow or an opcode trap), the initial value of PmIOn and PmSFn is "0" and the port will be configured as a high impedance input port.

Figure 5-4 shows the type D configuration.



Figure 5-4 Type D Configuration

#### 5.2.5 Type E (P14\_6, P14\_7)

The type E port has a secondary function. Depending on the state of the port mode registers (PmIOn) and the port secondary function control registers (PmSFn), the port configuration is switched between input (primary/secondary function), pulled-up input (primary/secondary function), output, and secondary function output.

When reset (due to RES input, BRK instruction execution, watchdog timer overflow or an opcode trap), the initial value of PI4IOn and PI4SFn is "0" and the port will be configured as a high impedance input port.

Figure 5-5 shows the type E configuration.



Figure 5-5 Type E Configuration

#### 5.2.6 Type F (P12)

The type F port has a secondary function input, but is an input-only port that is not assigned a port mode register (PnIO) and a port secondary function control register (PnSF). P12 also functions as the analog input of the A/D converter.

Figure 5-6 shows the type F configuration.



Figure 5-6 Type F Configuration

## 5.3 Port Registers

There are three types of port control registers:

- Port data registers (Pn: n = 0 to 12, 14, 15)
- Port mode registers (PnIO: n = 0 to 11, 14, 15)
- Port secondary function control registers (PnSF: n = 0 to 11, 14, 15)

These registers are allocated as SFRs.

Table 5-2 lists a summary of the port control SFRs.

Table 5-2 Port Control SFR Summary (1/2)

| Address | Name                  | Symbol | Symbol | R/W   | 8/16      | Initial   | Reference |
|---------|-----------------------|--------|--------|-------|-----------|-----------|-----------|
| [H]     | Name                  | (byte) | (word) | □/ VV | operation | value [H] | page      |
| 0018    | Port 0 data register  | P0     | _      | R/W   | 8         | 00        | 5-12      |
| 0019    | Port 1 data register  | P1     |        | R/W   | 8         | 00        | 5-14      |
| 001A☆   | Port 2 data register  | P2     | _      | R/W   | 8         | 00        | 5-16      |
| 001B☆   | Port 3 data register  | P3     | _      | R/W   | 8         | 00        | 5-18      |
| 001C    | Port 4 data register  | P4     | _      | R/W   | 8         | 00        | 5-20      |
| 001D☆   | Port 5 data register  | P5     | _      | R/W   | 8         | 00        | 5-22      |
| 001E    | Port 6 data register  | P6     | _      | R/W   | 8         | 00        | 5-24      |
| 001F☆   | Port 7 data register  | P7     | _      | R/W   | 8         | 00        | 5-26      |
| 00B8☆   | Port 8 data register  | P8     | _      | R/W   | 8         | 00        | 5-28      |
| 00B9☆   | Port 9 data register  | P9     | _      | R/W   | 8         | 00        | 5-30      |
| 00BA☆   | Port 10 data register | P10    | _      | R/W   | 8         | 00        | 5-32      |
| 00BB☆   | Port 11 data register | P11    | _      | R/W   | 8         | 00        | 5-34      |
| 00BC    | Port 12 data register | P12    | _      | R     | 8         | Undefined | 5-36      |
| 00BE☆   | Port 14 data register | P14    | _      | R/W   | 8         | 00        | 5-37      |
| 00BF☆   | Port 15 data register | P15    | _      | R/W   | 8         | 00        | 5-39      |
| 0020    | Port 0 mode register  | POIO   |        | R/W   | 8         | 00/FF     | 5-12      |
| 0021    | Port 1 mode register  | P1IO   | _      | R/W   | 8         | 00/FF     | 5-14      |
| 0022☆   | Port 2 mode register  | P2IO   | _      | R/W   | 8         | 00/0F     | 5-16      |
| 0023☆   | Port 3 mode register  | P3IO   | _      | R/W   | 8         | 00/02     | 5-18      |
| 0024    | Port 4 mode register  | P4IO   | _      | R/W   | 8         | 00/FF     | 5-20      |
| 0025☆   | Port 5 mode register  | P5IO   |        | R/W   | 8         | 00        | 5-22      |
| 0026    | Port 6 mode register  | P6IO   | _      | R/W   | 8         | 00        | 5-24      |
| 0027☆   | Port 7 mode register  | P7IO   | _      | R/W   | 8         | 00        | 5-26      |
| 00C0☆   | Port 8 mode register  | P8IO   | _      | R/W   | 8         | 00        | 5-28      |
| 00C1☆   | Port 9 mode register  | P9IO   |        | R/W   | 8         | 00        | 5-30      |
| 00C2☆   | Port 10 mode register | P10IO  | _      | R/W   | 8         | 00        | 5-32      |
| 00C3☆   | Port 11 mode register | P11IO  | _      | R/W   | 8         | 00        | 5-34      |
| 00C4☆   | Port 14 mode register | P14IO  | _      | R/W   | 8         | 00        | 5-37      |
| 00C5☆   | Port 15 mode register | P15IO  | _      | R/W   | 8         | 00        | 5-39      |

Table 5-2 Port Control SFR Summary (2/2)

| Address | Name                                        | Symbol | Symbol | R/W | 8/16      | Initial   | Reference |
|---------|---------------------------------------------|--------|--------|-----|-----------|-----------|-----------|
| [H]     | D 10 1 1 1                                  | (byte) | (word) |     | operation | value [H] | page      |
| 0028    | Port 0 secondary function control register  | P0SF   | _      | R/W | 8         | 00/FF     | 5-12      |
| 0029    | Port 1 secondary function control register  | P1SF   | _      | R/W | 8         | 00/FF     | 5-14      |
| 002A☆   | Port 2 secondary function control register  | P2SF   | _      | R/W | 8         | 00/0F     | 5-16      |
| 002B☆   | Port 3 secondary function control register  | P3SF   | _      | R/W | 8         | 00/03     | 5-18      |
| 002C    | Port 4 secondary function control register  | P4SF   | _      | R/W | 8         | 00/FF     | 5-20      |
| 002D☆   | Port 5 secondary function control register  | P5SF   | _      | R/W | 8         | 00        | 5-22      |
| 002E    | Port 6 secondary function control register  | P6SF   | _      | R/W | 8         | 00        | 5-24      |
| 002F☆   | Port 7 secondary function control register  | P7SF   | _      | R/W | 8         | 00        | 5-26      |
| 00C6☆   | Port 14 secondary function control register | P14SF  | _      | R/W | 8         | 00        | 5-37      |
| 00C7☆   | Port 15 secondary function control register | P15SF  | _      | R/W | 8         | 00        | 5-39      |
| 00C8☆   | Port 8 secondary function control register  | P8SF   | _      | R/W | 8         | 00        | 5-28      |
| 00C9☆   | Port 9 secondary function control register  | P9SF   | _      | R/W | 8         | 00        | 5-30      |
| 00CA☆   | Port 10 secondary function control register | P10SF  | _      | R/W | 8         | 00        | 5-32      |
| 00CB☆   | Port 11 secondary function control register | P11SF  | _      | R/W | 8         | 00        | 5-34      |

## [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (☆) in the address column indicates a missing bit.
- 3. Initial values may change depending upon the status of the  $\overline{EA}$  pin (mode registers and secondary control registers for port 0 to port 4). Listings are in the order of  $\overline{EA}$  = high-level/low-level.
- 4. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

#### 5.3.1 Port Data Registers (Pn : n = 0 to 12, 14, 15)

Port data registers (Pn: n = 0 to 12, 14, 15) store the port output data.

Pn registers are allocated as SFRs and when reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), their value becomes 00H.

If an instruction to read Pn is executed, for ports specified as inputs, the pin status ("0" or "1") will be read. For ports specified as outputs, the Pn status ("0" or "1") will be read. If an instruction to write to Pn is executed, regardless whether the port is input or output, data will be written to Pn. Because P12 is an input-only port, only read instructions can be executed. If a read instruction is executed, the pin status ("0" or "1") will be read.

#### [Note]

If a bit specified as input by the port mode register (PnIO) is read, the pin status will be read. When writing data to a port data register (Pn), if read-modify-write instructions such as arithmetic, logical and bit manipulation instructions are used, the port data register (Pn) of the bit specified as an input will be overwritten.

#### 5.3.2 Port Mode Registers (PnIO: n = 0 to 11, 14, 15)

Port mode registers (PnIO : n = 0 to 11, 14, 15) specify whether I/O ports are inputs or outputs.

PnIO registers are allocated as SFRs and when reset (due to a RES input, BRK instruction execution, watchdog timer overflow, opcode trap), their value becomes 00H and all ports will be set to the input mode. However, if the EA pin is at a low level, ports used to access external memory will automatically be set to the output mode.

Setting each individual bit of PnIO to "0" configures the input mode and "1" configures the output mode.

## 5.3.3 Port Secondary Function Control Registers (PnSF: n = 0 to 11, 14, 15)

Port secondary function control registers (PnSF: n = 0 to 11, 14, 15) specify the secondary function output for ports.

PnSF registers are allocated as SFRs and when reset (due to  $\overline{\text{RES}}$  input, BRK instruction execution, watchdogtimer overflow, or opcode trap) their values become 00H and the primary function will be selected for all ports. However, if the  $\overline{\text{EA}}$  pin is at a low level, ports used to access external memory will automatically be configured as secondary function outputs.

When the port is in input mode, if PnSF is set to "1", the input will be pulled-up. When the port is in output mode, if PnSF is set to "1", the secondary function output will be selected. The secondary function input does not depend upon PnSF, and can be read in the same manner as the primary function input with PnIO = 0.

Table 5-3 lists the port status due to the settings of the port mode register and the port secondary function control register.

PnIO PnSF Function

0 0 Input (primary/secondary function)

0 1 Pulled-up input (primary/secondary function)

1 0 Output (primary function)

1 Output (secondary function)

**Table 5-3 Port Settings** 

If a port that is not assigned a secondary function is set to secondary function output (PnIO = 1, PnSF = 1), "0" will be output to that port.

Table 5-4 lists the values read when reading the port data register (Pn : n = 0 to 11, 14, 15) according to the settings of port mode register (PnIO) and port secondary control register (PnSF).

Table 5-4 Port Data Register Read Data

| PnIO | PnSF | Read data                        |
|------|------|----------------------------------|
| 0    | *    | Pin status                       |
| 1    | 0    | Pn (value of port data register) |
| 1    | 1    | Output secondary function data   |

\*: "0" or "1," n: 0 to 11, 14, 15

#### 5.4 Port 0 (P0)

Port 0 is an 8-bit I/O port. Each individual bit can be specified as input or output by the port 0 mode register (P0IO). When output is specified (corresponding bits of P0IO = "1"), the value of the corresponding bits in the port 0 data register (P0) will be output from their appropriate pins.

In addition to its port function, P0 is assigned a secondary function (external memory data I/O when selecting a separate bus type, and external memory data I/O and address output when selecting a multiplexed bus type). If the secondary function is to be used, set the corresponding bits of the port 0 mode register (P0IO) and the port 0 secondary function control register (P0SF) to "1".

If the port is specified as an input (corresponding bits of P0IO = "0") and the port 0 secondary function control register (P0SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-7 shows the configuration of the port 0 data register (P0), port 0 mode register (P0IO) and the port 0 secondary function control register (P0SF).



"\*" indicates data I/O in a separate bus type. In a multiplexed bus type, it will be data I/O and address output.

Figure 5-7 P0, P0IO, P0SF Configuration

Table 5-5 lists the data that is read, depending on the settings of P0IO and P0SF, when executing an instruction to read P0.

At reset (due to  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), if the  $\overline{EA}$  pin is at a high level, P0 will become a high impedance input port (P0IO = 00H, P0SF = 00H) and the contents of P0 will be 00H. If the  $\overline{EA}$  pin is at a low level, P0 will be set as a secondary function I/O port (P0IO = FFH, P0SF = FFH) and the contents of P0 will be 00H.

Table 5-5 P0 Read Data

|      | P0IO | P0SF | Read data                                 |
|------|------|------|-------------------------------------------|
| DO 0 | 0    | *    | P0_0 pin state                            |
| P0_0 | 1    | *    | Value of bit 0 of P0 (port data register) |
| DO 1 | 0    | *    | P0_1 pin state                            |
| P0_1 | 1    | *    | Value of bit 1 of P0 (port data register) |
| D0 0 | 0    | *    | P0_2 pin state                            |
| P0_2 | 1    | *    | Value of bit 2 of P0 (port data register) |
| D0 0 | 0    | *    | P0_3 pin state                            |
| P0_3 | 1    | *    | Value of bit 3 of P0 (port data register) |
| DO 4 | 0    | *    | P0_4 pin state                            |
| P0_4 | 1    | *    | Value of bit 4 of P0 (port data register) |
| D0 5 | 0    | *    | P0_5 pin state                            |
| P0_5 | 1    | *    | Value of bit 5 of P0 (port data register) |
| D0 0 | 0    | *    | P0_6 pin state                            |
| P0_6 | 1    | *    | Value of bit 6 of P0 (port data register) |
| D0 7 | 0    | *    | P0_7 pin state                            |
| P0_7 | 1    | *    | Value of bit 7 of P0 (port data register) |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P0, depending on the settings of P0IO and P0SF, values will be read as listed in Table 5-5. The modified values will be written to P0 (port 0 data register).

#### 5.5 Port 1 (P1)

Port 1 is an 8-bit I/O port. Each individual bit can be specified as input or output by the port 1 mode register (P1IO). When output is specified (corresponding bits of P1IO = "1"), the value of the corresponding bits in the port 1 data register (P1) will be output from their appropriate pins.

In addition to its port function, P1 is assigned a secondary function (external memory address output). If the secondary function is to be used, set the corresponding bits of the port 1 mode register (P1IO) and the port 1 secondary function control register (P1SF) to "1".

If the port is specified as an input (corresponding bits of P1IO = "0") and the port 1 secondary function control register (P1SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-8 shows the configuration of the port 1 data register (P1), port 1 mode register (P1IO) and the port 1 secondary function control register (P1SF).



Figure 5-8 P1, P1IO, P1SF Configuration

Table 5-6 lists the data that is read, depending on the settings of P1IO and P1SF, when executing an instruction to read P1.

At reset (due to  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), if the  $\overline{EA}$  pin is at a high level, P1 will become a high impedance input port (P1IO = 00H, P1SF = 00H) and the contents of P1 will be 00H. If the  $\overline{EA}$  pin is at a low level, P1 will be set as a secondary function output port (P1IO = FFH, P1SF = FFH) and the contents of P1 will be 00H.

Table 5-6 P1 Read Data

|      | P1IO | P1SF | Read data                                 |
|------|------|------|-------------------------------------------|
| D1 0 | 0    | *    | P1_0 pin state                            |
| P1_0 | 1    | *    | Value of bit 0 of P1 (port data register) |
| D1 1 | 0    | *    | P1_1 pin state                            |
| P1_1 | 1    | *    | Value of bit 1 of P1 (port data register) |
| D1 0 | 0    | *    | P1_2 pin state                            |
| P1_2 | 1    | *    | Value of bit 2 of P1 (port data register) |
| D1 0 | 0    | *    | P1_3 pin state                            |
| P1_3 | 1    | *    | Value of bit 3 of P1 (port data register) |
| D1 4 | 0    | *    | P1_4 pin state                            |
| P1_4 | 1    | *    | Value of bit 4 of P1 (port data register) |
| D4 C | 0    | *    | P1_5 pin state                            |
| P1_5 | 1    | *    | Value of bit 5 of P1 (port data register) |
| D1 C | 0    | *    | P1_6 pin state                            |
| P1_6 | 1    | *    | Value of bit 6 of P1 (port data register) |
| D1 7 | 0    | *    | P1_7 pin state                            |
| P1_7 | 1    | *    | Value of bit 7 of P1 (port data register) |

"\*" indicates "0" or "1"

## [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P1, depending on the settings of P1IO and P1SF, values will be read as listed in Table 5-6. The modified values will be written to P1 (port 1 data register).

#### 5.6 Port 2 (P2)

Port 2 is a 4-bit I/O port. Each individual bit can be specified as input or output by the port 2 mode register (P2IO). When output is specified (corresponding bits of P2IO = "1"), the value of the corresponding bits in the port 2 data register (P2) will be output from their appropriate pins.

In addition to its port function, P2 is assigned a secondary function (external memory address output). If the secondary function is to be used, set the corresponding bits of the port 2 mode register (P2IO) and the port 2 secondary function control register (P2SF) to "1".

If the port is specified as an input (corresponding bits of P2IO = "0") and the port 2 secondary function control register (P2SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-9 shows the configuration of the port 2 data register (P2), port 2 mode register (P2IO) and the port 2 secondary function control register (P2SF).



"—" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-9 P2, P2IO, P2SF Configuration

Table 5-7 lists the data that is read, depending on the settings of P2IO and P2SF, when executing an instruction to read P2.

At reset (due to a  $\overline{\text{RES}}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), if the  $\overline{\text{EA}}$  pin is at a high level, P2 will become a high impedance input port (P2IO = 00H, P2SF = 00H) and the contents of P2 will be 00H. If the  $\overline{\text{EA}}$  pin is at a low level, P2 will be set as a secondary function output port (P2IO = 0FH, P2SF = 0FH) and the contents of P2 will be 00H.

Table 5-7 P2 Read Data

|      | P2IO | P2SF | Read data                                 |  |  |  |
|------|------|------|-------------------------------------------|--|--|--|
| D2 0 | 0    | *    | P2_0 pin state                            |  |  |  |
| P2_0 | 1    | *    | /alue of bit 0 of P2 (port data register) |  |  |  |
| DO 1 | 0    | *    | P2_1 pin state                            |  |  |  |
| P2_1 | 1    | *    | Value of bit 1 of P2 (port data register) |  |  |  |
| DO O | 0    | *    | P2_2 pin state                            |  |  |  |
| P2_2 | 1    | *    | Value of bit 2 of P2 (port data register) |  |  |  |
| DO 0 | 0    | *    | P2_3 pin state                            |  |  |  |
| P2_3 | 1    | *    | Value of bit 3 of P2 (port data register) |  |  |  |

"\*" indicates "0" or "1"

## [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P2, depending on the settings of P2IO and P2SF, values will be read as listed in Table 5-7. The modified values will be written to P2 (port 2 data register).

#### 5.7 Port 3 (P3)

Port 3 is a 4-bit I/O port. Each individual bit can be specified as input or output by the port 3 mode register (P3IO). When output is specified (corresponding bits of P3IO = "1"), the value of the corresponding bits in the port 3 data register (P3) will be output from their appropriate pins.

In addition to its port function, P3 is assigned secondary functions (ALE,  $\overline{PSEN}$ ,  $\overline{RD}$ , and  $\overline{WR}$  outputs). If a secondary function is to be used, set the corresponding bits of the port 3 mode register (P3IO) and the port 3 secondary function control register (P3SF) to "1". If the port is specified as an input (corresponding bits of P3IO = "0") and the port 3 secondary function control register (P3SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-10 shows the configuration of the port 3 data register (P3), port 3 mode register (P3IO) and the port 3 secondary function control register (P3SF).



"-" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-10 P3, P3IO, P3SF Configuration

Table 5-8 lists the data that is read, depending on the settings of P3IO and P3SF, when executing an instruction to read P3.

At reset (due to a  $\overline{RES}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), if the  $\overline{EA}$  pin is at a high level, P3 will become a high impedance input port (P3IO = 00H, P3SF = 00H) and the contents of P3 will be 00H. If the  $\overline{EA}$  pin is at a low level, only P3\_0 and P3\_1 will be set as a secondary function I/O port (P3IO = 03H, P3SF = 03H) and the contents of P3 will be 00H.

Table 5-8 Read Data

|      | P3IO   | P3SF | Read data                                 |
|------|--------|------|-------------------------------------------|
| D2 0 | 0      | *    | P3_0 pin state                            |
| P3_0 | P3_0 1 | *    | Value of bit 0 of P3 (port data register) |
| D2 1 | 0      | *    | P3_1 pin state                            |
| P3_1 | 1      | *    | Value of bit 1 of P3 (port data register) |
| DO O | 0      | *    | P3_2 pin state                            |
| P3_2 | 1      | *    | Value of bit 2 of P3 (port data register) |
| D2 2 | 0      | *    | P3_3 pin state                            |
| P3_3 | 1      | *    | Value of bit 3 of P3 (port data register) |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P3, depending on the settings of P3IO and P3SF, values will be read as listed in Table 5-8. The modified values will be written to P3 (port 3 data register).

#### 5.8 Port 4 (P4)

Port 4 is an 8-bit I/O port. Each individual bit can be specified as input or output by the port 4 mode register (P4IO). When output is specified (corresponding bits of P4IO = "1"), the value of the corresponding bits in the port 4 data register (P4) will be output from their appropriate pins.

In addition to its port function, P4 is assigned a secondary function (external memory address output when selecting a separate bus type). If the secondary function is to be used, set the corresponding bits of the port 4 mode register (P4IO) and the port 4 secondary function control register (P4SF) to "1".

If the port is specified as an input (corresponding bits of P4IO = "0") and the port 4 secondary function control register (P4SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-11 shows the configuration of the port 4 data register (P4), port 4 mode register (P4IO) and the port 4 secondary function control register (P4SF).



Figure 5-11 P4, P4IO, P4SF Configuration

Table 5-9 lists the data that is read, depending on the settings of P4IO and P4SF, when executing an instruction to read P4.

At reset (due to a  $\overline{\text{RES}}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), if the  $\overline{\text{EA}}$  pin is at a high level, P4 will become a high impedance input port (P4IO = 00H, P4SF = 00H) and the contents of P4 will be 00H. If the  $\overline{\text{EA}}$  pin is at a low level, P4 will be set as a secondary function output port (P4IO = FFH, P4SF = FFH) and the contents of P4 will be 00H.

Table 5-9 P4 Read Data

|      | P4IO | P4SF | Read data                                 |
|------|------|------|-------------------------------------------|
| D4 0 | 0    | *    | P4_0 pin state                            |
| P4_0 | 1    | *    | Value of bit 0 of P4 (port data register) |
| D4 1 | 0    | *    | P4_1 pin state                            |
| P4_1 | 1    | *    | Value of bit 1 of P4 (port data register) |
| D4 0 | 0    | *    | P4_2 pin state                            |
| P4_2 | 1    | *    | Value of bit 2 of P4 (port data register) |
| D4 2 | 0    | *    | P4_3 pin state                            |
| P4_3 | 1    | *    | Value of bit 3 of P4 (port data register) |
| D4 4 | 0    | *    | P4_4 pin state                            |
| P4_4 | 1    | *    | Value of bit 4 of P4 (port data register) |
| D4 5 | 0    | *    | P4_5 pin state                            |
| P4_5 | 1    | *    | Value of bit 5 of P4 (port data register) |
| D4 6 | 0    | *    | P4_6 pin state                            |
| P4_6 | 1    | *    | Value of bit 6 of P4 (port data register) |
| D4 7 | 0    | *    | P4_7 pin state                            |
| P4_7 | 1    | *    | Value of bit 7 of P4 (port data register) |

"\*" indicates "0" or "1"

## [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P4, depending on the settings of P4IO and P4SF, values will be read as listed in Table 5-9. The modified values will be written to P4 (port 4 data register).

#### 5.9 Port 5 (P5)

Port 5 is a 4-bit I/O port. Each individual bit can be specified as input or output by the port 5 mode register (P5IO). When output is specified (corresponding bits of P5IO = "1"), the value of the corresponding bits in the port 5 data register (P5) will be output from their appropriate pins.

In addition to its port function, P5 is assigned secondary functions (such as capture/compare I/O). If a secondary function output is to be used, set the corresponding bits of the port 5 mode register (P5IO) and the port 5 secondary function control register (P5SF) to "1". If a secondary function input is to be used, reset the corresponding bits of the port 5 mode register (P5IO) to "0" to configure the input mode (same input as the primary function input).

If the port is specified as an input (corresponding bits of P5IO = "0") and the port 5 secondary function control register (P5SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bit 7 of port 5 is set to secondary function output (P5IO7 = 1, P5SF7 = 1), the output will be fixed at "0", regardless of the value of the port 5 data register.

Figure 5-12 shows the configuration of the port 5 data register (P5), port 5 mode register (P5IO) and the port 5 secondary function control register (P5SF).



Figure 5-12 P5, P5IO, P5SF Configuration

indicates a bit that does not exist. If read, the value will be "0.

Table 5-10 lists the data that is read, depending on the settings of P5IO and P5SF, when executing an instruction to read P5.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P5 will become a high impedance input port (P5IO = 00H, P5SF = 00H) and the contents of P5 will be 00H.

Table 5-10 P5 Read Data

|      | P5IO | P5SF | Read data                                 |
|------|------|------|-------------------------------------------|
| P5_4 | 0    | *    | P5_4/CPCM0 pin state                      |
|      | 1    | 0    | Value of bit 4 of P5 (port data register) |
|      | 1    | 1    | CPCM0 output data                         |
| P5_5 | 0    | *    | P5_5/CPCM1 pin state                      |
|      | 1    | 0    | Value of bit 5 of P5 (port data register) |
|      | 1    | 1    | CPCM1 output data                         |
| P5_6 | 0    | *    | P5_6 pin state                            |
|      | 1    | 0    | Value of bit 6 of P5 (port data register) |
|      | 1    | 1    | TM0OUT output data                        |
| P5_7 | 0    | *    | P5_7/TM0EVT pin state                     |
|      | 1    | 0    | Value of bit 7 of P5 (port data register) |
|      | 1    | 1    | "0"                                       |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P5, depending on the settings of P5IO and P5SF, values will be read as listed in Table 5-10. The modified values will be written to P5 (port 5 data register).

#### 5.10 Port 6 (P6)

Port 6 is an 8-bit I/O port. Each individual bit can be specified as input or output by the port 6 mode register (P6IO). When output is specified (corresponding bits of P6IO = "1"), the value of the corresponding bits in the port 6 data register (P6) will be output from their appropriate pins.

In addition to its port function, P6 is assigned a secondary function (such as external interrupt input). If the secondary function output is to be used, set the corresponding bits of the port 6 mode register (P6IO) and the port 6 secondary function control register (P6SF) to "1". If the secondary function input is to be used, reset the corresponding bits of the port 6 mode register (P6IO) to "0" to configure the input mode (same input as the primary function input).

If the port is set as an input (corresponding bits of P6IO = "0") and the port 6 secondary function control register (P6SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bits 0 to 4 and bit 6 of port 6 are set as a secondary function output (P6IOn = 1, P6SFn = 1), the output will be fixed at "0", regardless of the value of the port 6 data register.

Figure 5-13 shows the configuration of the port 6 data register (P6), port 6 mode register (P6IO) and the port 6 secondary function control register (P6SF).



0 output\*: "0" is output, regardless of the value of the port data register

Figure 5-13 P6, P6IO, P6SF Configuration

Table 5-11 lists the data that is read, depending on the settings of P6IO and P6SF, when executing an instruction to read P6.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P6 will become a high impedance input port (P6IO = 00H, P6SF = 00H) and the contents of P6 will be 00H.

Table 5-11 P6 Read Data

|      | P6IO | P6SF | Read data                                 |
|------|------|------|-------------------------------------------|
| P6_0 | 0    | *    | P6_0/EXINT0 pin state                     |
|      | 1    | 0    | Value of bit 0 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
| P6_1 | 0    | *    | P6_1/EXINT1 pin state                     |
|      | 1    | 0    | Value of bit 1 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
|      | 0    | *    | P6_2/EXINT2 pin state                     |
| P6_2 | 1    | 0    | Value of bit 2 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
|      | 0    | *    | P6_3/EXINT3 pin state                     |
| P6_3 | 1    | 0    | Value of bit 3 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
|      | 0    | *    | P6_4/TM1EVT pin state                     |
| P6_4 | 1    | 0    | Value of bit 4 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
| P6_5 | 0    | *    | P6_5 pin state                            |
|      | 1    | 0    | Value of bit 5 of P6 (port data register) |
|      | 1    | 1    | TM1OUT output data                        |
| P6_6 | 0    | *    | P6_6 pin state                            |
|      | 1    | 0    | Value of bit 6 of P6 (port data register) |
|      | 1    | 1    | "0"                                       |
| P6_7 | 0    | *    | P6_7 pin state                            |
|      | 1    | 0    | Value of bit 7 of P6 (port data register) |
|      | 1    | 1    | TM2OUT output data                        |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P6, depending on the settings of P6IO and P6SF, values will be read as listed in Table 5-11. The modified values will be written to P6 (port 6 data register).

#### 5.11 Port 7 (P7)

Port 7 is a 7-bit I/O port. Each individual bit can be specified as input or output by the port 7 mode register (P7IO). When output is specified (corresponding bits of P7IO = "1"), the value of the corresponding bits in the port 7 data register (P7) will be output from their appropriate pins.

In addition to its port function, P7 is assigned secondary functions (such as PWM0 output). If a secondary function output is to be used, set the corresponding bits of the port 7 mode register (P7IO) and the port 7 secondary function control register (P7SF) to "1".

If the port is set as an input (corresponding bits of P7IO = "0") and the port 7 secondary function control register (P7SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

Figure 5-14 shows the configuration of the port 7 data register (P7), port 7 mode register (P7IO) and the port 7 secondary function control register (P7SF).



"-" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-14 P7, P7IO, P7SF Configuration

Table 5-12 lists the data that is read, depending on the settings of P7IO and P7SF, when executing an instruction to read P7.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P7 will become a high impedance input port (P7IO = 00H, P7SF = 00H) and the contents of P7 will be 00H.

Table 5-12 P7 Read Data

|      | P7IIO | P7ISF | Read data                                 |
|------|-------|-------|-------------------------------------------|
| P7_6 | 0     | *     | P7_6 pin state                            |
|      | 1     | 0     | Value of bit 6 of P7 (port data register) |
|      | 1     | 1     | PWM0OUT output data                       |
| P7_7 | 0     | *     | P7_7 pin state                            |
|      | 1     | 0     | Value of bit 7 of P7 (port data register) |
|      | 1     | 1     | PWM1OUT output data                       |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P7, depending on the settings of P7IO and P7SF, values will be read as listed in Table 5-12. The modified values will be written to P7 (port 7 data register).

#### 5.12 Port 8 (P8)

Port 8 is a 7-bit I/O port. Each individual bit can be specified as input or output by the port 8 mode register (P8IO). When output is specified (corresponding bits of P8IO = "1"), the value of the corresponding bits in the port 8 data register (P8) will be output from their appropriate pins.

In addition to its port function, P8 is assigned secondary functions (such as SIO1 receive data input). If a secondary function output is to be used, set the corresponding bits of the port 8 mode register (P8IO) and the port 8 secondary function control register (P8SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 8 mode register (P8IO) to "0" to configure the input mode (same input as the primary function input).

If the port is set as an input (corresponding bits of P8IO = "0") and the port 8 secondary function control register (P8SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bit 0 of port 8 is set as a secondary function output (P8IO0 = 1, P8SF0 = 1), the output will be fixed at "0", regardless of the value of the port 8 data register.

Figure 5-15 shows the configuration of the port 8 data register (P8), port 8 mode register (P8IO) and the port 8 secondary function control register (P8SF).



0 output\*: "0" is output, regardless of the value of the port data register "—" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-15 P8, P8IO, P8SF Configuration

Table 5-13 lists the data that is read, depending on the settings of P8IO and P8SF, when executing an instruction to read P8.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P8 will become a high impedance input port (P8IO = 00H, P8SF = 00H) and the contents of P8 will be 00H.

Table 5-13 P8 Read Data

|      | P8IO | P8SF | Read data                                 |
|------|------|------|-------------------------------------------|
| P8_0 | 0    | *    | P8_0/RXD1 pin state                       |
|      | 1    | 0    | Value of bit 0 of P8 (port data register) |
|      | 1    | 1    | "0"                                       |
| P8_1 | 0    | *    | P8_1 pin state                            |
|      | 1    | 0    | Value of bit 1 of P8 (port data register) |
|      | 1    | 1    | TXD1 output data                          |
|      | 0    | *    | P8_2/RXC1 pin state                       |
| P8_2 | 1    | 0    | Value of bit 2 of P8 (port data register) |
|      | 1    | 1    | RXC1 output data                          |
| P8_3 | 0    | *    | P8_3/TXC1 pin state                       |
|      | 1    | 0    | Value of bit 3 of P8 (port data register) |
|      | 1    | 1    | TXC1 output data                          |
|      | 0    | *    | P8_4 pin state                            |
| P8_4 | 1    | 0    | Value of bit 4 of P8 (port data register) |
|      | 1    | 1    | TM4OUT output data                        |
| P8_6 | 0    | *    | P8_6 pin state                            |
|      | 1    | 0    | Value of bit 6 of P8 (port data register) |
|      | 1    | 1    | PWM2OUT output data                       |
| P8_7 | 0    | *    | P8_7 pin state                            |
|      | 1    | 0    | Value of bit 7 of P8 (port data register) |
|      | 1    | 1    | PWM3OUT output data                       |

"\*" indicates "0" or "1"

#### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P8, depending on the settings of P8IO and P8SF, values will be read as listed in Table 5-13. The modified values will be written to P8 (port 8 data register).

#### 5.13 Port 9 (P9)

Port 9 is a 5-bit I/O port. Each individual bit can be specified as input or output by the port 9 mode register (P9IO). When output is specified (corresponding bits of P9IO = "1"), the value of the corresponding bits in the port 9 data register (P9) will be output from their appropriate pins.

In addition to its port function, P9 is assigned secondary functions (such as external interrupt input). If a secondary function output is to be used, set the corresponding bits of the port 9 mode register (P9IO) and the port 9 secondary function control register (P9SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 9 mode register (P9IO) to "0" to configure the input mode (same input as the primary function input).

If the port is set as an input (corresponding bits of P9IO = "0") and the port 9 secondary function control register (P9SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bits 0 to 3 of port 9 are set as secondary function outputs (P9IOn = 1, P9SFn = 1), the output will be fixed at "0", regardless of the value of the port 9 data register.

Figure 5-16 shows the configuration of the port 9 data register (P9), port 9 mode register (P9IO) and the port 9 secondary function control register (P9SF).



0 output\*: "0" is output, regardless of the value of the port data register "—" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-16 P9, P9IO, P9SF Configuration

Table 5-14 lists the data that is read, depending on the settings of P9IO and P9SF, when executing an instruction to read P9.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P9 will become a high impedance input port (P9IO = 00H, P9SF = 00H) and the contents of P9 will be 00H.

Table 5-14 P9 Read Data

|      | P9IO | P9SF | Read data                                 |  |  |  |
|------|------|------|-------------------------------------------|--|--|--|
|      | 0    | *    | P9_0/EXINT4 pin state                     |  |  |  |
| P9_0 | 1    | 0    | Value of bit 0 of P9 (port data register) |  |  |  |
|      | 1    | 1    | "0"                                       |  |  |  |
|      | 0    | *    | P9_1/EXINT5 pin state                     |  |  |  |
| P9_1 | 1    | 0    | Value of bit 1 of P9 (port data register) |  |  |  |
|      | 1    | 1    | "0"                                       |  |  |  |
|      | 0    | *    | P9_2/EXINT6 pin state                     |  |  |  |
| P9_2 | 1    | 0    | Value of bit 2 of P9 (port data register) |  |  |  |
|      | 1    | 1    | "0"                                       |  |  |  |
|      | 0    | *    | P9_3/EXINT7 pin state                     |  |  |  |
| P9_3 | 1    | 0    | Value of bit 3 of P9 (port data register) |  |  |  |
|      | 1    | 1    | "0"                                       |  |  |  |
|      | 0    | *    | P9_7 pin state                            |  |  |  |
| P9_7 | 1    | 0    | Value of bit 7 of P9 (port data register) |  |  |  |
|      | 1    | 1    | HLDACK output                             |  |  |  |

"\*" indicates "0" or "1"

### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P9, depending on the settings of P9IO and P9SF, values will be read as listed in Table 5-14. The modified values will be written to P9 (port 9 data register).

### 5.14 Port 10 (P10)

Port 10 is a 3-bit I/O port. Each individual bit can be specified as input or output by the port 10 mode register (P10IO). When output is specified (corresponding bits of P10IO = "1"), the value of the corresponding bits in the port 10 data register (P10) will be output from their appropriate pins.

In addition to its port function, P10 is assigned secondary functions (such as SIO4 transmitreceive clock I/O). If a secondary function output is to be used, set the corresponding bits of the port 10 mode register (P10IO) and the port 10 secondary function control register (P10SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 10 mode register (P10IO) to "0" to configure the input mode (same input as the primary function input).

If the port is set as an input (corresponding bits of P10IO = "0") and the port 10 secondary function control register (P10SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bit 5 of port 10 is set as secondary function outputs (P10IOn = 1, P10SFn = 1), the output will be fixed at "0", regardless of the value of the port 10 data register.

Figure 5-17 shows the configuration of the port 10 data register (P10), port 10 mode register (P10IO) and the port 10 secondary function control register (P10SF).



0 output\*: "0" is output, regardless of the value of the port data register "—" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-17 P10, P10IO, P10SF Configuration

Table 5-15 lists the data that is read, depending on the settings of P10IO and P10SF, when executing an instruction to read P10.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P10 will become a high impedance input port (P10IO = 00H, P10SF = 00H) and the contents of P10 will be 00H.

Table 5-15 P10 Read Data

|       | P10IO | P10SF | Read data                                  |  |
|-------|-------|-------|--------------------------------------------|--|
|       | 0     | *     | P10_3/SIOCK4 pin state                     |  |
| P10_3 | 1     | 0     | Value of bit 3 of P10 (port data register) |  |
|       | 1     | 1     | SIOCK4 output data                         |  |
|       | 0     | *     | P10_4 pin state                            |  |
| P10_4 | 1     | 0     | Value of bit 4 of P10 (port data register) |  |
| 1 1   |       | 1     | SIOO4 output data                          |  |
|       | 0     | *     | P10_5/SIO14 pin state                      |  |
| P10_5 | 1     | 0     | Value of bit 5 of P10 (port data register) |  |
|       | 1     | 1     | "0"                                        |  |

<sup>&</sup>quot;\*" indicates "0" or "1"

### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P10, depending on the settings of P10IO and P10SF, values will be read as listed in Table 5-15. The modified values will be written to P10 (port 10 data register).

### 5.15 Port 11 (P11)

Port 11 is a 4-bit I/O port. Each individual bit can be specified as input or output by the port 11 mode register (P11IO). When output is specified (corresponding bits of P11IO = "1"), the value of the corresponding bits in the port 11 data register (P11) will be output from their appropriate pins.

In addition to its port function, P11 is assigned secondary functions (such as WAIT input). If a secondary function output is to be used, set the corresponding bits of the port 11 mode register (P11IO) and the port 11 secondary function control register (P11SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 11 mode register (P11IO) to "0" to configure the input mode (same input as the primary function input).

If the port is set as an input (corresponding bits of P11IO = "0") and the port 11 secondary function control register (P11SF) is set to "1", the pin inputs corresponding to those bits will be pulled-up.

If bits 0 and 1 of port 11 are set as secondary function outputs (P11IOn = 1, P11SFn = 1), the output will be fixed at "0", regardless of the value of the port 11 data register.

Figure 5-18 shows the configuration of the port 11 data register (P11), port 11 mode register (P11IO) and the port 11 secondary function control register (P11SF).



0 output\*: "0" is output, regardless of the value of the port data register "—" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-18 P11, P11IO, P11SF Configuration

Table 5-16 lists the data that is read, depending on the settings of P11IO and P11SF, when executing an instruction to read P11.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P11 will become a high impedance input port (P11IO = 00H, P11SF = 00H) and the contents of P11 will be 00H.

Table 5-16 P11 Read Data

|       | P11IO | P11SF | Read data                                  |  |  |  |
|-------|-------|-------|--------------------------------------------|--|--|--|
|       | 0     | *     | P11_0/WAIT pin state                       |  |  |  |
| P11_0 | 1     | 0     | Value of bit 0 of P11 (port data register) |  |  |  |
|       | 1     | 1     | "0"                                        |  |  |  |
|       | 0     | *     | P11_1/HOLD pin state                       |  |  |  |
| P11_1 | 1     | 0     | Value of bit 1 of P11 (port data register) |  |  |  |
| 1     |       | 1     | "0"                                        |  |  |  |
|       | 0     | *     | P11_2 pin state                            |  |  |  |
| P11_2 | 1     | 0     | Value of bit 2 of P11 (port data register) |  |  |  |
|       | 1 1   |       | CLKOUT output data                         |  |  |  |
|       | 0     | *     | P11_3 pin state                            |  |  |  |
| P11_3 | 1     | 0     | Value of bit 3 of P11 (port data register) |  |  |  |
|       | 1     | 1     | XTOUT output data                          |  |  |  |

"\*" indicates "0" or "1"

### [Note]

If arithmetic, SB, RB, XORB or other read-modify-write instructions are executed for P11, depending on the settings of P11IO and P11SF, values will be read as listed in Table 5-16. The modified values will be written to P11 (port 11 data register).

### 5.16 Port 12 (P12)

Port 12 is an 8-bit input-only port. Therefore, there is no mode register or secondary function control register.

The pin status can be read by the port 12 data register (P12).

In addition to its port function, a secondary function (analog input for A/D converter) is assigned to P12 (same input as the primary function input).

There are no pulled-up inputs at port 12.

Figure 5-19 shows the configuration of the port 12 data register (P12). Table 5-17 lists the P12 read data.



Figure 5-19 P12 Configuration

Table 5-17 P12 Read Data

|       | Read data           |
|-------|---------------------|
| P12_0 | P12_0/Al0 pin state |
| P12_1 | P12_1/Al1 pin state |
| P12_2 | P12_2/Al2 pin state |
| P12_3 | P12_3/Al3 pin state |
| P12_4 | P12_4/Al4 pin state |
| P12_5 | P12_5/Al5 pin state |
| P12_6 | P12_6/Al6 pin state |
| P12_7 | P12_7/AI7 pin state |

### 5.17 Port 14 (P14)

Port 14 is a 5-bit I/O port. Each individual bit can be specified as input or output by the port 14 mode register (P14IO). When output is specified (corresponding bits of P14IO = "1"), the value of the corresponding bits in the port 14 data register (P14) will be output from their appropriate pins.

In addition to its port function, P14 is assigned secondary functions (such as SIO5 receive data input). If a secondary function output is to be used, set the corresponding bits of the port 14 mode register (P14IO) and the port 14 secondary function control register (P14SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 14 mode register (P14IO) to "0" to configure the input mode (same input as the primary function input).

If the port is configured as an input (corresponding bits of P14IO = "0") and the port 14 secondary function control register (P14SF) is set to "1", inputs will be pulled-up at the pins corresponding to those bits.

If bit 2 of port 14 is configured as a secondary function output (P14IO0 = 1, P14SF0 = 1), the output will be fixed at "0", regardless of the value of the port 14 data register.

Figure 5-20 shows the configuration of the port 14 data register (P14), port 14 mode register (P14IO) and the port 14 secondary function control register (P14SF).



-" indicates a bit that does not exist. If read, the value will be "0."

Figure 5-20 P14, P14IO, P14SF Configuration

Table 5-18 lists the data that is read, depending on the settings of P14IO and P14SF, when executing an instruction to read P14.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), P14 will become a high impedance input port (P14IO = 00H, P14SF = 00H) and the contents of P14 will be 00H.

Table 5-18 P14 Read Data

|                        | P14IO               | P14SF | Read data                                  |  |
|------------------------|---------------------|-------|--------------------------------------------|--|
|                        | 0                   | *     | P14_0/SIOCK5 pin state                     |  |
| P14_0                  | 1                   | 0     | Value of bit 0 of P14 (port data register) |  |
|                        | 1                   | 1     | SIOCK5 output data                         |  |
|                        | 0                   | *     | P14_1 pin state                            |  |
| P14_1                  | 1                   | 0     | Value of bit 1 of P14 (port data register) |  |
|                        | 1                   | 1     | SIOO5 output data                          |  |
|                        | 0                   | *     | P14_2/SIOI5 pin state                      |  |
| P14_2                  | 1                   | 0     | Value of bit 2 of P14 (port data register) |  |
| 1 1                    |                     | 1     | "0"                                        |  |
|                        | 0                   | *     | P14_6 pin state                            |  |
| P14_6                  | 1                   | 0     | Value of bit 6 of P14 (port data register) |  |
|                        | 1 1 AO0 output data |       | AO0 output data                            |  |
|                        | 0                   | *     | P14_7 pin state                            |  |
| P14_7 1 0 Value of bit |                     | 0     | Value of bit 7 of P14 (port data register) |  |
|                        | 1                   | 1     | AO1 output data                            |  |

<sup>&</sup>quot;\*" indicates "0" or "1"

### [Note]

If arthmetic, SB, RB, XORB or other read-modify-write instructions are executed for P14, depending on the settings of P14IO and P14SF, values will be read as listed in Table 5-18. The modified values will be written to P14 (port 14 data register).

### 5.18 Port 15 (P15)

Port 15 is a 4-bit I/O port. Each individual bit can be specified as input or output by the port 15 mode register (P15IO). When output is specified (corresponding bits of P15IO = "1"), the value of the corresponding bits in the port 15 data register (P15) will be output from their appropriate pins.

In addition to its port function, P15 is assigned secondary functions (such as SIO6 receive data input). If a secondary function output is to be used, set the corresponding bits of the port 15 mode register (P15IO) and the port 15 secondary function control register (P15SF) to "1". If a secondary function input is to be used, reset corresponding bits of the port 15 mode register (P15IO) to "0" to configure the input mode (same input as the primary function input).

If the port is configured as an input (corresponding bits of P15IO = "0") and the port 15 secondary function control register (P15SF) is set to "1", inputs will be pulled-up at the pins corresponding to those bits.

If bit 0 of port 15 is configured as a secondary function output (P15IO0 = 1, P15SF0 = 1), the output will be fixed at "0", regardless of the value of the port 15 data register.

Figure 5-21 shows the configuration of the port 15 data register (P15), port 15 mode register (P15IO) and the port 15 secondary function control register (P15SF).



Figure 5-21 P15, P15IO, P15SF Configuration

Table 5-19 lists the data that is read, depending on the settings of P15IO and P15SF, when executing an instruction to read P15.

At reset (due to a  $\overline{\text{RES}}$  input, BRK instruction execution, watchdog timer overflow, or opcode trap), P15 will become a high impedance input port (P15IO = 00H, P15SF = 00H) and the contents of P15 will be 00H.

Table 5-19 P15 Read Data

|                                                                           | P15IO          | P15SF                                      | Read data                                  |  |  |  |
|---------------------------------------------------------------------------|----------------|--------------------------------------------|--------------------------------------------|--|--|--|
|                                                                           | 0 * P15_0/RXD6 |                                            | P15_0/RXD6 pin state                       |  |  |  |
| P15_0                                                                     | 1              | 0                                          | Value of bit 0 of P15 (port data register) |  |  |  |
|                                                                           | 1              | 1                                          | "0"                                        |  |  |  |
|                                                                           | 0              | *                                          | P15_1 pin state                            |  |  |  |
| P15_1                                                                     | 1              | 0                                          | Value of bit 1 of P15 (port data register) |  |  |  |
|                                                                           | 1              | 1                                          | TXD6 output data                           |  |  |  |
|                                                                           | 0              | *                                          | P15_2/RXC6 pin state                       |  |  |  |
| P15_2 1 0 Value of bit 2 of P15 (port data register) 1 1 RXC6 output data |                | Value of bit 2 of P15 (port data register) |                                            |  |  |  |
|                                                                           |                | RXC6 output data                           |                                            |  |  |  |
|                                                                           | 0              | *                                          | P15_3/TXC6 pin state                       |  |  |  |
| P15_3                                                                     | 1              | 0                                          | Value of bit 3 of P15 (port data register) |  |  |  |
|                                                                           | 1              | 1                                          | TXC6 output data                           |  |  |  |

<sup>&</sup>quot;\*" indicates "0" or "1"

### [Note]

If arthmetic, SB, RB, XORB or other read-modify-write instructions are executed for P15, depending on the settings of P15IO and P15SF, values will be read as listed in Table 5-19. The modified values will be written to P15 (port 15 data register).

# Chapter 6

# **Clock Oscillation Circuit**

6

### 6. Clock Oscillation Circuit

### 6.1 Overview

The MSM66577 family has two systems of internal clock oscillation circuits, OSC and XT. Four types of clocks can be selected as the CPU operating clock (CPUCLK): OSCCLK (main clock), frequency divided clocks (1/2OSCCLK, 1/4OSCCLK), and XTCLK (sub clock). The current consumed during operation can be reduced by changing the clock in response to the operating conditions. XT is used mainly for the real-time counter. Externally generated clocks can be input directly to both OSC and XT.

### 6.2 Clock Oscillation Circuit Configuration

Figure 6-1 shows the configuration of the clock oscillation circuit.



OSCCLK: Main clock

XTCLK: Subclock (32.768 kHz)
CPUCLK: CPU operating clock
SBYCON: Standby control register
PRPHCON: Peripheral control register

Figure 6-1 Clock Oscillation Circuit Configuration

### 6.3 Clock Oscillation Circuit Registers

Table 6-1 lists a summary of the SFRs for clock oscillation circuit control.

Table 6-1 Summary of SFRs for Clock Oscillation Circuit Control

| Address | Name                        | Symbol  | Symbol | R/W  | 8/16      | Initial   | Reference |
|---------|-----------------------------|---------|--------|------|-----------|-----------|-----------|
| [H]     | name                        | (byte)  | (word) | H/VV | Operation | value [H] | page      |
| 000F    | Standby control register    | SBYCON  | _      | R/W  | 8         | 08        | 3-4       |
| 0015☆   | Peripheral control register | PRPHCON | _      | R/W  | 8         | 8C        | 15-2      |

### [Notes]

- A star (☆) in the address column indicates a missing bit.
- 2. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

### 6.4 OSC Oscillation Circuit

The OSC oscillation circuit generates the main clock pulse (OSCCLK). A crystal oscillator and other required elements are connected to OSC0 and OSC1.

Figure 6-2 shows the configuration of the OSC oscillation circuit. Figure 6-3 shows an example connection of an OSC crystal oscillation circuit.



Figure 6-2 OSC Oscillation Circuit Configuration



Figure 6-3 OSC Crystal Oscillation Circuit Connection Example

### [Notes]

- 1. The values of C0 and C1 must be set based on the specifications of the external crystal (XTAL).
- 2. Instead of XTAL, a ceramic resonator may be used.
- 3. Depending upon the frequency band used, additional components (not shown) may be required.

Table 6-2 shows examples of circuit constants in the case of using a ceralock of Murata MFG. make.

**Table 6-2 Examples of Circuit Constants** 

| _          |                                  | Recomm | nended c | onstants   | Operating            | Operating conditions |  |
|------------|----------------------------------|--------|----------|------------|----------------------|----------------------|--|
| Frequency  | Product number                   | C0     | C1       | Rd         | Power supply         | Temperature          |  |
| [Hz]       |                                  | [pF]   | [pF]     | $[\Omega]$ | voltage range<br>[V] | range<br>[°C]        |  |
| 2 MHz      | CSTLS2M00G56-B0/CSTCC2M00G56-R0  | _      |          | 680        |                      |                      |  |
| 2 1011 12  | (built-in load capacitor type)   |        |          | 000        |                      |                      |  |
| 4 MHz      | CSTLS4M00G56-B0/CSTCK4M00G55-R0  | _      | _        | 220        | 2.4 to 3.6/          |                      |  |
| 4 1011 12  | (built-in load capacitor type)   |        |          | 220        | 4.5 to 5.5           |                      |  |
| 10 MHz     | CSTLS10M0G56-B0/CSTCC10M0G056-R0 |        |          | 0          |                      |                      |  |
| 10 1011 12 | (built-in load capacitor type)   | _      | _        | U          |                      |                      |  |
| 14 MHz     | CSACV14M0X55J-R0                 | 10     | 10       | 0          |                      | -30 to +70           |  |
| 20 MHz     | CSA20.00MXZ040, CST20.00MXW040   | 15     | 15       | 0          |                      |                      |  |
| 20 1011 12 | (built-in load capacitor type)   | 13     | 13       | O          |                      |                      |  |
| 24 MHz     | CSA24.00MXZ040, CST24.00MXW0H1   | 5      | 5        | 0          | 4.5 to 5.5           |                      |  |
| 24 1011 12 | (built-in load capacitor type)   | 3      | 5        |            | 4.5 10 5.5           |                      |  |
| 30 MHz     | CSA30.00MXZ040, CST30.00MXW040   | 5      | 5        | 0          |                      |                      |  |
| JO IVII IZ | (built-in load capacitor type)   | 5      | )<br>    | U          |                      |                      |  |

If the main clock pulse (OSCCLK) is to be supplied externally, connect it directly to the OSC0 pin input. Leave the OSC1 pin open (unconnected).

Figure 6-4 shows an example connection when the OSC clock is input externally.



Figure 6-4 Connection Example for External OSC Clock Input

### [Note]

If an external clock is to be used for operation, keep the clock pulse width as specified by the AC characteristics.

The standby control register (SBYCON) can be set to halt the OSC oscillation circuit. When resuming oscillation of the OSC oscillation circuit from a halted state, the main clock pulse (OSCCLK) will be transmit after waiting for the oscillation stabilization time, the number of clock cycles specified by OST0 and OST1 (bits 4 and 5) of SBYCON. Because the oscillation stabilization time differs depending upon the oscillator used, externally mounted components, and the frequency band, first verify the actual oscillation stabilization time of the circuit board in the product application, and then set SBYCON with the wait time until suitable oscillation stabilization is achieved.

### 6.5 XT Oscillation Circuit

The XT oscillation circuit generates the subclock pulse (XTCLK). A crystal oscillator of 32.768 kHz and other required elements are connected to XT0 and  $\overline{\text{XT1}}$ .

To reduce power consumption, the XT oscillation circuit operates at a voltage level that is regulated internally. Before an external clock is to be input, set EXTXT (bit 4) of the peripheral control register (PRPHCON) to "1" (refer to Section 15.3). This switches the internally regulated voltage to  $V_{DD}$  and turns OFF the oscillation feedback resistors.

Figure 6-5 shows the configuration of the XT oscillation circuit. Figure 6-6 shows an example connection of the XT crystal oscillation circuit.



\*If the EXTXT flag of PRPHCON is set to "1", feedback resistors are OFF.

Figure 6-5 XT Oscillation Circuit Configuration



Figure 6-6 XT Crystal Oscillation Circuit Connection Example

### [Notes]

- The values of C2 and C3 must be set based on the specification of the external XTAL (32.768 kHz).
- 2. Because the XT oscillation circuit was designed to be connected to an extremely low power crystal, there may not be any oscillation if another type of crystal is connected.

If the subclock pulse (XTCLK) is to be supplied externally, connect it to the XT0 pin input and leave the  $\overline{XT1}$  pin open (unconnected).

Figure 6-7 shows an example connection when the XT clock is input externally.



Figure 6-7 Connection Example for External XT Clock Input

### [Note]

Before an external clock is to be used in the XT oscillation circuit, set EXTXT (bit 4) of PRPHCON to "1".

The XT oscillation circuit cannot be halted by the program. Because there is no circuit to control the oscillation stabilization time, <u>from the time when power is turned on until overflow of the real-time counter causes bit 12 (RTC12) to be set, do not select the sub clock (XTCLK) as the CPU operation clock (CPUCLK).</u>

If the sub clock (XTCLK) is not used, fix the XT0 pin at GND level and set EXTXT (bit 4) of PRPHCON to "1".

# Chapter 7

# Time Base Counter (TBC)

7

### 7. Time Base Counter (TBC)

### 7.1 Overview

The MSM66577 family has an 8-bit internal time base counter (TBC) to generate a reference clock for internal peripheral modules.

The front stage of the TBC has an auto-reload type 4-bit 1/n counter. Base clocks can be generated for internal peripheral from the wide-ranging CPUCLK frequency.

### 7.2 Time Base Counter (TBC) Configuration

Figure 7-1 shows the TBC configuration.



Figure 7-1 TBC Configuration

### 7.3 Time Base Counter Registers

Table 7-1 lists a summary of SFRs for time base counter control.

Table 7-1 Summary of SFRs for Time Base Counter Control

| Address | Name                       | Symbol  | Symbol | R/W      | 8/16      | Initial   | Reference |
|---------|----------------------------|---------|--------|----------|-----------|-----------|-----------|
| [H]     | Name                       | (byte)  | (word) | I □/ V V | Operation | value [H] | page      |
| 0060☆   | TBC clock divider register | TBCKDVR | TDCKDV | R/W      | 8/16      | F0        | 7-3       |
| 0061 ☆  | TBC clock divider counter  | _       | TBCKDV | R        | 16        | F0        | 7-2       |

### [Notes]

- 1. A star (☆) in the address column indicates a missing bit.
- 2. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

### 7.4 1/n Counter

To generate base clocks for internal peripheral modules from the wide ranging CPUCLK frequency, the MSM66577 family is equipped with a 4-bit auto-reload timer into which CPUCLK is input.

This 1/n counter consists of a 4-bit counter (TBC clock dividing counter) and a 4-bit register that stores the reload value (TBC clock divider register).

### 7.4.1 Description of 1/n Counter Registers

### (1) TBC clock dividing counter (TBCKDV upper 8 bits)

The TBC clock dividing counter (upper 8 bits of TBCKDV) is a 4-bit counter and its input is CPUCLK. When the counter overflows it is loaded with the contents of the TBC clock divider register (TBCKDVR).

The TBC clock dividing counter (upper 8 bits of TBCKDV) can be accessed only in word sized units. The value of the TBC clock dividing counter is read from the four bits of bit 8 through bit 11. If the upper 4 bits are read, a value of "1" will always be obtained. The TBC clock divider register (TBCKDVR) is read from the lower 8 bits of TBCKDV.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the upper 8 bits of TBCKDV become F0H.

Figure 7-2 shows the configuration of the upper 8 bits of TBCKDV.



Figure 7-2 Configuration of Upper 8 Bits of TBCKDV

### (2) TBC clock divider register (TBCKDVR)

The TBC clock divider register (TBCKDVR) consists of 4 bits. This register stores the value to be reloaded into the TBC clock dividing counter.

TBCKDVR can be read from or written to by the program. However, write operations are not valid for bits 4 through 7. If read, bits 4 through 7 are always "1".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TBCKDVR becomes F0H.

### [Note]

When reset, the 1/n counter divides CPUCLK by 16 and 1/16CPUCLK is supplied to TBC as TBCCLK. Therefore, after writing a reload value to TBCKDVR, there may be at most a delay of 16 CPUCLK pulses before the start of the division operation (as per the written value).

Figure 7-3 shows the configuration of TBCKDVR. Table 7-2 lists the correspondence between TBCKDVR settings and TBCCLK.



"—" indicates a nonexistent bit. When read, its value will be "1."

Figure 7-3 TBCKDVR (Lower 8 Bits of TBCKDV) Configuration

Table 7-2 Correspondence between TBCKDVR Settings and TBCCLK

| Value of TBCKDVR settings [H] | TBCCLK      |
|-------------------------------|-------------|
| F0                            | 1/16 CPUCLK |
| F1                            | 1/15 CPUCLK |
| F2                            | 1/14 CPUCLK |
| F3                            | 1/13 CPUCLK |
| F4                            | 1/12 CPUCLK |
| F5                            | 1/11 CPUCLK |
| F6                            | 1/10 CPUCLK |
| F7                            | 1/9 CPUCLK  |
| F8                            | 1/8 CPUCLK  |
| F9                            | 1/7 CPUCLK  |
| FA                            | 1/6 CPUCLK  |
| FB                            | 1/5 CPUCLK  |
| FC                            | 1/4 CPUCLK  |
| FD                            | 1/3 CPUCLK  |
| FE                            | 1/2 CPUCLK  |
| FF                            | 1/1 CPUCLK  |

### 7.4.2 Example of 1/n Counter-related Register Settings

• TBC clock divider register (TBCKDVR)
This register stores the reload value to the TBC clock dividing counter. When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the reload value becomes F0H, and TBCCLK becomes CPUCLK divided by 16 (1/16CPUCLK). If TBCCLK is set to 1/1CPUCLK, the reload value becomes FFH.

### 7.5 Time Base Counter (TBC) Operation

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the time base counter (TBC) is reset to "0". Thereafter, as long as the original oscillation (CPCLK) supply is not halted, operation will continue by TBCCLK that has been divided by the front stage 1/n counter.

Overflow of TBC is divided further by a frequency divider circuit, and supplied to the general-purpose 8-bit timer 6 (that also functions as the watchdog timer).

## Chapter 8

# General-Purpose 8/16 Bit Timers

### 8. General-Purpose 8/16 Bit Timers

### 8.1 Overview

The MSM66577 family has the following internal general-purpose timers: a 16-bit autoreload timer (timer 0), six 8-bit auto-reload timers (timers 1, 2, 3, 4, 5, and 9), and an 8-bit auto-reload timer that also functions as a watchdog timer (timer 6). Timers 1 and 2 can be combined and used as a 16-bit timer.

### 8.2 General-purpose 8-bit/16-bit Timer Configurations

Table 8-1 lists a summary of the function of each general-purpose timer. Marks ( $\checkmark$ ) within the table indicate that a function can be selected. Dashes (—) indicate that the function cannot be selected.

**Table 8-1 Timer Configurations and Functions** 

| Timer   | 8/16 bits  | Auto-reload | External    | Timer    | PWM clock | Baud rate   | Watchdog     |
|---------|------------|-------------|-------------|----------|-----------|-------------|--------------|
| name    | 6/ 10 DILS | Auto-reload | event input | output   | output    | generator   | timer        |
| Timer 0 | 16         | <b>✓</b>    | <           | <b>/</b> | _         | _           | _            |
| Timer 1 | 8/16       | <b>✓</b>    | <b>/</b>    | <b>/</b> | _         | _           | _            |
| Timer 2 | 8/16       | <b>✓</b>    | <b>✓</b>    | <b>√</b> | _         | _           | _            |
| Timer 3 | 8          | <b>✓</b>    | _           | _        | _         | √ (SIO6)    | _            |
| Timer 4 | 8          | <b>✓</b>    | _           | <b>/</b> | _         | √ (SIO1)    | _            |
| Timer 5 | 8          | <b>✓</b>    | _           | _        | _         | √ (SIO4, 5) | _            |
| Timer 6 | 8          | <b>√</b>    | _           | _        | _         | _           | $\checkmark$ |
| Timer 9 | 8          | <b>√</b>    | _           | _        | <b>/</b>  | _           | _            |

[Note]

TMOUT of timers 3, 5 and 9 are not output on ports, but can be used by software as a flag.

### 8.3 General-purpose 8-bit/16-bit Timer Registers

Table 8-2 lists a summary of SFRs for the control of general-purpose 8-bit and 16-bit timers.

Table 8-2 Summary of SFRs for General-Purpose 8-bit/16-bit Timer Control

| Addraga     |                                        | Cumbal    | Cumbal        |     | 8/16      | Initial   | Deference |
|-------------|----------------------------------------|-----------|---------------|-----|-----------|-----------|-----------|
| Address     | Name                                   | Symbol    | Symbol (word) | R/W |           | Initial   | Reference |
| [H]<br>0062 | Canaral nurnage 16 bit                 | (byte)    | (word)        |     | Operation | value [H] | page      |
| 0062        | General-purpose 16-bit timer 0 counter | _         | TM0C          | R/W | 16        | Undefined | 8-4       |
|             |                                        |           |               |     |           |           |           |
| 0064        | General-purpose 16-bit                 | _         | TM0R          | R/W | 16        | Undefined | 8-4       |
| 0005        | timer 0 register                       |           |               |     |           |           |           |
| 0066☆       | General-purpose 16-bit                 | TM0CON    | _             | R/W | 16        | 70        | 8-4       |
| 0068        | timer 0 control register               | TM1C      |               |     |           |           |           |
|             | General-purpose 8-bit                  |           | TM12C         | R/W | 8/16      | Undefined | 8-10      |
| 0069        | timer 12 counter                       | TM2C      |               |     |           |           |           |
| 006A        | General-purpose 8-bit                  | TM1R      | TM12R         | R/W | 8/16      | Undefined | 8-10      |
| 006B        | timer control register                 | TM2R      |               |     |           |           |           |
| 006C☆       | General-purpose 8-bit                  | TM1CON    | _             | R/W | 8         | 70        | 8-10      |
|             | timer 1 control register               |           |               |     |           |           |           |
| 006D☆       | General-purpose 8-bit                  | TM2CON    | _             | R/W | 8         | 40        | 8-11      |
|             | timer 2 control register               |           |               |     |           |           |           |
| 0070        | General-purpose 8-bit                  | TM3C      | _             | R/W | 8         | Undefined | 8-22      |
|             | timer 3 counter                        |           |               |     |           |           |           |
| 0071        | General-purpose 8-bit                  | TM3R      | _             | R/W | 8         | Undefined | 8-22      |
|             | timer 3 register                       |           |               |     |           |           |           |
| 0072☆       | General-purpose 8-bit                  | TM3CON    | _             | R/W | 8         | 70        | 8-22      |
| 0072 M      | timer 3 control register               |           |               |     |           |           |           |
| 0074        | General-purpose 8-bit                  | TM4C      | _             | R/W | 8         | Undefined | 8-28      |
|             | timer 4 counter                        |           |               |     |           |           |           |
| 0075        | General-purpose 8-bit                  | TM4R      | _             | R/W | 8         | Undefined | 8-28      |
| 0070        | timer 4 register                       | 1141111   |               |     |           |           |           |
| 0076☆       | General-purpose 8-bit                  | TM4CON    | _             | R/W | 8         | 70        | 8-28      |
| 0070 %      | timer 4 control register               | 110140014 |               |     |           |           |           |
| 0078        | General-purpose 8-bit                  | TM5C      | _             | R/W | 8         | Undefined | 8-34      |
| 0070        | timer 5 counter                        | 110100    |               |     |           |           |           |
| 0079        | General-purpose 8-bit                  | TM5R      | _             | R/W | 8         | Undefined | 8-34      |
| 0073        | timer 5 register                       | TIVIOIT   |               |     |           |           |           |
| 007A☆       | General-purpose 8-bit                  | TM5CON    | _             | R/W | 8         | Undefined | 8-34      |
| UUIAM       | timer 5 control register               | TIVISCOIN |               |     |           |           |           |
| 007C        | General-purpose 8-bit                  | TM6C      | _             | R/W | 8         | Undefined | 8-40      |
| 0070        | timer 6 counter                        | TIVIOC    |               |     |           |           | 8-40      |
| 007D        | General-purpose 8-bit                  | TMOD      |               | R/W | 8         | Undefined | 0.40      |
| 007D        | timer 6 register                       | TM6R      | _             |     |           |           | 8-40      |
| 0075        | General-purpose 8-bit                  |           | _             | R/W | 8         | 40        | 0.44      |
| 007E☆       | timer 6 control register               | TM6CON    |               |     |           | 10        | 8-41      |
|             | General-purpose 8-bit                  |           | _             | R/W | 8         | Llanda C  | 0.40      |
| 00CC        | timer 9 counter                        | TM9C      |               |     |           | Undefined | 8-49      |
| 00CD        | General-purpose 8-bit                  |           | _             | R/W | 8         | Linda Co  | 0.40      |
|             | timer 9 register                       | TM9R      |               |     |           | Undefined | 8-49      |
|             | General-purpose 8-bit                  |           |               |     | _         |           |           |
| 00CE☆       | timer 9 control register               | TM9CON    | -             | R/W | 8         | 70        | 8-49      |
|             |                                        | l         |               |     |           | L         |           |

### [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (☆) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".
- 4. Bits 5 and 6 of the TM6COM register allow read only access (W is invalid). Bits 0 to 3 and 7 allow R/W access.

### 8.4 Timer 0

Timer 0 is a 16-bit auto-reload timer that has functions for external event input and timer output.

### 8.4.1 Timer 0 Configuration

Figure 8-1 shows the timer 0 configuration.



TM0C: General-purpose 16-bit timer 0 counter TM0R: General-purpose 16-bit timer 0 register

TM0CON: General-purpose 16-bit timer 0 control register

TM0EVT: Timer 0 external event input pin (P5\_7)

TM0OUT: Timer 0 output pin (P5\_6)

Figure 8-1 Timer 0 Configuration

### 8.4.2 Description of Timer 0 Registers

### (1) General-purpose 16-bit timer 0 counter (TM0C)

The general-purpose 16-bit timer 0 counter (TM0C) is a 16-bit up-counter. When this counter overflows, an interrupt request is generated and it is loaded with the contents of general-purpose 16-bit timer 0 register (TM0R).

TM0C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TMOC are undefined.

### [Note]

Writing a timer value to TM0C causes the same value to also be written to the general-purpose 16-bit timer 0 register (TM0R).

### (2) General-purpose 16-bit timer 0 register (TM0R)

The general-purpose 16-bit timer 0 register (TM0R) consists of 16 bits. This register stores the value to be reloaded into the general-purpose 16-bit timer 0 counter (TM0C).

TM0R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TMOR are undefined.

### (3) General-purpose 16-bit timer 0 control register (TM0CON)

The general-purpose 16-bit timer 0 control register (TM0CON) consists of 5 bits. Bits 0 to 2 (TM0C0 to TM0C2) of TM0CON select the timer 0 count clock, bit 3 (TM0RUN) starts or halts the counting, and bit 7 (TM0OUT) specifies the initial timer output level (High or Low) at start-up. And each time TM0C overflows, the content of bit 7 (TM0OUT) is reversed.

TM0CON can be read from and written to by the program. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bits 4 to 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM0CON becomes 70H.

Figure 8-2 shows the TM0CON configuration.

### [Note]

<u>Just before TM0C overflows</u>, if an SB, RB, XORB or other read-modify-write instruction is performed on TM0CON, then TM0OUT may not operate correctly.



<sup>&</sup>quot;—" indicates a nonexistent bit. When read, its value will be "1."

Figure 8-2 TM0CON Configuration

### 8.4.3 Example of Timer 0-related Register Settings

### (1) Port 5 mode register (P5IO)

If TM0OUT (timer output) is to be used, set bit 6 (P5IO6) to "1" to configure the port as an output. If TM0EVT (event input) is to be used, reset bit 7 (P5IO7) to "0" to configure the port as an input.

### (2) Port 5 secondary function control register (P5SF)

If TM0OUT (timer output) is to be used, set bit 6 (P5SF6) to "1" to configure the port as a secondary function output. If TM0EVT (event input) is to be used, disable or enable the pull-up resistor with bit 7 (P5SF7).

### (3) General-purpose 16-bit timer 0 counter (TM0C)

Set the timer value that will be valid at the start of counting. When writing to TM0C, the same value will also be simultaneously and automatically written to the general-purpose 16-bit timer 0 register (TM0R).

### (4) General-purpose 16-bit timer 0 register (TM0R)

This register sets the value to be loaded after general-purpose 16-bit timer 0 counter (TM0C) overflows. If the timer value (TM0C) and the reload value (TM0R) are identical, this register will automatically be set just by setting TM0C. If the values are different or are to be modified, this register must be set explicitly.

### (5) General-purpose 16-bit timer 0 control register (TM0CON)

Bits 0 to 2 (TM0C0 to TM0C2) of this register set the count clock for timer 0. If TM0OUT (timer output) is to be used, specify the initial value with bit 7 (TM0OUT). If bit 3 (TM0RUN) is set to "1", timer 0 will begin counting. If reset to "0", timer 0 will halt counting.

### 8.4.4 Timer 0 Operation

When the TM0RUN bit is set to "1", timer 0 will begin counting upward, running on the count clock selected by TM0CON. If external event input is selected as the count clock, timer 0 can also be used as an event counter. When TM0C overflows, an interrupt request is generated, the contents of TM0R are loaded into TM0C and the TM0OUT output is inverted. The initial value of the TM0OUT pin is specified by bit 7 (TM0OUT) of TM0CON. This operation is repeated until the TM0RUN bit is reset to "0". Figure 8-3 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/4 TBCCLK).



Figure 8-3 Timer 0 Operation

### [Note]

Set the minimum pulse width of the external event input to at least 1 CPU clock (CPUCLK). The external event input signal is sampled at the falling edge of the CPUCLK to create the count clock for the timer.

### 8.4.5 Timer 0 Interrupt

When a timer 0 interrupt factor occurs, the interrupt request flag (QTM0OV) is set to "1". The interrupt request flag (QTM0OV) is located in interrupt request register 1 (IRQ1).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM0OV). The interrupt enable flag (ETM0OV) is located in interrupt enable register 1 (IE1).

Three levels of priority can be set with the interrupt priority setting flags (P0TM0OV and P1TM0OV). The interrupt priority setting flags are located in interrupt priority control register 2 (IP2).

Table 8-3 lists the vector address of the timer 0 interrupt factor and the interrupt processing flags.

Table 8-3 Timer 0 Vector Address and Interrupt Processing Flags

| Interview to store                 | Vector         | Interrupt | Interrupt | Priority level |         |
|------------------------------------|----------------|-----------|-----------|----------------|---------|
| Interrupt factor                   | address [H]    | request   | enable    | 1              | 0       |
| Overflow of timer 0                | 001A           | QTM0OV    | ETM0OV    | P1TM0OV        | P0TM0OV |
| Symbols (byte) of registers that   |                | IRQ1      | IE1       | IP2            |         |
| contain interrupt processing flags |                | INQ1 IE1  |           | IF Z           |         |
|                                    | Reference page | 17-13     | 17-18     | 17-24          |         |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

### 8.5 Timers 1 and 2

Timers 1 and 2 are 8-bit auto-reload timers. Timers 1 and 2 can be combined and used in a 16-bit auto-reload mode. Timers 1 and 2 have functions for external event input, timer output, and PWM mode.

### 8.5.1 Timers 1 and 2 Configurations

Figure 8-4 shows the configuration of timers 1 and 2.



TM1C: General-purpose 8-bit timer 1 counter TM2C: General-purpose 8-bit timer 2 counter TM1R: General-purpose 8-bit timer 1 register TM2R: General-purpose 8-bit timer 2 register

TM1CON: General-purpose 8-bit timer 1 control register TM2CON: General-purpose 8-bit timer 2 control register TM1EVT: Timer 1 external event input pin (P6\_4) TM2EVT: Timer 2 external event input pin (P6\_6)

TM1OUT: Timer 1 output pin (P6\_5) TM2OUT: Timer 2 output pin (P6\_7)

Figure 8-4 Timer 1 and 2 Configurations

### 8.5.2 Description of Timer 1 and 2 Registers

### (1) General-purpose 8-bit timer 1 and 2 counters (TM1C, TM2C)

The general-purpose 8-bit timer 1 and 2 counters (TM1C, TM2C) are 8-bit up-counters. When each counter overflows, an interrupt request is generated and that counter is loaded with the contents of the general-purpose 8-bit timer 1 or 2 register (TM1R, TM2R).

TM1C and TM2C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM1C and TM2C are undefined.

### [Note]

Writing a timer value to TM1C or TM2C causes the same value to also be written to the general-purpose 8-bit timer 1 and 2 registers (TM1R, TM2R).

### (2) General-purpose 8-bit timer 1 and 2 registers (TM1R, TM2R)

The general-purpose 8-bit timer 1 and 2 registers (TM1R, TM2R) consist of 8 bits. These registers store the value to be reloaded into the general-purpose 8-bit timer 1 or 2 counter (TM1C, TM2C).

TM1R and TM2R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM1R and TM2R are undefined.

### (3) General-purpose 8-bit timer 1 control register (TM1CON)

The general-purpose 8-bit timer 1 control register (TM1CON) consists of 5 bits. Bits 0 to 2 (TM1C0 to TM1C2) of TM1CON select the timer 1 count clock, bit 3 (TM1RUN) starts or stops the counting, and bit 7 (TM1OUT) specifies the initial timer output level (High or Low) at start-up. The value of bit 7 (TM1OUT) is inverted when TM1C overflows.

TM1CON can be read from and written to by the program. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bits 4 to 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM1CON becomes 70H.

Figure 8-5 shows the TM1CON configuration.

|          | 7      | 6 | 5 | 4 | 3      | 2     | 1     | 0     | Address: 006C [H] |      |          |                       |
|----------|--------|---|---|---|--------|-------|-------|-------|-------------------|------|----------|-----------------------|
| TM1CON   | TM1OUT | _ | _ | _ | TM1RUN | TM1C2 | TM1C1 | TM1C0 | F                 |      |          | s: R/W                |
| At reset | 0      | 1 | 1 | 1 | 0      | 0     | 0     | 0     | П                 | TM1C |          |                       |
|          |        |   |   |   |        |       |       |       |                   |      | 0        | Timer 1 count clock   |
|          |        |   |   |   |        |       |       |       | 2                 | _    | -        |                       |
|          |        |   |   |   |        |       |       |       | 0                 | 0    | 0        | TBCCLK                |
|          |        |   |   |   |        |       |       |       | 0                 | 0    | 1        | 1/2 TBCCLK            |
|          |        |   |   |   |        |       |       |       | 0                 | 1    | 0        | 1/4 TBCCLK            |
|          |        |   |   |   |        |       |       |       | 0                 | 1    | 1        | 1/8 TBCCLK            |
|          |        |   |   |   |        |       |       |       | 1                 | 0    | 0        | 1/32 TBCCLK           |
|          |        |   |   |   |        |       |       |       | 1                 | 0    | 1        | 1/256 TBCCLK          |
|          |        |   |   |   |        |       |       |       | 1                 | 1    | 0        | TM1EVT (rising edge)  |
|          |        |   |   |   |        |       |       |       | 1                 | 1    | 1        | TM1EVT (falling edge) |
|          |        |   |   |   |        |       |       |       |                   | _    |          | hadi a a a Para       |
|          |        |   |   |   |        |       |       |       | 0                 |      | imer 1   | halt counting         |
|          |        |   |   |   |        |       |       |       | 1                 | Т    | imer 1   | start counting        |
|          |        |   |   |   |        |       |       |       |                   |      |          |                       |
|          |        |   |   |   |        |       |       |       | 0                 | L    | ow lev   | el output             |
|          |        |   |   |   |        |       |       |       | 1                 | Н    | ligh lev | el output             |

"—" indicates a nonexistent bit. When read, its value will be "1".

Figure 8-5 TM1CON Configuration

## (4) General-purpose 8-bit timer 2 control register (TM2CON)

The general-purpose 8-bit timer 2 control register (TM2CON) consists of 7 bits. TM2CON can be read from and written to by the program. However, write operation are invalid for bit 6. If read, a value of "1" will always be obtained for bit 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM2CON becomes 40H.

Figure 8-6 shows the TM2CON configuration.

#### [Description of each bit]

- TM2C0 to TM2C2 (bits 0 to 2)
   These bits specify the timer 2 count clock.
- TM2RUN (bit 3)
  This bit starts or stops the counting.
- MOD16 (bit 4)
  - Setting this bit combines timer 1 and 2 into the 16-bit auto-reload mode. While this bit is set, the settings of TM2C0 to TM2C2 and TM2RUN are invalid.
- MODPWM (bit 5)
   Setting this bit combines timer 1 and 2 into the PWM mode. While this bit is set, the setting of TM2RUN is invalid, and if TM1RUN is set, timer 1 and 2 will count simultaneously.
- TM2OUT (bit 7)
   This bit specifies the initial timer output level (High or Low) at start-up. The value of bit 7 (TM2OUT) is inverted whenever TM2C overflows.

| TM2CON   | 7<br>TM2OUT | 6 | 5<br>MODPWM N | 4<br>MOD16 T | 3<br>M2RUN | 2<br>TM2C2 | 1<br>TM2C1 | 0<br>TM2C0 | F |      | ddress    | s: 006D [H]<br>s: R/W |
|----------|-------------|---|---------------|--------------|------------|------------|------------|------------|---|------|-----------|-----------------------|
| At reset | 0           | 1 | 0             | 0            | 0          | 0          | 0          | 0          |   |      |           |                       |
|          |             |   |               |              |            |            |            |            | 2 | TM2C |           | Timer 2 count clock   |
|          |             |   |               |              |            |            |            |            | 0 | 0    | 0         | TBCCLK                |
|          |             |   |               |              |            |            |            |            | H | _    | _         |                       |
|          |             |   |               |              |            |            |            |            | 0 | 0    | 1         | 1/2 TBCCLK            |
|          |             |   |               |              |            |            |            |            | 0 | 1    | 0         | 1/4 TBCCLK            |
|          |             |   |               |              |            |            |            |            | 0 | 1    | 1         | 1/8 TBCCLK            |
|          |             |   |               |              |            |            |            |            | 1 | 0    | 0         | 1/32 TBCCLK           |
|          |             |   |               |              |            |            |            |            | 1 | 0    | 1         | 1/256 TBCCLK          |
|          |             |   |               |              |            |            |            |            | 1 | 1    | 0         | TM2EVT (rising edge)  |
|          |             |   |               |              |            |            |            |            | 1 | 1    | 1         | TM2EVT (falling edge) |
|          |             |   |               |              |            |            |            |            | 0 | _    | imar O    | halt accepting        |
|          |             |   |               |              |            |            |            |            |   |      |           | halt counting         |
|          |             |   |               |              |            |            |            |            | 1 | T    | imer 2    | start counting        |
|          |             |   |               |              |            |            |            |            | 0 | 8    | -bit auto | o-reload timer mode   |
|          |             |   |               |              |            |            |            |            | 1 | 1    | 6-bit au  | to-reload timer mode  |
|          |             |   |               |              |            |            |            |            |   |      |           |                       |
|          |             |   |               |              |            |            |            |            | 0 | Α    | uto-rel   | oad timer mode        |
|          |             |   |               |              |            |            |            |            | 1 | Р    | WM m      | ode                   |
|          |             |   |               |              |            |            |            |            |   |      |           |                       |
|          |             |   |               |              |            |            |            |            | 0 | L    | ow leve   | el output             |
|          |             |   |               |              |            |            |            |            | 1 | H    | ligh lev  | el output             |

Figure 8-6 TM2CON Configuration

"—" indicates a nonexistent bit. When read, its value will be "1".

### 8.5.3 Example of Timer 1- and 2-related Register Settings

#### • 8-bit auto-reload timer mode (Timer 1)

### (1) Port 6 mode register (P6IO)

If TM1OUT (timer output) is to be used, set bit 5 (P6IO5) to "1" to configure the port as an output. If TM1EVT (event input) is to be used, reset bit 4 (P6IO4) to "0" to configure the port as an input.

## (2) Port 6 secondary function control register (P6SF)

If TM1OUT (timer output) is to be used, set bit 5 (P6SF5) to "1" to configure the port as a secondary function output. If TM1EVT (event input) is to be used, disable or enable the pull-up resistor with bit 4 (P6SF4).

## (3) General-purpose 8-bit timer 1 counter (TM1C)

Set the timer value that will be valid at the start of counting. When writing to TM1C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 1 register (TM1R).

## (4) General-purpose 8-bit timer 1 register (TM1R)

This register sets the value to be loaded after general-purpose 8-bit timer 1 counter (TM1C) overflows. If the timer value (TM1C) and the reload value (TM1R) are identical, this register will automatically be set just by setting TM1C. If the values are different or are to be modified, this register must be set explicitly.

## (5) General-purpose 8-bit timer 1 control register (TM1CON)

Bits 9 to 0 (TM1C0 to TM1C2) of this register specify the count clock for timer 1. If TM1OUT (timer output) is to be used, specify the initial value with bit 7 (TM1OUT). If bit 3 (TM1RUN) is set to "1", timer 1 will begin counting. If reset to "0", timer 1 will halt counting.

#### • 8-bit auto-reload timer mode (Timer 2)

#### (1) Port 6 mode register (P6IO)

If TM2OUT (timer output) is to be used, set bit 7 (P6IO7) to "1" to configure the port as an output. If TM2EVT (event input) is to be used, reset bit 6 (P6IO6) to "0" to configure the port as an input.

## (2) Port 6 secondary function control register (P6SF)

If TM2OUT (timer output) is to be used, set bit 7 (P6SF7) to "1" to configure the port as a secondary function output. If TM2EVT (event input) is to be used, disable or enable the pull-up resistor with bit 6 (P6SF6).

#### (3) General-purpose 8-bit timer 2 counter (TM2C)

Set the timer value that will be valid at the start of counting. When writing to TM2C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 2 register (TM2R).

## (4) General-purpose 8-bit timer 2 register (TM2R)

This register sets the value to be loaded after general-purpose 8-bit timer 2 counter (TM2C) overflows. If the timer value (TM2C) and the reload value (TM2R) are identical, this register will automatically be set just by setting TM2C. If the values are different or are to be modified, this register must be set explicitly.

## (5) General-purpose 8-bit timer 2 control register (TM2CON)

Bits 0 to 2 (TM2C0 to TM2C2) of this register specify the count clock for timer 2. If TM2OUT (timer output) is to be used, specify the initial value with bit 7 (TM2OUT). If bit 3 (TM2RUN) is set to "1", timer 2 will begin counting. If reset to "0", timer 2 will halt counting.

#### • 16-bit auto-reload timer mode

## (1) Port 6 mode register (P6IO)

If TM1OUT (timer 1 output) and TM2OUT (timer 2 output) are to be used, set bits 5 and 7 (P6IO5, P6IO7) to "1" to configure the ports as outputs. If TM1EVT (event input) is to be used, reset bit 4 (P6IO4) to "0" to configure the port as an input.

## (2) Port 6 secondary function control register (P6SF)

If TM1OUT (timer 1 output) and TM2OUT (timer 2 output) are to be used, set bits 5 and 7 (P6SF5, P6SF7) to "1" to configure the ports as secondary function outputs. If TM1EVT (event input) is to be used, disable or enable the pull-up resistor with bit 4 (P6SF4).

## (3) General-purpose 16-bit timer 12 counter (TM12C)

Set the timer value that will be valid at the start of counting. When writing to TM12C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 12 register (TM12R).

## (4) General-purpose 16-bit timer 12 register (TM12R)

This register sets the value to be loaded after general-purpose 16-bit timer 12 counter (TM12C) overflows. If the timer value (TM12C) and the reload value (TM12R) are identical, this register will automatically be set just by setting TM12C. If the values are different or are to be modified, this register must be set explicitly.

## (5) General-purpose 8-bit timer 1 control register (TM1CON)

Bits 0 to 2 (TM1C0 to TM1C2) of this register specify the count clock for timer 1. If TM1OUT (timer 1 output) is to be used, specify the initial value with bit 7 (TM1OUT). If bit 3 (TM1RUN) is set to "1", timer 1 will begin counting. If reset to "0", timer 1 will halt counting.

## (6) General-purpose 8-bit timer 2 control register (TM2CON)

Setting bit 4 (MOD16) to "1" sets the 16-bit timer mode. While this bit is set, bits 0 to 2 (TM2C0 to TM2C2) and bit 3 (TM2RUN) settings are invalid and setting bit 3 (TM1RUN) of the timer 1 control register (TM1CON) to "1" starts simultaneous counting of timers 1 and 2. If TM2OUT (timer 2 output) is to be used, specify the initial value with bit 7 (TM2OUT).

#### PWM mode

### (1) Port 6 mode register (P6IO)

If TM1OUT (timer 1 output) and TM2OUT (timer 2 output) are to be used, set bits 5 and 7 (P6IO5, P6IO7) to "1" to configure the ports as outputs. If TM1EVT and TM2EVT (event inputs) are to be used, reset bit 4 and 6 (P6IO4, P6IO6) to "0" to configure the ports inputs.

## (2) Port 6 secondary function control register (P6SF)

If TM1OUT (timer 1 output) and TM2OUT (timer 2 output) are to be used, set bits 5 and 7 (P6SF5, P6SF7) to "1" to configure the ports as secondary function outputs. If TM1EVT and TM2EVT (event input) are to be used, disable or enable the pull-up resistor with bits 4 and 6 (P6SF4, P6SF6).

## (3) General-purpose 16-bit timer 12 counter (TM12C)

Set the timer value that will be valid at the start of counting. When writing to TM12C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 12 register (TM12R).

## (4) General-purpose 16-bit timer 12 register (TM12R)

This register sets the value to be loaded after general-purpose 16-bit timer 12 counter (TM12C) overflows. If the timer value (TM12C) and the reload value (TM12R) are identical, this register will automatically be set just by setting TM12C. If the values are different or are to be modified, this register must be set explicitly.

#### (5) General-purpose 8-bit timer 1 control register (TM1CON)

Bits 0 to 2 (TM1C0 to TM1C2) of this register specify the count clock for timer 1. If TM1OUT (timer 1 output) is to be used, specify the initial value with bit 7 (TM1OUT). If bit 3 (TM1RUN) is set to "1", timer 1 will begin counting. If reset to "0", timer 1 will halt counting.

## (6) General-purpose 8-bit timer 2 control register (TM2CON)

Setting bit 5 (MODPWM) to "1" sets the PWM mode. While this bit is set, bit 3 (TM2RUN) settings are invalid; setting bit 3 (TM1RUN) of the timer 1 control register (TM1CON) to "1", starts simultaneous counting of timers 1 and 2. If TM2OUT (timer 2 output) is to be used, specify the initial value with bit 7 (TM2OUT).

## 8.5.4 Timer 1 and 2 Operation

#### • 8-bit auto-reload timer mode

When the RUN bits corresponding to TM1 and TM2 are set to "1", timers 1 and 2 will begin counting upward, running on the count clocks selected by TM1CON and TM2CON. When TM1C and TM2C overflow, individual interrupt requests are generated, and the corresponding contents of TM1R and TM2R are loaded into TM1C and TM2C. In addition, the output of TM1OUT and TM2OUT is inverted. This operation is repeated until the RUN bits are reset to "0". Figure 8-7 shows an example of 8-bit auto-reload timer mode operation.



Figure 8-7 8-Bit Auto-Reload Timer Mode Operation Example

#### 16-bit auto-reload timer mode

Setting the MOD16 bit of TM2CON to "1" combines TM1 and TM2 to set the 16-bit autoreload timer mode. TM2C counts upward, using overflow of TM1C as the count clock. When TM2C overflows, a timer 2 interrupt request is generated, and the contents of TM1R and TM2R are loaded into TM1C and TM2C respectively. In addition, the output of TM2OUT is inverted.

During this mode, overflow of TM1C does not cause the contents of TM1R to be loaded. However, a timer 1 interrupt request will be generated and the output of TM1OUT will change.



Figure 8-8 16-Bit Auto-Reload Timer Mode Operation Example

#### PWM mode

Setting the MODPWM bit of TM2CON to "1" sets the PWM mode that uses TM1 and TM2. During the PWM mode, since the following operation is performed, use TM2C as the PWM cycle counter and TM1C as the duty control counter.

When TM1C overflows, an interrupt request is generated, and the PWM F/F is set. When TM2C overflows, an interrupt request is generated, the contents of TM1R and TM2R are loaded into TM1C and TM2C respectively, and the PWM F/F is reset. If "set" and "reset" of the PWM F/F are simultaneously generated, priority is given to the "reset".

The Q output (positive phase) of the PWM F/F is output from TM1OUT and the Q output of the PWM F/F (inverted phase) is output from TM2OUT.

Note that if the count clock selected for TM1C is faster than the TM2C count clock, interrupt requests due to TM1C overflow may occur two or more times in a single cycle.

Also note that if the count clock selected for TM1C is slower than the TM2C count clock, at the start of counting (when TM1RUN is set), and when TM2C overflows, a synchronous shift will occur, and the TM1C overflow cycle may shift. (The same count clocks are recommended.)



Figure 8-9 PWM Timer Mode Operation Example

## 8.5.5 Timer 1 and 2 Interrupts

## • Timer 1 interrupt

When a timer 1 interrupt factor occurs, the interrupt request flag (QTM1OV) is set to "1". The interrupt request flag (QTM1OV) is located in interrupt request register 1 (IRQ1).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM1OV). The interrupt enable flag (ETM1OV) is located in interrupt enable register 1 (IE1).

Three levels of priority can be set with the interrupt priority setting flags (P0TM1OV and P1TM1OV). The interrupt priority setting flags are located in interrupt priority control register 3 (IP3).

Table 8-4 lists the vector address and interrupt processing flags for the timer 1 interrupt factor.

**Table 8-4 Timer 1 Vector Address and Interrupt Processing Flags** 

| Interrupt factor                                | Vector address | Interrupt | Interrupt | Priority level |         |  |  |
|-------------------------------------------------|----------------|-----------|-----------|----------------|---------|--|--|
| interrupt factor                                | [H]            | request   | enable    | 1              | 0       |  |  |
| Overflow of timer 1                             | 0022           | QTM1OV    | ETM1OV    | P1TM1OV        | P0TM1OV |  |  |
| Symbols (byte) of registering interrupt process | IRQ1           | IE1       | IF        | 23             |         |  |  |
|                                                 | Reference page | 17-13     | 17-18     | 17-25          |         |  |  |

For farther details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

## • Timer 2 interrupt

When a timer 2 interrupt factor occurs, the interrupt request flag (QTM2OV) is set to "1". The interrupt request flag (QTM2OV) is located in interrupt reguest register 1 (IRQ1).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM2OV). The interrupt enable flag (ETM2OV) is located in interrupt enable register 1 (IE1).

Three levels of priority can be set with the interrupt priority setting flags (P0TM2OV and P1TM2OV). The interrupt priority setting flags are located in interrupt priority control register 3 (IP3).

Table 8-5 lists the vector address and interrupt processing flags for the timer 2 interrupt factor.

**Table 8-5 Timer 2 Vector Address and Interrupt Processing Flags** 

| Interrupt factor                                | Vector address | Interrupt | Interrupt | Priority level |         |  |  |
|-------------------------------------------------|----------------|-----------|-----------|----------------|---------|--|--|
| interrupt factor                                | [H]            | request   | enable    | 1              | 0       |  |  |
| Overflow of timer 2                             | 0024           | QTM2OV    | ETM2OV    | P1TM2OV        | P0TM2OV |  |  |
| Symbols (byte) of registering interrupt process | IRQ1           | IE1       | IF        | 23             |         |  |  |
|                                                 | 17-13          | 17-18     | 17-25     |                |         |  |  |

For farther details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 8.6 Timer 3

Timer 3 is an 8-bit auto-reload timer that has a baud rate generator function for SIO6. TM3OUT is not output on ports, but can be used by software as a flag.

# 8.6.1 Timer 3 Configuration

Figure 8-10 shows the timer 3 configuration.



TM3C: General-purpose 8-bit timer 3 counter TM3R: General-purpose 8-bit timer 3 register

TM3CON: General-purpose 8-bit timer 3 control register

Figure 8-10 Timer 3 Configuration

## 8.6.2 Description of Timer 3 Registers

### (1) General-purpose 8-bit timer 3 counter (TM3C)

The general-purpose 8-bit timer 3 counter (TM3C) is an 8-bit up-counter. When this counter overflows, an interrupt request is generated and it is loaded with the contents of general-purpose 8-bit timer 3 register (TM3R). TM3C can also be used as a baud rate generator for SIO6.

TM3C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM3C are undefined.

## [Note]

Writing a timer value to TM3C causes the same value to also be written to the general-purpose 8-bit timer 3 register (TM3R).

## (2) General-purpose 8-bit timer 3 register (TM3R)

The general-purpose 8-bit timer 3 register (TM3R) consists of 8 bits. This register stores the value to be reloaded into the general-purpose 8-bit timer 3 counter (TM3C).

TM3R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM3R are undefined.

## (3) General-purpose 8-bit timer 3 control register (TM3CON)

The general-purpose 8-bit timer 3 control register (TM3CON) consists of 5 bits. Bits 0 to 2 (TM3C0 to TM3C2) of TM3CON select the timer 3 count clock, bit 3 (TM3RUN) starts or halts the counting, and bit 7 (TM3OUT) specifies the initial timer output level (High or Low) at start-up. And each time TM3C overflows, the content of bit 7 (TM3OUT) is reversed.

TM3CON can be read from and written to by the program. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bits 4 to 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM3CON becomes 70H.

Figure 8-11 shows the TM3CON configuration.

#### [Note]

<u>Just before TM3C overflows</u>, if an SB, RB, XORB or other read-modify-write instruction is performed on TM3CON, then TM3OUT may not operate correctly.

|          | 7      | 6 | 5 | 4 | 3      | 2     | 1     | 0     | _ | Address: 0072 [H] |       |                           |  |  |  |
|----------|--------|---|---|---|--------|-------|-------|-------|---|-------------------|-------|---------------------------|--|--|--|
| TM3CON   | TM3OUT | _ | _ | _ | TM3RUN | TM3C2 | TM3C1 | ТМЗСО |   |                   |       | ess: 0072 [H]<br>ess: R/W |  |  |  |
| At reset | 0      | 1 | 1 | 1 | 0      | 0     | 0     | 0     |   | - 40              |       |                           |  |  |  |
|          |        |   |   |   |        |       |       |       | _ | M3                |       | Timer 3 count clock       |  |  |  |
|          |        |   |   |   |        |       |       |       | 2 | 1                 | 0     |                           |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 | 0                 | 0     | TBCCLK                    |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 | 0                 | 1     | 1/2 TBCCLK                |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 | 1                 | 0     | 1/4 TBCCLK                |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 | 1                 | 1     | 1/8 TBCCLK                |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | 0                 | 0     | 1/32 TBCCLK               |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | 0                 | 1     | 1/256 TBCCLK              |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | 1                 | 0     | Prohibited setting        |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | 1                 | 1     | Prohibited setting        |  |  |  |
|          |        |   |   |   |        |       |       |       |   | _                 |       | O beath a south as        |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 | -                 |       | 3 halt counting           |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | l I               | mer   | 3 start counting          |  |  |  |
|          |        |   |   |   |        |       |       |       | 0 |                   | ا بده | lavel cutaut              |  |  |  |
|          |        |   |   |   |        |       |       |       | _ |                   |       | level output              |  |  |  |
|          |        |   |   |   |        |       |       |       | 1 | Н                 | ligh  | level output              |  |  |  |
|          |        |   |   |   |        |       |       |       | " | ' ind             | licat | es a nonexistent bit.     |  |  |  |

When read, its value will be "1."

Figure 8-11 TM3CON Configuration

# [Note]

Do not select a timer 3 count clock setting that is prohibited. If a "prohibited setting" is selected, timer 3 will not operate properly.

### 8.6.3 Example of Timer 3-related Register Settings

## (1) General-purpose 8-bit timer 3 counter (TM3C)

Set the timer value that will be valid at the start of counting. When writing to TM3C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 3 register (TM3R).

## (2) General-purpose 8-bit timer 3 register (TM3R)

This register sets the value to be loaded after general-purpose 8-bit timer 3 counter (TM3C) overflows. If the timer value (TM3C) and the reload value (TM3R) are identical, this register will automatically be set just by setting TM3C. If the values are different or are to be modified, this register must be set explicitly.

## (3) General-purpose 8-bit timer 3 control register (TM3CON)

Bits 0 to 2 (TM3C0 to TM3C2) of this register specify the count clock for timer 3. If TM3OUT (timer output) is to be used, specify the initial value with bit 7 (TM3OUT). If bit 3 (TM3RUN) is set to "1", timer 3 will begin counting. If reset to "0", timer 3 will halt counting.

### 8.6.4 Timer 3 Operation

When the TM3RUN bit is set to "1", timer 3 will begin counting upward, running on the count clock selected by TM3CON. When TM3C overflows, an interrupt request is generated, the contents of TM3R are loaded into TM3C and the TM3OUT output is inverted. The initial value of the TM3OUT pin is specified by bit 7 (TM3OUT) of TM3CON. This operation is repeated until the TM3RUN bit is reset to "0". Overflow of TM3C can be used as a baud rate generator for SIO6. Figure 8-12 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/4 TBCCLK).



Figure 8-12 Timer 3 Operation Example

### 8.6.5 Timer 3 Interrupt

When a timer 3 interrupt factor occurs, the interrupt request flag (QTM3OV) is set to "1". The interrupt request flag (QTM3OV) is located in interrupt request register 1 (IRQ1).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM0OV). The interrupt enable flag (ETM3OV) is located in interrupt enable register 1 (IE1).

Three levels of priority can be set with the interrupt priority setting flags (P0TM3OV and P1TM3OV). The interrupt priority setting flags are located in interrupt priority control register 3 (IP3).

Table 8-6 lists the vector address of the timer 3 interrupt factor and the interrupt processing flags.

**Table 8-6 Timer 3 Vector Address and Interrupt Processing Flags** 

| Interview footor        | Vector         | Interrupt | Interrupt | Priority level |         |  |
|-------------------------|----------------|-----------|-----------|----------------|---------|--|
| Interrupt factor        | address [H]    | request   | enable    | 1              | 0       |  |
| Overflow of timer 3     | 0026           | QTM3OV    | ETM3OV    | P1TM3OV        | P0TM3OV |  |
| Symbols (byte) of reg   | isters that    | IRQ1      | IE1       | IP3            |         |  |
| contain interrupt proce | INQI           | IEI       | 15        | 3              |         |  |
|                         | Reference page | 17-13     | 17-18     | 17-            | ·25     |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 8

#### 8.7 Timer 4

Timer 4 is an 8-bit auto-reload timer that has functions for timer output and a baud rate generator for SIO1.

## 8.7.1 Timer 4 Configuration

Figure 8-13 shows the timer 4 configuration.



TM4C: General-purpose 8-bit timer 4 counter TM4R: General-purpose 8-bit timer 4 register

TM4CON: General-purpose 8-bit timer 4 control register

TM4OUT: Timer 4 output pin (P8\_4)

Figure 8-13 Timer 4 Configuration

## 8.7.2 Description of Timer 4 Registers

### (1) General-purpose 8-bit timer 4 counter (TM4C)

The general-purpose 8-bit timer 4 counter (TM4C) is an 8-bit up-counter. When this counter overflows, an interrupt request is generated and it is loaded with the contents of general-purpose 8-bit timer 4 register (TM4R). TM4C can also be used as a baud rate generator for SIO1.

TM4C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM4C are undefined.

## [Note]

Writing a timer value to TM4C causes the same value to also be written to the general-purpose 8-bit timer 4 register (TM4R).

## (2) General-purpose 8-bit timer 4 register (TM4R)

The general-purpose 8-bit timer 4 register (TM4R) consists of 8 bits. This register stores the value to be reloaded into the general-purpose 8-bit timer 4 counter (TM4C).

TM4R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM4R are undefined.

## (3) General-purpose 8-bit timer 4 control register (TM4CON)

The general-purpose 8-bit timer 4 control register (TM4CON) consists of 5 bits. Bits 0 to 2 (TM4C0 to TM4C2) of TM4CON select the timer 4 count clock, bit 3 (TM4RUN) starts or halts the counting, and bit 7 (TM4OUT) specifies the initial timer output level (High or Low) at start-up. And each time TM4C overflows, the content of bit 7 (TM4OUT) is reversed.

TM4CON can be read from and written to by the program. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bits 4 to 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM4CON becomes 70H.

Figure 8-14 shows the TM4CON configuration.

#### [Note]

<u>Just before TM4C overflows</u>, if an SB, RB, XORB or other read-modify-write instruction is performed on TM4CON, then TM4OUT may not operate correctly.



Figure 8-14 TM4CON Configuration

## [Note]

Do not select a timer 4 count clock setting that is prohibited. If a "prohibited setting" is selected, timer 4 will not operate properly.

### 8.7.3 Example of Timer 4-related Register Settings

### (1) Port 8 mode register (P8IO)

If TM4OUT (timer output) is to be used, set bit 4 (P8IO4) to "1" to configure the port as an output.

## (2) Port 8 secondary function control register (P8SF)

If TM4OUT (timer output) is to be used, set bit 4 (P8SF4) to "1" to configure the port as a secondary function output.

### (3) General-purpose 8-bit timer 4 counter (TM4C)

Set the timer value that will be valid at the start of counting. When writing to TM4C, the same value will also be written simultaneously and automatically to the general-purpose 8-bit timer 4 register (TM4R).

#### (4) General-purpose 8-bit timer 4 register (TM4R)

This register sets the value to be loaded after general-purpose 8-bit timer 4 counter (TM4C) overflows. If the timer value (TM4C) and the reload value (TM4R) are identical, this register will automatically be set just by setting TM4C. If the values are different or are to be modified, this register must be set explicitly.

#### (5) General-purpose 8-bit timer 4 control register (TM4CON)

Bits 0 to 2 (TM4C0 to TM4C2) of this register specify the count clock for timer 4. If TM4OUT (timer output) is to be used, specify the initial value with bit 7 (TM4OUT). If bit 3 (TM4RUN) is set to "1", timer 4 will begin counting. If reset to "0", timer 4 will halt counting.

## 8.7.4 Timer 4 Operation

When the TM4RUN bit is set to "1", timer 4 will begin counting upward, running on the count clock selected by TM4CON. When TM4C overflows, an interrupt request is generated, the contents of TM4R are loaded into TM4C and the TM4OUT output is inverted. The initial value of the TM4OUT pin is specified by bit 7 (TM4OUT) of TM4CON. This operation is repeated until the TM4RUN bit is reset to "0". Overflow of TM4C can be used as a baud rate generator for SIO1. Figure 8-15 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/4 TBCCLK).



Figure 8-15 Timer 4 Operation Example

### 8.7.5 Timer 4 Interrupt

When a timer 4 interrupt factor occurs, the interrupt request flag (QTM4OV) is set to "1". The interrupt request flag (QTM4OV) is located in interrupt request register 2 (IRQ2).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM4OV). The interrupt enable flag (ETM4OV) is located in interrupt enable register 2 (IE2).

Three levels of priority can be set with the interrupt priority setting flags (P0TM4OV and P1TM4OV). The interrupt priority setting flags are located in interrupt priority control register 5 (IP5).

Table 8-7 lists the vector address of the timer 4 interrupt factor and the interrupt processing flags.

Table 8-7 Timer 4 Vector Address and Interrupt Processing Flags

| Interrupt factor        | Vector         | Interrupt | Interrupt | Priority level |         |  |
|-------------------------|----------------|-----------|-----------|----------------|---------|--|
| Interrupt factor        | address [H]    | request   | enable    | 1              | 0       |  |
| Overflow of timer 4     | 0036           | QTM4OV    | ETM4OV    | P1TM4OV        | P0TM4OV |  |
| Symbols (byte) of reg   | isters that    | IDOO      | IE2       | IDC            |         |  |
| contain interrupt proce | IRQ2           | IE2       | IP5       |                |         |  |
|                         | Reference page | 17-14     | 17-19     | 17-            | -27     |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 8.8 Timer 5

Timer 5 is an 8-bit auto-reload timer that has a baud rate generator function for SIO4 and 5. TM5OUT is not output on ports, but can be used by software as a flag.

# 8.8.1 Timer 5 Configuration

Figure 8-16 shows the timer 5 configuration.



TM5C: General-purpose 8-bit timer 5 counter TM5R: General-purpose 8-bit timer 5 register

TM5CON: General-purpose 8-bit timer 5 control register

Figure 8-16 Timer 5 Configuration

### 8.8.2 Description of Timer 5 Registers

### (1) General-purpose 8-bit timer 5 counter (TM5C)

The general-purpose 8-bit timer 5 counter (TM5C) is an 8-bit up-counter. When this counter overflows, an interrupt request is generated and it is loaded with the contents of general-purpose 8-bit timer 5 register (TM5R). TM5C can also be used as a baud rate generator for SIO4 and 5.

TM5C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), contents of TM5C are undefined.

## [Note]

Writing a timer value to TM5C causes the same value to also be written to the general-purpose 8-bit timer 5 register (TM5R).

## (2) General-purpose 8-bit timer 5 register (TM5R)

The general-purpose 8-bit timer 5 register (TM5R) consists of 8 bits. This register stores the value to be reloaded into the general-purpose 8-bit timer 5 counter (TM5C).

TM5R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM5R are undefined.

## (3) General-purpose 8-bit timer 5 control register (TM5CON)

The general-purpose 8-bit timer 5 control register (TM5CON) consists of 5 bits. Bits 0 to 2 (TM5C0 to TM5C2) of TM5CON select the timer 5 count clock and bit 3 (TM5RUN) starts or halts the counting. Specify the initial timer output level (High or Low) at start-up with bit 7 (TM5OUT). The contents of bit 7 (TM5OUT) are reversed each time TM5C overflows.

TM5CON can be read from and written to by the program. However, write operations are invalid for the upper 4 bits. If read, a value of "1" will always be obtained for bits 4 to 6. The value read from bit 7 is undefined.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM5CON are undefined.

Figure 8-17 shows the TM5CON configuration.

|          | 7      | 6 | 5 | 4 | 3      | 2     | 1     | 0     |                       | Address: 007A [H] |      |                           |  |  |
|----------|--------|---|---|---|--------|-------|-------|-------|-----------------------|-------------------|------|---------------------------|--|--|
| TM5CON   | TM5OUT | _ | _ | _ | TM5RUN | TM5C2 | TM5C1 | TM5C0 | F                     |                   |      | ess: 007A [H]<br>ess: R/W |  |  |
| At reset | 0      | 1 | 1 | 1 | 0      | 0     | 0     | 0     | _                     | T1450             |      |                           |  |  |
|          |        |   |   |   |        |       |       |       |                       | M50               | -    | Timer 5 count clock       |  |  |
|          |        |   |   |   |        |       |       |       | 2                     | 1                 | 0    |                           |  |  |
|          |        |   |   |   |        |       |       |       | 0                     | 0                 | 0    | TBCCLK                    |  |  |
|          |        |   |   |   |        |       |       |       | 0                     | 0                 | 1    | 1/2 TBCCLK                |  |  |
|          |        |   |   |   |        |       |       |       | 0                     | 1                 | 0    | 1/4 TBCCLK                |  |  |
|          |        |   |   |   |        |       |       |       | 0                     | 1                 | 1    | 1/8 TBCCLK                |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | 0                 | 0    | 1/32 TBCCLK               |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | 0                 | 1    | 1/256 TBCCLK              |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | 1                 | 0    | Prohibited setting        |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | 1                 | 1    | Prohibited setting        |  |  |
|          |        |   |   |   |        |       |       | 0     | Timer 5 halt counting |                   |      |                           |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | Т                 | ïme  | r 5 start counting        |  |  |
|          |        |   |   |   |        |       |       |       |                       |                   |      |                           |  |  |
|          |        |   |   |   |        |       |       |       | 0                     | L                 | ow l | level                     |  |  |
|          |        |   |   |   |        |       |       |       | 1                     | F                 | ligh | Level                     |  |  |
|          |        |   |   |   |        |       |       |       |                       |                   |      |                           |  |  |

<sup>&</sup>quot;—" indicates a nonexistent bit. When read, its value will be "1."

Figure 8-17 TM5CON Configuration

# [Note]

Do not select a timer 5 count clock setting that is prohibited. If a "prohibited setting" is selected, timer 5 will not operate properly.

### 8.8.3 Example of Timer 5-related Register Settings

## (1) General-purpose 8-bit timer 5 counter (TM5C)

Set the timer value that will be valid at the start of counting. When writing to TM5C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 5 register (TM5R).

## (2) General-purpose 8-bit timer 5 register (TM5R)

This register sets the value to be loaded after general-purpose 8-bit timer 5 counter (TM5C) overflows. If the timer value (TM5C) and the reload value (TM5R) are identical, this register will automatically be set just by setting TM5C. If the values are different or are to be modified, this register must be set explicitly.

## (3) General-purpose 8-bit timer 5 control register (TM5CON)

Bits 0 to 2 (TM5C0 to TM5C2) of this register specify the count clock for timer 5. If TM5OUT (timer output) is used, specify the initial value with bit 7 (TM5OUT). If bit 3 (TM5RUN) is set to "1", timer 5 will begin counting. If reset to "0", timer 5 will halt counting.

## 8.8.4 Timer 5 Operation

When the TM5RUN bit is set to "1", timer 5 will begin counting upward, running on the count clock selected by TM5CON. When TM5C overflows, an interrupt request is generated and the contents of TM5R are loaded into TM5C. This operation is repeated until the TM5RUN bit is reset to "0". Overflow of TM5C can be used as a baud rate generator for SIO4 and 5. Figure 8-18 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/4 TBCCLK).



Figure 8-18 Timer 5 Operation Example

### 8.8.5 Timer 5 Interrupt

When a timer 5 interrupt factor occurs, the interrupt request flag (QTM5OV) is set to "1". The interrupt request flag (QTM5OV) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM5OV). The interrupt enable flag (ETM5OV) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0TM5OV and P1TM5OV). The interrupt priority setting flags are located in interrupt priority control register 6 (IP6).

Table 8-8 lists the vector address of the timer 5 interrupt factor and the interrupt processing flags.

**Table 8-8 Timer 5 Vector Address and Interrupt Processing Flags** 

| Intervient factor       | Vector         | Interrupt | Interrupt | Priority level |         |  |
|-------------------------|----------------|-----------|-----------|----------------|---------|--|
| Interrupt factor        | address [H]    | request   | enable    | 1              | 0       |  |
| Overflow of timer 5     | 003A           | QTM5OV    | ETM5OV    | P1TM5OV        | P0TM5OV |  |
| Symbols (byte) of reg   | isters that    | IDO2      | IE3       | IDC            |         |  |
| contain interrupt proce | IRQ3           | IES       | IP6       |                |         |  |
|                         | Reference page | 17-15     | 17-20     | 17-            | -28     |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 8.9 Timer 6

Timer 6 is an 8-bit auto-reload timer that has two operating modes, auto-reload timer mode and watchdog timer (WDT) mode. If the counter overflows during the WDT mode, the system will be reset.

## 8.9.1 Timer 6 Configuration

Figure 8-19 shows the timer 5 configuration.



TM6C: General-purpose 8-bit timer 6 counter TM6R: General-purpose 8-bit timer 6 register

TM6CON: General-purpose 8-bit timer 6 control register

MODWDT: WDT mode setting signal

Figure 8-19 Timer 6 Configuration

### 8.9.2 Description of Timer 6 Registers

## (1) General-purpose 8-bit timer 6 counter (TM6C)

The general-purpose 8-bit timer 6 counter (TM6C) is an 8-bit up-counter.

 During auto-reload timer mode
 When an interrupt request is generated due to overflow of the counter, the contents of general-purpose 8-bit timer 6 register (TM6R) are loaded into TM6C.

## • During WDT mode

Counter overflow causes the system to be reset. When starting or initializing WDT, a special write operation to TM6C is necessary (so that WDT will not be easily initialized by an out-of-control program). The count value can be read during WDT operation, but once WDT is started, it is not possible to write to TM6C.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), the contents of TM6C are undefined.

## [Note]

Writing a timer value to TM6C causes the same value to be also written to general-purpose 8-bit timer 6 register (TM6R).

## (2) General-purpose 8-bit timer 6 register (TM6R)

The general-purpose 8-bit timer 6 register (TM6R) consists of 8 bits. This register stores the value to be reloaded into the general-purpose 8-bit timer 6 counter (TM6C).

During the auto-reload timer mode, the program can read from and write to TM6R. During the WDT mode, TM6R is read-only.

At reset (due to a RES input, BRK instruction execution, watchdog timer overflow, or opcode trap), the contents of TM6R are undefined.

### (3) General-purpose 8-bit timer 6 control register (TM6CON)

The general-purpose 8-bit timer 6 control register (TM6CON) consists of 7 bits.

During the auto-reload timer mode, the program can read from and write to TM6CON. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bit 4.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM6CON becomes 10H.

Figure 8-20 shows the TM6CON configuration.

#### [Description of each bit]

WDTC0 to WDTC2 (bits 0 to 2)
 WDTC0 to WDTC2 specify the count clock for timer 6.

#### • ATMRUN (bit 3)

During the auto-reload timer mode, ATMRUN specifies whether the count is running or halted.

During the WDT mode, the value that has been written will be read.

#### • WDTRUN (bit 5)

This read-only flag is read as "1" during counting in the WDT mode. With this flag, it is possible to determine whether the count operation in the WDT mode has started.

### • WDTLDE (bit 6)

During the WDT mode, WDT is initialized within a fixed period by loading the value of TM6R into TM6C. This load operation (WDT initialization) is performed by alternately writing "n3H" and "nCH" (where n is an arbitrary value from 0 to F) to TM6C.

WDTLDE is a read-only flag used during initialization to determine whether the next value to be written to TM6C will be "n3H" or "nCH".

### • MODWDT (bit 7)

This bit specifies the timer 6 operating mode (auto-reload timer mode or WDT mode).

#### [Note]

Before setting MODWDT to "1" to enter the WDT mode, set the WDT overflow period with TM6C, TM6R and TM6CON (WDTC0 to WDTC2). It is not possible to modify the period once MODWDT is set to "1" and the WDT mode is entered. (Writes become invalid).

Since MODWDT is located within TM6CON, byte instructions can be used to simultaneously write to MODWDT and WDTC0 through WDTC2.



Figure 8-20 TM6CON Configuration

# 8.9.3 Example of Timer 6-related Register Settings

#### Auto-reload timer mode settings

## (1) General-purpose 8-bit timer 6 counter (TM6C)

Set the timer value that will be valid at the start of counting. When writing to TM6C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 6 register (TM6R).

### (2) General-purpose 8-bit timer 6 register (TM6R)

This register sets the value to be loaded after general-purpose 8-bit timer 6 counter (TM6C) overflows. If the timer value (TM6C) and the reload value (TM6R) are identical, this register will automatically be set just by setting TM6C. If the values are different or are to be modified, this register must be set explicitly.

## (3) General-purpose 8-bit timer 6 control register (TM6CON)

Bits 0 to 2 (WDTC0 to WDTC2) of this register specify the count clock for timer 6. If bit 3 (ATMRUN) is set to "1", timer 6 will begin counting. If reset to "0", timer 6 will halt counting.

#### Watchdog timer (WDT) mode settings

#### (1) General-purpose 8-bit timer 6 register (TM6R)

This register sets the value to be loaded into general-purpose 8-bit timer 6 counter (TM6C).

#### (2) General-purpose 8-bit timer 6 control register (TM6CON)

- (i) Specify the count clock for timer 6 with bits 0 to 2 (WDTC0 to WDTC2) of this register.
- (ii) Set bit 7 (MODWDT) to "1" to enter the WDT mode.

(Settings (i) and (ii) can be performed simultaneously by using a byte instruction such as MOVB.)

## (3) General-purpose 8-bit timer 6 counter (TM6C)

Write the WDT activation code, "n3H", to start WDT counting.

(At this time, the contents of TM6C are not modified. "n3H" is only used to activate WDT.)

Thereafter, WDT is initialized by alternately writing "nCH" and "n3H" before overflow. WDTLDE (bit 6) of TM6CON can be read to determine whether the value to be written for the next initialization is "nCH" or "n3H". "WDT initialization" is defined as loading the value of TM6R into TM6C. (n is an arbitrary value from 0 to F.)

#### 8.9.4 Timer 6 Operation

#### · Auto-reload timer mode

When the MODWDT bit in TM6CON is reset to "0", the mode changes to the auto-reload timer mode. If the ATMRUN bit is set to "1", timer 6 will begin counting upward, running on the count clock selected by TM6CON. When TM6C overflows, an interrupt request is generated and the contents of TM6R are loaded into TM6C. This operation is repeated until the ATMRUN bit is reset to "0". Figure 8-21 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/8 TBCCLK).



Figure 8-21 Timer 6 Operation (During Auto-Reload Timer Mode)

#### Watchdog timer (WDT) mode

When the MODWDT bit in TM6CON is set to "1", the mode changes to the WDT mode. Once the WDT mode is set, it is not possible to return to the auto-reload timer mode until the system is reset. In the WDT mode, writing "n3H" to TM6C will cause the WDT count operation to begin. Thereafter, alternately writing "nCH" and "n3H" by the program will cause the contents of TM6R to be loaded into TM6C and initialize WDT.

If WDT initialization is not implemented within the fixed amount of time set by the count clock and the reload value, then TM6C will overflow and the system will be reset. To process a system reset, the branch address (2 bytes) stored in addresses 0004 to 0005 (vector address for reset by WDT) is loaded into the program counter.

The time (tWDT) until TM6C overflows can be expressed by the below equation, where f [MHz] is the fundamental clock (CPUCLK), T is the TM6C count clock (divided value of TBCCLK), n is the divisor for the 1/n counter at the TBC front stage, and R is the value of TM6R.

$$t_{WDT} = (1/f) \times T \times n \times (256 - R)$$
 [µs] (R: 0 to 255)

Figure 8-22 shows timing diagrams of an out-of-control program and detection by WDT. Figure 8-23 shows an example of an out-of-control program.





Figure 8-22 Timing Diagram of Out-of-Control Program Detection



Figure 8-23 Example of Out-of-Control Program Detection

# 8.9.5 Timer 6 Interrupt (During Auto-Reload Timer Mode)

When a timer 6 interrupt factor occurs (during the auto-reload timer mode), the interrupt request flag (QTM6OV) is set to "1". The interrupt request flag (QTM6OV) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM6OV). The interrupt enable flag (ETM6OV) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0TM6OV and P1TM6OV). The interrupt priority setting flags are located in interrupt priority control register 7 (IP7).

Table 8-9 lists the vector address of the timer 6 interrupt factor and the interrupt processing flags.

**Table 8-9 Timer 6 Vector Address and Interrupt Processing Flags** 

| Interrupt factor                   | Vector         | Interrupt | Interrupt | Priority level |         |  |
|------------------------------------|----------------|-----------|-----------|----------------|---------|--|
| interrupt factor                   | address [H]    | request   | enable    | 1              | 0       |  |
| Overflow of timer 6                | 0042           | QTM6OV    | ETM6OV    | P1TM6OV        | P0TM6OV |  |
| Symbols (byte) of reg              | IDO2           | IE3       | IP7       |                |         |  |
| contain interrupt processing flags |                | IRQ3      |           |                | IES     |  |
|                                    | Reference page | 17-15     | 17-20     | 17-            | -29     |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 8.10 Timer 9

Timer 9 is an 8-bit auto-reload timer that has the function for clock output for PWM. TM9OUT is not output on ports, but can be used by software as a flag.

# 8.10.1 Timer 9 Configuration

Figure 8-24 shows the timer 9 configuration.



TM9C: General-purpose 8-bit timer 9 counter TM9R: General-purpose 8-bit timer 9 register

TM9CON: General-purpose 8-bit timer 9 control register

Figure 8-24 Timer 9 Configuration

# 8.10.2 Description of Timer 9 Registers

# (1) General-purpose 8-bit timer 9 counter (TM9C)

The general-purpose 8-bit timer 9 counter (TM9C) is an 8-bit up-counter. When this counter overflows, an interrupt request is generated and it is loaded with the contents of general-purpose 8-bit timer 9 register (TM9R). This counter can also be used as a clock for PWM.

TM9C can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM9C are undefined.

#### [Note]

Writing a timer value to TM9C causes the same value to also be written to the general-purpose 8-bit timer 9 register (TM9R).

#### (2) General-purpose 8-bit timer 9 register (TM9R)

The general-purpose 8-bit timer 9 register (TM9R) consists of 8 bits. This register stores the value to be reloaded into the general-purpose 8-bit timer 9 counter (TM9C).

TM9R can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of TM9R are undefined.

#### (3) General-purpose 8-bit timer 9 control register (TM9CON)

The general-purpose 8-bit timer 9 control register (TM9CON) consists of 5 bits. Bits 0 to 2 (TM9C0 to TM9C2) of TM9CON select the timer 9 count clock, bit 3 (TM9RUN) specifies starting or halting the counting, and bit 7 (TM9OUT) specifies the initial timer output level (High or Low) at start-up. And each time TM0C overflows, the content of bit 7 (TM9OUT) is reversed.

TM9CON can be read from and written to by the program. However, write operations are invalid for bits 4 to 6. If read, a value of "1" will always be obtained for bits 4 to 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), TM9CON becomes 70H.

Figure 8-25 shows the TM9CON configuration.

#### [Note]

<u>Just before TM9C overflows</u>, if an SB, RB, XORB or other read-modify-write instruction is performed on TM9CON, then TM9OUT may not operate correctly.

| TM9CON   | 7<br>TM9OUT | 6 | 5<br>— | 4 | 3<br>TM9RUN | 2<br>TM9C2 | 1<br>TM9C1 | 0<br>TM9C0 | F |     |      | ess: 00CE [H]<br>ess: R/W                       |
|----------|-------------|---|--------|---|-------------|------------|------------|------------|---|-----|------|-------------------------------------------------|
| At reset | 0           | 1 | 1      | 1 | 0           | 0          | 0          | 0          | П | M90 | 0    |                                                 |
|          |             |   |        |   |             |            |            |            | 2 | 1   | 0    | Timer 9 count clock                             |
|          |             |   |        |   |             |            |            |            | 0 | 0   | 0    | TBCCLK                                          |
|          |             |   |        |   |             |            |            |            | 0 | 0   | 1    | 1/2 TBCCLK                                      |
|          |             |   |        |   |             |            |            |            | 0 | 1   | 0    | 1/4 TBCCLK                                      |
|          |             |   |        |   |             |            |            |            | 0 | 1   | 1    | 1/8 TBCCLK                                      |
|          |             |   |        |   |             |            |            |            | 1 | 0   | 0    | 1/32 TBCCLK                                     |
|          |             |   |        |   |             |            |            |            | 1 | 0   | 1    | 1/256 TBCCLK                                    |
|          |             |   |        |   |             |            |            |            | 1 | 1   | 0    | Prohibited setting                              |
|          |             |   |        |   |             |            |            |            | 1 | 1   | 1    | Prohibited setting                              |
|          |             |   |        |   |             |            |            |            | 0 | Т   | imer | 9 halt counting                                 |
|          |             |   |        |   |             |            |            |            | 1 | Т   | ime  | 9 start counting                                |
|          |             |   |        |   |             |            |            |            | 0 |     |      | level output                                    |
|          |             |   |        |   |             |            |            |            | 1 |     |      | level output                                    |
|          |             |   |        |   |             |            |            |            |   |     |      | •                                               |
|          |             |   |        |   |             |            |            |            |   |     |      | es a nonexistent bit.<br>its value will be "1." |

Figure 8-25 TM9CON Configuration

# [Note]

Do not select a timer 9 count clock setting that is prohibited. If a "prohibited setting" is selected, timer 9 will not operate properly.

# 8.10.3 Example of Timer 9-related Register Settings

# (1) General-purpose 8-bit timer 9 counter (TM9C)

Set the timer value that will be valid at the start of counting. When writing to TM9C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 9 register (TM9R).

# (2) General-purpose 8-bit timer 9 register (TM9R)

This register sets the value to be loaded after general-purpose 8-bit timer 9 counter (TM9C) overflows. If the timer value (TM9C) and the reload value (TM9R) are identical, this register will automatically be set just by setting TM9C. If the values are different or are to be modified, this register must be set explicitly.

# (3) General-purpose 8-bit timer 9 control register (TM9CON)

Bits 0 to 2 (TM9C0 to TM9C2) of this register specify the count clock for timer 9. If TM9OUT (timer output) is to be used, specify the initial value with bit 7 (TM9OUT). If bit 3 (TM9RUN) is set to "1", timer 9 will begin counting. If reset to "0", timer 9 will halt counting.

# 8.10.4 Timer 9 Operation

When the TM9RUN bit is set to "1", timer 9 will begin counting upward, running on the count clock selected by TM9CON. When TM9C overflows, an interrupt request is generated, the contents of TM9R are loaded into TM9C and the TM9OUT output is inverted. The initial value of the TM9OUT pin is specified by bit 7 (TM9OUT) of TM9CON. This operation is repeated until the TM9RUN bit is reset to "0". Overflow of TM9C can be used as the clock output for PWM. Figure 8-26 shows an operation example (for settings of 1/n counter frequency division ratio 1/1 and 1/4 TBCCLK).



Figure 8-26 Timer 9 Operation Example

# 8.10.5 Timer 9 Interrupt

When a timer 9 interrupt factor occurs, the interrupt request flag (QTM9OV) is set to "1". The interrupt request flag (QTM9OV) is located in interrupt request register 4 (IRQ4).

Interrupts can be enabled or disabled by the interrupt enable flag (ETM9OV). The interrupt enable flag (ETM9OV) is located in interrupt enable register 4 (IE4).

Three levels of priority can be set with the interrupt priority setting flags (P0TM9OV and P1TM9OV). The interrupt priority setting flags are located in interrupt priority control register 9 (IP9).

Table 8-10 lists the vector address of the timer 9 interrupt factor and the interrupt processing flags.

**Table 8-10 Timer 9 Vector Address and Interrupt Processing Flags** 

| Interrupt factor                   | Vector Interrupt Interrupt P |         |        | Priorit | y level |
|------------------------------------|------------------------------|---------|--------|---------|---------|
| Interrupt factor                   | address [H]                  | request | enable | 1       | 0       |
| Overflow of timer 9                | 0072                         | QTM9OV  | ETM9OV | P1TM9OV | P0TM9OV |
| Symbols (byte) of reg              | IDO4                         | IE4     | IP9    |         |         |
| contain interrupt processing flags |                              | IRQ4    |        |         | IE4     |
| Reference page                     |                              | 17-16   | 17-21  | 17-31   |         |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# Chapter 9

# Capture/Compare Timer

# 9. Capture/Compare Timer

#### 9.1 Overview

The MSM66577 family has a built-in 2-channel capture/compare timer.

Timer functions consist of a capture mode used for pulse width and cycle measurements and a compare out mode used for pulse output with real-time control. Functions can be selected for use with each of the two channels.

# 9.2 Capture/Compare Timer Configuration

Figure 9-1 shows the capture/compare timer configuration. The counter unit consists of a 16-bit free running counter (FRC) and two capture/compare out modules.



FRC: free running counter (16 bits)

CPCMRn: Capture/compare register (16 bits)

CAPCON: Capture control register

CPCMBFRn: Capture/compare buffer register (16 bits)

CPCMOUTn: Capture/compare out bit

CPCMn: Capture input/compare output pin (P5\_4, P5\_5)

CPCMBFn: Compare out buffer bit CPCMSBFn: Compare out sub-buffer bit

Figure 9-1 Capture/Compare Timer Configuration

# 9.3 Capture/Compare Timer Registers

Table 9-1 lists a summary of SFRs for control of the capture/compare timer.

Table 9-1 Summary of SFRs for Control of the Capture/Compare Timer

| Address | Nome                       | Symbol   | Symbol       | R/W          | 8/16      | Initial   | Reference       |
|---------|----------------------------|----------|--------------|--------------|-----------|-----------|-----------------|
| [H]     | Name                       | (byte)   | (word)       | H/VV         | Operation | value [H] | page            |
| 0040    | Froe rupping counter       |          | FRC          | D 44/        | 16        | 0000      | 9-3             |
| 0041    | Free running counter       | _        | FRC          | R/W          | 10        | 0000      | 9-3             |
| 004A    |                            |          | CPCMR0       | R/W          | 16        | 0000      | 9-6             |
| 004B    |                            | _        | CFCIVINU     | □/ VV        | 10        | 0000      | 9-0             |
| 004C    | Capture/compare            |          | CPCMR1       | R/W          | 16        | 0000      | 9-6             |
| 004D    | register 1                 | _        | CPCIVINI     | <b>□/ VV</b> | 10        | 0000      | 9-0             |
| 0050☆   | Free running counter       | FRCON    | _            | R/W          | 8         | C0        | 9-4             |
| 0030 x  | control register           | FACON    |              |              | 0         |           | 3- <del>4</del> |
| 0051 ☆  | Capture control register   | CAPCON   | _            | R/W          | 8         | C0        | 9-7             |
| 0055☆   | Compare control register 0 | CPCMCON0 | _            | R/W          | 8         | F8        | 9-6             |
| 0056☆   | Compare control register 1 | CPCMCON1 | _            | R/W          | 8         | F8        | 9-6             |
| 00EA    | Capture/compare            |          | CDCMDEDO     | D/M          | 16        | 0000      | 0.0             |
| 00EB    | 0EB buffer register 0      |          | CPCMBFR0     | R/W          | 16        | 0000      | 9-8             |
| 00EC    | Capture/compare            |          | CPCMBFR1     | R/W          | 16        | 0000      | 0.8             |
| 00ED    | buffer register 1          | _        | OF CIVIDER I |              |           |           | 9-8             |

# [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (♠) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

# 9.4 16-Bit Free Running Counter (FRC)

A 16-bit free running counter (FRC) is used as the counter unit of the compare/capture timer.

### 9.4.1 16-Bit Free Running Counter Configuration

Figure 9-2 shows the 16-bit free running counter configuration.



FRC: free running counter (16 bits)

FRCON: free running counter control register

Figure 9-2 16-Bit Free Running Counter Configuration

#### 9.4.2 Description of 16-bit Free Running Counter Register

#### (1) 16-bit free running counter (FRC)

The 16-bit free running counter (FRC) is a 16-bit up-counter. Counter overflow causes an interrupt request to be generated and the counter to be cleared to "0".

FRC can be read from and written to by the program.

Use the interrupt processing routine active when the interrupt request is generated to write the next values to the free running counter (FRC).

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), FRC becomes 0000H.

# (2) Free running counter control register (FRCON)

The free running counter control register (FRCON) consists of 6 bits. FRCON selects the count clock for the free running counter (FRC), starts/stops the counter, and specifies the operating mode of the capture/compare out module. Bits 0 to 2 (FRCK0 to FRCK2) select the FRC count clock and bit 3 (FRRUN) specifies whether to run or stop the counter. Bit 4 (CP0MD) specifies the CPCM0 operating mode and bit 5 (CP1MD) specifies the CPCM1 operating mode.

FRCON can be read from and written to by the program. However, write operations are invalid for the upper 2 bits. If read, a value of "1" will always be obtained for the upper 2 bits.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), FRCON becomes C0H, TBCCLK is selected for the FRC count clock, and counting is halted. Also, the capture/compare out module will specify the compare out mode.

Figure 9-3 shows the FRCON configuration.



"—" indicates a nonexistent bit. If read, its value will be "1."

Figure 9-3 FRCON Configuration

# 9.5 Capture/Compare Out Modules

The MSM66577 family has two sets of capture/compare out modules. The configuration of the two sets is identical with the only difference being the address of registers in the SFR area.

# [Note]

To switch the mode between the capture mode and the compare mode, first stop the free running counter (set FRRUN of the FRCON register to "0"), then switch the mode. If the mode is switched without stopping the free running counter, the capture/compare register (CPCMR0 or CPCMR1) value may become different from the expected value.

# 9.5.1 Capture/Compare Out Module Configuration

Figure 9-4 shows the capture/compare out module configuration.



FRC: free running counter (16 bits)

CPCMRn: Capture/compare register (16 bits)

CAPCON: Capture control register

CPCMBFRn: Capture/compare buffer register (16 bits)

CPCMOUTn: Capture/compare out bit

CPCMn: Capture input/compare output pin (P5\_4, P5\_5)

CPCMBFn: Compare out buffer bit CPCMSBFn: Compare out sub-buffer bit

Figure 9-4 Capture/Compare Out Module Configuration

# 9.5.2 Description of Capture/Compare Out Module Registers

# (1) Capture/compare registers (CPCMR0, CPCMR1)

The capture/compare registers (CPCMR0 and CPCMR1) consist of 16 bits. In the compare out mode, CPCMR0 and CPCMR1 are always compared to the value of the free running counter (FRC). In the capture mode, when the edge specified as valid is input to a CPCMn pin, a capture event interrupt is generated, and at the same time, the contents of the free running counter (FRC) are loaded into CPCMR0 and CPCMR1.

CPCMR0 and CPCMR1 can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), CPCMR0 and CPCMR1 become 0000H.

# (2) Capture/compare control registers (CPCMCON0, CPCMCON1)

The capture/compare control registers (CPCMCON0 and CPCMCON1) consist of 3 bits. In the compare out mode, if CPCMR0 and CPCMR1 match the value of the free running counter (FRC), the contents of CPCMBFn (bit 1) are loaded into CPCMOUTn (bit 0). At the same time, the contents of CPCMSBFn (bit 2) are loaded into CPCMBFn (bit 1). CPCMBFn is set to the level (High or Low level) that is desired at the time of the next match.

CPCMCON0 and CPCMCON1 can be read from and written to by the program. However, write operations are invalid for the upper 5 bits. If read, the value of the upper 5 bits is always "1".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), CPCMCON0 and CPCMCON1 become F8H.

Figure 9-5 shows the configuration of CPCMCON0 and CPCMCON1.



Figure 9-5 CPCMCON0 and CPCMCON1 Configuration

#### [Note]

<u>Just before the occurrence of an event</u> caused by compare out, if an SB, RB, XORB or other read-modify-write instruction is performed on CPCMCON0 or CPCMCON1, then CPCMBFn and CPCMOUTn may not operate correctly.

# (3) Capture control register (CAPCON)

The capture control register (CAPCON) consists of 4 bits. When the capture/compare out module is in the capture mode, CAPCON specifies the valid edge for the signal input to CPCM0 and CPCM1 pins. Bits 2 and 3 (CP0E0 and CP0E1) specify the valid edge of the signal input to the CPCM0 pin, and bits 4 and 5 (CP1E0 and CP1E1) specify the valid edge of the signal input to the CPCM1 pin.

CAPCON can be read from and written to by the program. However, write operations are invalid for the upper 2 bits and lower 2 bits. If read, the upper 2 bits are always "1" and the lower 2 bits are always "0".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), CAPCON becomes C0H, and "capture input invalid" is specified for CPCM0 and CPCM1.

Figure 9-6 shows the configuration of CAPCON.



"—" indicates a nonexistent bit.

If bits 6 and 7 are read, their value will be "1."

Bits 0 and 1 are read as "0."

Figure 9-6 CAPCON Configuration

#### [Note]

Set the minimum pulse width of the capture input longer than 1 CPU clock (CPUCLK). The capture input signal is sampled at the falling edge of the CPUCLK and used as the internal capture signal.

# (4) Capture/compare buffer registers (CPCMBFR0, CPCMBFR1)

The capture/compare buffer registers (CPCMBFR0, CPCMBFR1) consist of 16 bits. During the compare out mode, if the value specified in CPCMR0 and CPCMR1 matches the value of the free running counter (FRC), the value set in CPCMBFR0 and CPCMBFR1 is loaded into CPCMR0 and CPCMR1.

The program can read from and write to CPCMBFR0 and CPCMBFR1.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), CPCMBFR0 and CPCMBFR1 become 0000H.

# 9.6 Example of Capture/Compare Timer-related Register Settings

# 9.6.1 Capture Mode Settings

# (1) Port 5 mode register (P5IO)

If CPCM0 is to be set to the capture mode, reset bit 4 (P5IO4) to "0" to configure the port as an input. If CPCM1 is to be set to the capture mode, reset bit 5 (P5IO5) to "0" to configure the port as an input.

# (2) Port 5 secondary function control register (P5SF)

Bit 4 (P5SF4) specifies whether the CPCM0 capture input is pulled up. Bit 5 (P5SF5) specifies whether the CPCM1 capture input is pulled up.

# (3) Capture control register (CAPCON)

Specify the valid edge for CPCM0 with bits 2 and 3 (CP0E0 and CP0E1). Specify the valid edge for CPCM1 with bits 4 and 5 (CP1E0 and CP1E1).

#### (4) Free running counter (FRC)

The initial value at the start of counting can be set by writing an arbitrary 16-bit value. FRC can be read from and written to during counting.

#### (5) Free running counter control register (FRCON)

Bits 0, 1, and 2 (FRCK0, FRCK1, and FRCK2) specify the count clock for the free running counter. To set CPCM0 to the capture mode, set bit 4 (CP0MD) to "1". To set CPCM1 to the capture mode, set bit 5 (CP1MD) to "1". If bit 3 (FRRUN) is set to "1", the free running counter will begin counting. If reset to "0", the free running counter will halt counting.

# 9.6.2 Compare Out Mode Settings

# (1) Port 5 mode register (P5IO)

If CPCM0 is to be set to the compare out mode, set bit 4 (P5IO4) to "1" to configure the port as an output. If CPCM1 is to be set to the compare out mode, set bit 5 (P5IO5) to "1" to configure the port as an output.

# (2) Port 5 secondary function control register (P5SF)

If CPCM0 is to be set to the compare out mode, set bit 4 (P5SF4) to "1" to configure the port as a secondary function output. If CPCM1 is to be set to the compare out mode, set bit 5 (P5SF5) to "1" to configure the port as a secondary function output.

# (3) Capture/compare control registers (CPCMCON0, CPCMCON1)

If CPCM0 is to be set to the compare out mode, specify with bit 0 (CPCMOUT0) the initial value to be output to the CPCM0 pin, and specify with bit 1 (CPCMBF0) the value desired to be output from the CPCM0 pin when the value of the free running counter matches the contents of the CPCMR0. Specify with bit 2 (CPCMSBF0) the value desired to be output from the CPCM0 pin when the next value of the free running counter matches the contents of the CPCMR0. If CPCM1 is to be set to the compare out mode, specify with bit 0 (CPCMOUT1) the initial value to be output to the CPCM1 pin, and specify with bit 1 (CPCMBF1) the value desired to be output from the CPCM1 pin when the value of the free running counter matches the contents of the CPCMR1. Specify with bit 2 (CPCMSBF1) the value desired to be output from the CPCM1 pin when the next value of the free running counter matches the contents of the CPCMR1.

# (4) Free running counter (FRC)

The initial value at the start of counting can be set by writing an arbitrary 16-bit value. FRC can be read from and written to during counting.

#### (5) Capture/compare registers (CPCMR0, CPCMR1)

If CPCM0 has been set to the compare out mode, set a count value in CPCMR0 at which to change the CPCM0 pin output. If CPCM1 has been set to the compare out mode, set a count value in CPCMR1 at which to change the CPCM1 pin output.

# (6) Capture/compare buffer registers (CPCMBFR0, CPCMBFR1)

If CPCM0 has been set to the compare out mode, CPCMBF0 specifies the next count value of CPCMR0 at which output of the CPCM0 pin will change. If CPCM1 has been set to the compare out mode, CPCMBF1 specifies the next count value of CPCMR1 at which output of the CPCM1 pin will change.

#### (7) Free running counter control register (FRCON)

Bits 0, 1, and 2 (FRCK0, FRCK1, and FRCK2) specify the count clock for the free running counter. To set CPCM0 to the compare out mode, reset bit 4 (CP0MD) to "0". To set CPCM1 to the compare out mode, reset bit 5 (CP1MD) to "0". If bit 3 (FRRUN) is set to "1", the free running counter will begin counting. If reset to "0", the free running counter will halt counting.

# 9.7 Capture/Compare Timer Operation

# 9.7.1 Capture Mode Operation

When the free running counter (FRC) is in the RUN state, if the valid edge specified by CAPCON is input to the CPCM0 or CPCM1 pins, the capture event will generate an interrupt request, and the contents of the free running counter (FRC) will be simultaneously loaded into CPCMRn (where n=0, 1).

Figure 9-7 shows an operation example of the capture mode.



Figure 9-7 Capture Module Operation Example

#### [Note]

Set the minimum pulse width of the capture input to at least 1 CPU clock (CPUCLK). The capture input signal is sampled at the falling edge of the CPUCLK and used as the internal capture signal.

# 9.7.2 Compare Out Mode Operation

When the free running counter (FRC) is in the RUN state, CPCMR0 and CPCMR1 are always compared to the value of the free running counter (FRC). If they match, an interrupt request is generated by compare out and the contents of the CPCMBFn (bit 1) of CPCMCON0 and CPCMCON1 are loaded into CPCMOUTn (bit 0) (where n=0,1). Also, the contents of the CPCMSBFn (bit s) are loaded into CPCMBFn (bit 1) and the contents of the CPCMBRn are loaded into CPCMRn. Therefore, set CPCMRn with the level desired at the timing for the next match and set CPCMBFn with the level desired at the timing for the match following the next match (where n=0,1). Use the interrupt processing routine active when the interrupt request is generated to write the next values to CPCMRn and CPCMBFn (where n=0,1).

Figure 9-8 shows an example of compare out mode operation.



Figure 9-8 Compare Out Mode Operation Example

# 9.8 Example Timings for Changing the Output Level of Compare Out

Example timings in the compare out mode for changing the output level of the CMP output are shown below.

Figure 9-9 shows an example when 1/4 CPUCLK is selected as the clock source for the free running counter (FRC). When the contents of CPCMRn are 100H, the FRC and CPCMRn matching signal will be HIGH 1 CLK after the interval where FRC is 100H. The CPCMn output pin (CPCMOUTn) changes at the falling edge of the logical AND of this matching signal with the FRC clock pulse. Further, the corresponding interrupt request flag is set at the next M1S1 (signal that indicates the beginning of an instruction).

This example shows the timing of an output level change when 1/2 CPUCLK or larger frequency division ratio is selected as the FRC clock source.



Figure 9-9 Example Timing for Changing the Output Level of Compare Out (FRC Clock = 1/4 CPUCLK)

Figure 9-10 shows an example when 1/1 CPUCLK is selected as the clock source for the free running counter (FRC). When the contents of CPCMRn are 100H, the FRC and CPCMRn matching signal will be HIGH 1 CLK after the interval where FRC is 100H. The CPCMn output pin (CPCMOUTn) changes at the falling edge of the logical AND of this matching signal with the FRC clock pulse. Therefore, when the FRC clock is set as 1/1 CPUCLK, the timing at which the CPCM output pin will change is FRC = CPCMRn + 01H (when FRC is 101H in the figure below). The corresponding interrupt request flag is set at the next M1S1 (signal that indicates the beginning of an instruction).



Figure 9-10 Example Timing for Changing the Output Level of Compare Out (FRC Clock = 1/1 CPUCLK)

#### [Note]

In the above, the free running counter (FRC) clock is described as the CPUCLK base. However, the actual FRC clock source is the time base counter (TBC) output. Therefore, the example of Figure 9-10 is limited to the case where TBCCLK is selected as the FRC clock with TBCCLK = CPUCLK (when the 1/n counter at the TBC front stage is set with the value 1/1).

For further details regarding TBC, refer to Chapter 7, "Time Base Counter (TBC)".

# 9.9 Capture/Compare Timer Interrupt

When each capture/compare timer interrupt factor occurs, the corresponding interrupt request flag is set to "1". Interrupt request flags are located in interrupt request register 0 (IRQ0).

Interrupts can be enabled or disabled by interrupt enable flags that correspond to each interrupt factor. The interrupt enable flags are located in interrupt enable register 0 (IE0).

Corresponding to each interrupt factor, interrupt priority setting flags can set three levels of priority for each interrupt factor. The interrupt priority setting flags are located in interrupt priority control registers 0 and 1 (IP0 and IP1).

Table 9-2 lists the vector address of each interrupt factor of the capture/compare timer and the interrupt processing flags.

Table 9-2 Capture/Compare Timer Vector Addresses and Interrupt Processing Flags

| Interrupt factor                   | Vector      | Interrupt | Interrupt | Priorit     | y level |
|------------------------------------|-------------|-----------|-----------|-------------|---------|
| interrupt factor                   | address [H] | request   | enable    | 1           | 0       |
| Overflow of free                   | 000C        | QFRCOV    | EFRCOV    | P1FRCOV     | P0FRCOV |
| running counter                    | 0000        |           |           |             |         |
| CPCM0 capture input                | 0016        | QCPCM0    | ECPCM0    | P1CPCM0     | P0CPCM0 |
| CPCM0 compare match                | 0016        |           |           |             |         |
| CPCM1 capture input                | 0018        | QCPCM1    | ECPCM1    | P1CPCM1     | P0CPCM1 |
| CPCM1 compare match                | 0016        | QUPUIVIT  |           | PICPCIVII   |         |
| Symbols (BYTE) of registers that   |             | IRQ0      | IE0       | IP0/IP1     |         |
| contain interrupt processing flags |             | ingu      | IEU       |             |         |
| Reference page                     |             | 17-12     | 17-17     | 17-22/17-23 |         |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# Chapter 10

# Real-Time Counter (RTC)

10

# 10. Real-Time Counter (RTC)

#### 10.1 Overview

The MSM66577 family contains one internal 15-bit real-time clock counter (RTC).

The real-time counter runs on the clock obtained from the oscillation circuit (32.768 kHz) connected to the XT pins. Interrupt requests at 1, 0.5, 0.25, and 0.125 seconds can be obtained from the output of the real-time counter.

Counting continues even when in a standby state (STOP, HALT and HOLD modes). The STOP and HALT modes can be released by the real-time counter interrupt.

# 10.2 Real-Time Counter Configuration

Figure 10-1 shows the real-time counter configuration.



Figure 10-1 Real-Time Counter Configuration

# 10.3 Real-Time Counter Control Register (RTCCON)

The real-time clock control register (RTCCON) consists of 4 bits. All real-time counter settings are performed with RTCCON.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), RTCCON becomes F0H.

Figure 10-2 shows the RTCCON configuration.

#### [Description of each bit]

• RTCCL (bit 0)

This bit is used to reset the real-time counter. If RTCCL is set to "1", the real-time counter will be reset to "0". When the real-time counter is reset, RTCCL is also simultaneously reset to "0".

• RTCIE (bit 1)

This bit enables or disables the real-time counter interrupt.

SELRTI0, SELRTI1 (bits 2 and 3)
 These bits select the interrupt cycle for the real-time counter interrupt.



"—" indicates a nonexistent bit. When read, its value will be "1."

Figure 10-2 RTCCON Configuration

# 10.4 Example of Real-Time Counter Register Settings

- (1) Peripheral Control Register (PRPHCON)

  If the real-time counter related is to run on an external clock input to the XT0 pin (instead of the clock from the XT oscillation circuit), set bit 4 (EXTXT) to "1". Thereafter, an external clock can be input to the XT0 pin.
- (2) Real-Time Counter Control Register (RTCCON)

  To reset the real-time counter, set bit 0 (RTCCL) to "1". If the real-time interrupt is to be used, specify the real-time counter interrupt request cycle with bits 2 and 3 (SELRTI0 and SELRTI1) and set bit 1 (RTCIE) to "1" to enable the interrupt.

# 10.5 Real-Time Counter Operation

The real-time counter counts upward at the falling edge of XTCLK (XT clock). The output of real-time counter bits 11 through 14, as selected by bits 2 and 3 (SELRTI0 and SELRTI1) of the real-time counter control register (RTCCON), generate real-time counter interrupt requests.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the real-time counter is reset to "0". The real-time counter can also be reset to "0" by setting the RTCCL bit of RTCCON to "1".

# **10.6 Real-Time Counter Interrupt**

When the real-time counter interrupt factor occurs, the interrupt request flag (QRTC) is set to "1". The interrupt request flag (QRTC) is located in interrupt request register 3 (IRQ3).

Interrupt can be enabled or disabled by the interrupt enable flag (ERTC). The interrupt enable flag (ERTC) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0RTC and P1RTC). The interrupt priority setting flags are located in interrupt priority control register 7 (IP7).

Table 10-1 lists the vector address of the real-time counter interrupt factor and the interrupt processing flags.

Table 10-1 Real-Time Counter Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector       | Interrupt | Interrupt | Priority level |       |  |
|------------------------------------|--------------|-----------|-----------|----------------|-------|--|
| Interrupt factor                   | address [H]  | request   | enable    | 1              | 0     |  |
| Real-time counter output           | 0048         | ORTC      | ERTC      | P1RTC          | P0RTC |  |
| (Cycle: 0.125 to 1 s)              | 0046         | Qhic      | ENIC      | PINIC          |       |  |
| Symbols (BYTE) of req              | gisters that | IDO2      | IE3       | ID7            |       |  |
| contain interrupt processing flags |              | IRQ3      | IES       | IP7            |       |  |
| Reference page                     |              | 17-15     | 17-20     | 17-29          |       |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# Chapter 11

# **PWM Function**

# 11. PWM Function

#### 11.1 Overview

The MSM66577 family contains 4 channels of PWM (Pulse Width Modulation) function that can vary the duty with a fixed cycle. The resolution of each channel of PWM output is 8 bits. Use of this function as 2 channels of PWM with 16-bit resolution is also possible. When used as a 16-bit PWM, a high-speed mode is available that does not degrade the resolution of PWM output.

# 11.2 PWM Configuration

The MSM66577 family has two sets of 2-channel 8-bit PWMs (8-bit PWM0 and 8-bit PWM1) that share a common counter. These can be cascaded and used as 16-bit PWM (16-bit mode).

Figure 11-1 shows the PWM configuration.



PWCY0, PWCY1: PWM cycle register (8 bits)

PWC0, PWC1: PWM counter (8 bits)
PWR0 to PWR3: PWM register (8 bits)
PWM0OUT to PWM3OUT: PWM output pin
PWMINT0 to PWMINT3: Interrupt request

Figure 11-1 PWM Configuration

# 11.3 PWM Register

Table 11-1 lists a summary of SFRs for PWM control.

Table 11-1 Summary of SFRs for PWM Control

| Address | Name                   | Symbol | Symbol    | R/W    | 8/16      | Initial   | Reference |
|---------|------------------------|--------|-----------|--------|-----------|-----------|-----------|
| [H]     | Name                   | (byte) | (word)    | IT/ VV | Operation | value [H] | page      |
| 0090    | PWM register 0         | PWR0   | DWD01     | D ///  | 8/16      | 00        | 44.4      |
| 0091    | PWM register 1         | PWR1   | PWR01 R/W | 0/10   | 00        | 11-4      |           |
| 0092    | PWM register 2         | PWR2   | PWR23 R   | R/W    | 8/16      | 00        | 11-4      |
| 0093    | PWM register 3         | PWR3   |           | H/ VV  | 6/10      | 00        |           |
| 0094    | PWM cycle register 0   | PWCY0  | PWCY      | R/W    | 8/16      | 00        | 11-3      |
| 0095    | PWM cycle register 1   | PWCY1  | FWC1      | L-/ VV |           | 00        | 11-0      |
| 0096    | PWM counter 0          | PWC0   | PWC       | R/W    | 8/16      | 00        | 11-3      |
| 0097    | PWM counter 1          | PWC1   | PWC       | H/ VV  | 0/10      | 00        | 11-3      |
| 0098    | PWM control register 0 | PWCON0 | _         | R/W    | 8         | 00        | 11-4      |
| 0099☆   | PWM control register 1 | PWCON1 | _         | R/W    | 8         | FE        | 11-6      |

# [Notes]

- 1. A star (☆) in the address column indicates a missing bit.
- 2. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

# 11

# 11.3.1 Description of PWM Registers

# (1) PWM counters (PWC0, PWC1)

The PWM counters (PWC0, PWC1) are 8-bit up-counters. When overflow occurs, the value in PWM cycle registers (PWCY0, PWCYC1) is loaded into PWC0 and PWC1.

PWC0 and PWC1 can be read from and written to by the program. PWC0 and PWC1 can also be accessed as 16-bit PWC. During a 16-bit access, PWC1 is the upper 8 bits and PWC0 is the lower 8 bits of PWC.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PWC0 and PWC1 become 00H.

# [Note]

Writing a count value to PWC0 causes the same value to also be written to PWM cycle register 0 (PWCY0). Similarly, writing a count value to PWC1 causes the same value to also be written to PWM cycle register 1 (PWCY1).

# (2) PWM cycle registers (PWCY0, PWCY1)

The PWM cycle registers (PWCY0, PWCY1) are 8-bit registers that set the PWM cycle.

PWCY0 and PWCY1 can be read from and written to by the program. PWCY0 and PWCY1 can also be accessed as 16-bit PWCY. During a 16-bit access, PWCY1 is the upper 8 bits and PWCY0 is the lower 8 bits of PWCY.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PWCY0 and PWCY1 become 00H.

# [Note]

The cycle set in PWCY0 must be longer than the duty value set by PWR0 and PWR2. Also, the cycle set in PWCY1 must be longer than the duty value set by PWR1 and PWR3. During the 16-bit mode, the cycle set in PWCY must be longer than the duty value set in PWR01 and PWR23.

# (3) PWM registers (PWR0 to PWR3)

The PWM registers (PWR0 to PWR3) are 8 bit registers that set the duty value. The duty value setting for PWR0 and PWR2 is limited to within the cycle range set by PWCY0. Also, the duty value setting for PWR1 and PWR3 is limited to within the cycle range set by PWCY1.

PWR0 to PWR3 can be read from and written to by the program. PWR0 and PWR1 can also be accessed as the 16-bit PWR01. PWR2 and PWR3 can also be accessed as the 16-bit PWR23. During a 16-bit access, PWR1 is the upper 8 bits and PWR0 is the lower 8 bits of PWR01, and PWR3 is the upper 8 bits and PWR2 is the lower 8 bits of PWR23.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PWR0 to PWR3 become 00H.

# [Note]

During the 16-bit mode, the duty valu set by PWR01 and PWR23 is limited to within the cycle range set by PWCY.

### (4) PWM control register 0 (PWCON0)

The PWM control register 0 (PWCON0) consists of 8 bits. PWCON0 starts and stops the PWM counters (PWC0, PWC1), selects the counter clock, and specifies the interrupt factor of PWINT0 and PWINT1.

PWCON0 can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PWCON0 becomes 00H.

Figure 11-2 shows the PWCON0 configuration.



Figure 11-2 PWCON0 Configuration

# (5) PWM control register 1 (PWCON1)

The PWM control register 1 (PWCON1) consists of 1 bit. PWCON1 register is used to select normal mode or high-speed mode of PWM. If bit 0 (PWHSM) is set to "1", the mode changes to high-speed mode. High-speed mode can only be used during the 16-bit mode.

PWCON can be read from or written to by the program. However, write operations are invalid for bits 1 through 7. If read, a value of "1" will always be obtained for bits 1 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PWCON1 becomes FEH.

Figure 11-3 shows the PWCON1 configuration.



"—" indicates a nonexistent bit. When read, its value will be "1."

Figure 11-3 PWCON1 Configuration

#### [Note]

High-speed mode is only valid when 16-bit PWM is used.

## 11.3.2 Example of PWM-related Register Settings

#### • 8-bit PWM settings

## (1) Port 7 mode register (P7IO)

If PWM0OUT is to be used, set bit 6 (P7IO6) to "1" to configure the port as an output. If PWM1OUT is to be used, set bit 7 (P7IO7) to "1" to configure the port as an output.

## (2) Port 8 mode register (P8IO)

If PWM2OUT is to be used, set bit 6 (P8IO6) to "1" to configure the port as an output. If PWM3OUT is to be used, set bit 7 (P8IO7) to "1" to configure the port as an output.

## (3) Port 7 secondary function control register (P7SF)

If PWM0OUT is to be used, set bit 6 (P7SF6) to "1" to configure the port as a secondary function output. If PWM1OUT is to be used, set bit 7 (P7SF7) to "1" to configure the port as a secondary function output. In the PWM initial state or when PWM function is halted, the PWM output port is fixed at "1". To fix the port at "0", return the port to a primary function.

## (4) Port 8 secondary function control register (P8SF)

If PWM2OUT is to be used, set bit 6 (P8SF6) to "1" to configure the port as a secondary function output. If PWM3OUT is to be used, set bit 7 (P8SF7) to "1" to configure the port as a secondary function output. In the PWM initial state or when PWM function is halted, the PWM output port is fixed at "1". To fix the port at "0", return the port to a primary function.

## (5) PWM counters (PWC0, PWC1)

Set these counters with the value at which to start counting. Writing to PWC0 and PWC1 causes the same value to be simultaneously and automatically written to PWCY0 and PWCY1.

#### (6) PWM cycle registers (PWCY0, PWCY1)

If PWM0OUT and PWM2OUT are to be used, set the PWM cycle in PWCY0. If PWM1OUT and PWM3OUT are to be used, set the PWM cycle in PWCY1.

## (7) PWM registers (PWR0 to PWR3)

If PWMnOUT are to be used, set the desired output duty value in PWRn (where n = 0 to 3). Set a value for PWR0 and PWR2 that is larger than the value of PWCY0. Set a value for PWR1 and PWR3 that is larger than the value of PWCY1.

## (8) PWM control register 0 (PWCON0)

If PWM0OUT and PWM2OUT are to be used, set the count clock for PWM counter 0 (PWC0) with bits 1 and 2 (PWCK00, PWCK01), and specify the interrupt factor that will initiate a PWINT0 interrupt request with bit 3 (PWC0OV). If bit 0 (PW0RUN) is set to "1", the PWM counter 0 (PWC0) begins counting. If reset to "0" the counting is halted.

If PWM1OUT and PWM3OUT are to be used, set the count clock for PWM counter 1 (PWC1) with bits 5 and 6 (PWCK10, PWCK11), and specify the interrupt factor that will initiate a PWINT1 interrupt request with bit 7 (PWC1OV). If bit 4 (PW1RUN) is set to "1", the PWM counter 1 (PWC1) begins counting. If reset to "0" the counting is halted.

[Equation to Calculate 8-Bit PWM Cycle]

 $f_{(PWM8)} = PWCLK / (256 - PWCYn)$   $f_{(PWM8)} : PWM cycle [Hz]$ 

PWCLK: PWM input clock frequency [Hz] PWCYn: Value of PWCY0 or PWCY1 (8 bits)

#### • 16-bit PWM settings

## (1) Port 7 mode register (P7IO)

If PWM1OUT is to be used, set bit 7 (P7IO7) to "1" to configure the port as an output.

#### (2) Port 8 mode register (P8IO)

If PWM3OUT is to be used, set bit 7 (P8IO7) to "1" to configure the port as an output. When the PWM function does not operate, this port is fixed at "1".

## (3) Port 7 secondary function control register (P7SF)

If PWM1OUT is to be used, set bit 7 (P7SF7) to "1" to configure the port as a secondary function output. In the PWM initial state or when PWM function is halted, the PWM output port is fixed at "1". To fix the port at "0", return the port to a primary function.

## (4) Port 8 secondary function control register (P8SF)

If PWM3OUT is to be used, set bit 7 (P8SF7) to "1" to configure the port as a secondary function output. In the PWM initial state or when PWM function is halted, the PWM output port is fixed at "1". To fix the port at "0", return the port to a primary function.

#### (5) PWM counters (PWC0, PWC1)

Set these counters with the value at which to start counting. Writing to PWC causes the same value to be simultaneously and automatically written to PWCY.

## (6) PWM cycle register (PWCY)

Set the PWM cycle in PWCY.

# (7) PWM registers (PWR01, PWR23)

If PWM1OUT is to be used, set the desired output duty value in PWR01. If PWM3OUT is to be used, set the desired output duty value in PWR23. Set a value for PWR01 and PWR23 that is larger than the value of PWCY.

# (8) PWM control register 0 (PWCON0)

Setting both bits 5 and 6 (PWCK10 and PWCK11) to "1" cascades the two counters (16-bit mode) so that overflow of PWM counter 0 (PWC0) is the clock input to PWM counter 1 (PWC1), thereby forming 16-bit PWM counter (PWC). Bits 1 and 2 (PWCK00 and PWCK01) specify the count clock. Bits 3 and 7 (PWC0OV and PWC1OV) specify the interrupt factor for PWINT0 and PWINT1 interrupt requests. Leaving bit 4 (PW1RUN) set to "1" allows starting and stopping during the 16-bit mode to be controlled with only bit 0 (PW0RUN).

# (9) PWM control register 1 (PWCON1)

Bit 0 (PWHSM) specifies normal 16-bit mode or high-speed mode. During the high-speed mode, starting and stopping can be controlled with only bit 4 (PW1RUN) of PWCON0.

[Equation to Calculate 16-Bit PWM Cycle]

 $f_{(PWM16)} = PWCLK / (65536 - PWCY)$   $f_{(PWM16)} : PWM cycle [Hz]$ 

PWCLK: PWM input clock frequency [Hz]

PWCY: Value of PWCY (16 bits)

## 11.4 PWM Operation

# 11.4.1 PWM Operation During 8-bit Mode

During the 8-bit mode, PWM output can use the four output pins of PWM0OUT through PWM3OUT.

PWM is started by setting the corresponding RUN bit (PW0RUN, PW1RUN) to "1". When the corresponding RUN bit becomes 1, PWC0 and/or PWC1 begin counting, at the same time the output flip-flop is set to "1", and a High level is output from the PWMnOUT pin (where n = 0 to 3). PWC0 and PWC1 continue to count upward. When their value matches the contents of the corresponding PWRn, an interrupt request is generated, the output flip-flop is reset to "0", and a Low level is output from the PWMnOUT pin. If PWC0 and PWC1 overflow, the output flip-flop is set to "1", and the PWMnOUT pin outputs a High level. Also, the value of PWCY0 and PWCY1 is loaded into PWC0 and PWC1. Thereafter, until the RUN bit is reset to "0", this operation will repeat and the duty controlled waveform will be output from the PWMnOUT pin. When the RUN bit is reset to "0", the PWMnOut pin is fixed at "1".

#### [Note]

Depending upon the count clock selected for PWC0 and PWC1, immediately after PWM is started, the PWM output duty may be shortened (for one cycle only).

If the value of PWC0 and PWC1 is 00H, and the value of the corresponding PWRn is 00H, the duty output is 1/256. Increasing the value of PWRn increases the output duty (High level). If the value of PWRn is FFH, the output is 256/256 or 100% duty. To realize 0/256 or 0% duty, use the port 1 primary function since 0% duty cannot be realized with the PWM function.

Figure 11-4 shows an example of PWM output operation.

#### 11.4.2 PWM Operation During 16-bit Mode

During the 16-bit mode, PWM output can use the two output pins of PWM1OUT and PWM3OUT.

PWM is started by first setting PW1RUN to "1", and then by setting PWM0RUN to "1". When the RUN bit becomes 1, PWC begins counting, the output flip-flop is simultaneously set to "1", and a High level is output from the PWM1OUT pin (PWM3OUT pin). PWC continues to count upward. When its value matches the contents of PWR01 (PWR23), a PWINT1 (PWINT3) interrupt request is generated, the output flip-flop is reset to "0", and a Low level is output from the PWM1OUT pin (PWM3OUT pin). If PWC overflows, the output flip-flop is set to "1", and the PWM1OUT pin (PWM3OUT pin) outputs a High level. Also, the value of PWCY is loaded into PWC. Thereafter, until the RUN bit is reset to "0", this operation will repeat and the duty controlled waveform will be output from the PWM1OUT pin (PWM3OUT pin). When the RUN bit is reset to "0", the PWMnOut pin is fixed at "1".

However, even in the 16-bit mode, an interrupt request (PWINT2) is generated when the value of PWC0 (lower 8 bits of PWC) matches that of PWR2 (lower 8 bits of PWR23). Also, a PWINT0 interrupt is generated when the value of PWC0 (lower 8 bits of PWC) matches that of PWR0 (lower 8 bits of PWR01), and an interrupt request (PWINT0) is generated when PWC0 overflows.

## [Note]

Depending upon the count clock selected for PWC, immediately after PWM is started, the PWM output duty may be shortened (for one cycle only).

If the value of PWC is 0000H, and the value of PWR01 (PWR23) is 0000H, the duty output is 1/65536. Increasing the value of PWR01 (PWR23) increases the output duty (High level). If the value of PWR01 (PWR23) is FFFFH, the output is 65536/65536 or 100% duty. To realize 0/65536 or 0% duty, use the port 1 primary function since 0% duty cannot be realized with the PWM function.

Figure 11-4 shows an example of PWM output operation. Figure 11-5 shows an example of the timing at which PWM output changes.



Figure 11-4 Example of PWM Output Operation



Figure 11-5 Example of PWM Output Change Timing

#### 11.4.3 PWM Operation During High-Speed Mode

During the 16-bit mode, setting bit 0 (PWHSM) of PWCON1 to "1" changes the mode to the high-speed mode. In the high-speed mode, as shown in Figure 11-6, overflow of the upper 8 bits of PWC cause the lower 8 bits of PWC to be incremented. The contents of PWC and PWR are compared, and a High level is output while PWC ≤ PWR.



Figure 11-6 PWM Output Waveform During High-Speed Mode

The PWM output in the normal 16-bit mode is 1 pulse per cycle as specified by PWCY. Therefore, when PWCY is 0000H (longest cycle), the PWM output is approximately 458 Hz (for a main clock of 30 MHz). In the high-speed mode, a maximum of 256 pulses are output in the cycle specified by PWCY. The PWM output can achieve the high-speed of 117.2 kHz (for a main clock of 30 MHz). With 256 pulses, because the sum of High and Low intervals is the same as for the 16-bit mode, there is no change in PWM resolution.

Figure 11-7 shows an example of PWM output during the high-speed mode when PWCY is 0000H (longest cycle).



Figure 11-7 Example of PWM Output During High-Speed Mode

#### 11.5 PWM Interrupts

When each PWM interrupt factor occurs, the corresponding interrupt request flag is set to "1". Interrupt request flags are located in interrupt request register 4 (IRQ4).

Interrupts can be enabled or disabled by the interrupt enable flag corresponding to each interrupt factor. The interrupt enable flags are located in interrupt enable register 4 (IE4).

Three levels of priority can be set with the interrupt priority setting flag corresponding to each interrupt factor. The interrupt priority setting flags are located in interrupt priority control register 8 (IP8).

Table 11-2 lists the vector address of each PWM interrupt factor and the interrupt processing flags.

Table 11-2 PWM Vector Addresses and Interrupt Processing Flags

| Intervent factor                   | Vector          | Interrupt | Interrupt | Priority level |        |
|------------------------------------|-----------------|-----------|-----------|----------------|--------|
| Interrupt factor                   | address [H]     | request   | enable    | 1              | 0      |
| Overflow of PWC0                   | 006A            | QPWM0     | EPWM0     | P1PWM0         | P0PWM0 |
| Match of PWC0 and PWR0             | UUbA            |           |           |                |        |
| Overflow of PWC1                   | 006C QPWM1 EPWM | ED\A/N41  | P1PWM1    | P0PWM1         |        |
| Match of PWC1 and PWR1             |                 |           | FIFVVIVII |                |        |
| Match of PWC0 and PWR2             | 006E            | QPWM2     | EPWM2     | P1PWM2         | P0PWM2 |
| Match of PWC1 and PWR3             | 0070            | QPWM3     | EPWM3     | P1PWM3         | P0PWM3 |
| Symbols (BYTE) of registers that   |                 | IRQ4      | IE4       | IP8            |        |
| contain interrupt processing flags |                 | INQ4      |           |                |        |
|                                    | Reference page  | 17-16     | 17-21     | 17-            | -30    |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# Chapter 12

# **Serial Port Functions**

## 12. Serial Port Functions

#### 12.1 Overview

The MSM66577 family contains four built-in serial port channels: two UART/Synchronous receiver transmitter serial port channels (SIO1 and SIO6), and two channels (SIO4 and SIO5) of synchronous receiver transmitter serial ports with 32-byte FIFO.

# 12.2 Serial Port Configuration

Figure 12-1 shows the configuration of the serial ports.



Figure 12-1 Serial Port Configuration

# 12.3 Serial Port Registers

Table 12-1 lists a summary of SFRs for control of the serial port functions.

Table 12-1 Summary of SFRs for Serial Port Function Control

| Address | Name                           | Symbol  | Symbol | R/W  | 8/16      | Initial            | Reference |
|---------|--------------------------------|---------|--------|------|-----------|--------------------|-----------|
| [H]     | Name                           | (byte)  | (word) | H/VV | Operation | value [H]          | page      |
| 0084☆   | SIO1 transmit control register | ST1CON  | _      | R/W  | 8         | 04                 | 12-4      |
| 0085    | SIO1 receive control register  | SR1CON  | _      | R/W  | 8         | 00                 | 12-6      |
| 0086    | SIO1 transmit-receive          | S1BUF — | R/W    | o    | Undefined | 10.10              |           |
| 0000    | buffer register                |         | _      | H/VV | 8         | Unaetinea          | 12-10     |
| 0087☆   | SIO1 status register           | S1STAT  | _      | R/W  | 8         | 00                 | 12-8      |
| 008C☆   | SIO4 control register          | SIO4CON | _      | R/W  | 8         | 80                 | 12-41     |
| 008D    | FIFO control register          | FIFOCON | _      | R/W  | 8         | 11                 | 12-43     |
| 008E    | SIO4 serial input FIFO         | SIN4    | _      | R    | 8         | Undefined          | 12-45     |
| UUOE    | data register                  |         |        |      |           |                    |           |
| 0000    | SIO4 serial output FIFO        | SOUT4   |        | 14/  | 8         | l lis al séis s al | 12-45     |
| 008F    | 008F data register             |         |        | W    | 0         | Undefined          | 12-43     |
| 00CF☆   | FIFO mode control register     | FIFOMOD | _      | R/W  | 8         | FC                 | 12-54     |
| 00D5☆   | SIO5 control register          | SIO5CON | _      | R/W  | 8         | 80                 | 12-52     |
| 0006    | SIO5 serial input FIFO         | SIN5    |        | R    | 8         | Undefined          | 12-54     |
| 0006    | 00D6 data register             |         | _      | n    | 0         | Oridelined         | 12-54     |
| 0007    | SIO5 serial output FIFO        | SOUT5   |        | W    | 8         | Undefined          | 12-54     |
| 0007    | 00D7 data register             |         | _      | VV   | 0         | Oridelined         | 12-54     |
| 00F4☆   | SIO6 transmit control register | ST6CON  | _      | R/W  | 8         | 04                 | 12-16     |
| 00F5    | SIO6 receive control register  | SR6CON  | _      | R/W  | 8         | 00                 | 12-18     |
| 0056    | SIO6 transmit-receive          | CCDLIE  | _      | R/W  | 8         | Undefined          | 12-22     |
| 00F6    | buffer register                | S6BUF   |        |      |           |                    |           |
| 00F7☆   | SIO6 status register           | S6STAT  | _      | R/W  | 8         | 00                 | 12-20     |

## [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (⅓) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

#### 12.4 SIO1

The SIO1 has a UART mode and a synchronous mode. Timer 4 is used as a baud rate generator exclusively for SIO1.

Table 12-2 lists specifications of SIO1.

Table 12-2 SIO1 Specifications

|                         | UART mode                         | Synchronous mode                |  |  |
|-------------------------|-----------------------------------|---------------------------------|--|--|
| Data length             | Selectable as 7 or 8 bits         | Selectable as 7 or 8 bits       |  |  |
| Parity                  | Odd, even, none                   |                                 |  |  |
| Error service           | Parity, overrun, framing          | Overrun                         |  |  |
| Stop bit                | Selectable as 1 or 2 bits         |                                 |  |  |
| Factors that generate   | Transmit buffer empty, transmit   | Transmit buffer empty, transmit |  |  |
| interrupt requests      | complete, receive complete        | complete, receive complete      |  |  |
| Full-duplex             | Possible                          | Possible                        |  |  |
| communication           | Possible                          | Possible                        |  |  |
| Transmit-receive buffer | Both transmission and reception   | Both transmission and reception |  |  |
| Transmit-receive buller | data are double buffered          | data are double buffered        |  |  |
| Max. communication      | 1 975 Mbna                        | 7.5 Mbps                        |  |  |
| speed (f = 30MHz)       | 1.875 Mbps                        | 7.5 Mbps                        |  |  |
|                         | LSB first                         | LSB first                       |  |  |
| Other                   | An external clock can be used for | Master mode/ slave mode         |  |  |
|                         | the UART baud rate                |                                 |  |  |

## 12.4.1 SIO1 Configuration

Figure 12-2 shows the SIO1 configuration.



BRG: Baud rate generator (timer 4) S1BUF: Transmit-receive buffer register ST1CON: SIO1 transmit control register

SR1CON: SIO1 receive control register S1STAT: SIO1 status register

1/n: 1/n frequency dividing counter

TXD1: SIO1 transmit data output pin (P8\_1)

TXC1: SIO1 transmit clock I/O pin (P8\_3) RXD1: SIO1 receive data input pin (P8\_0) RXC1: SIO1 receive clock I/O pin (P8\_2)

Figure 12-2 SIO1 Configuration

## 12.4.2 Description of SIO1 Registers

## (1) SIO1 transmit control register (ST1CON)

The SIO1 transmit control register (ST1CON) is a 7-bit register that controls operation of SIO1 transmission.

ST1CON can be read from and written to by the program. However, write operations are invalid for bit 2. If read, a value of "1" will always be obtained for bit 2.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ST1CON becomes 04H, the data length for SIO1 transmission is 8-bits, 2 stop bits are selected and the mode changes to UART mode with no parity.

The baud rate source is the same for transmission and reception. It is set by the receive control register (SR1CON) to be described later.

## [Note]

If ST1CON is to be modified, make those changes after transmission is complete. If ST1CON is modified before transmission is completed, the current transmission and future transmissions will not be executed correctly.

Figure 12-3 shows the ST1CON configuration.

[Description of each bit]

- ST1MOD (bit 0)
  - ST1MOD specifies the transmission mode (UART or synchronous).
- ST1LN (bit 1)
  - ST1LN specifies the SIO1 transmit data length.
- ST1STB/ST1SLV (bit 3)
  - During the UART mode, ST1STB specifies the SIO1 stop bit length.
  - During the synchronous mode, ST1SLV specifies master or slave operation.
- ST1PEN (bit 4)
  - ST1PEN specifies whether there is parity during SIO1 transmission. (Only valid during the UART mode)
- ST1ODD (bit 5)
  - ST1ODD specifies the parity bit logic during SIO1 transmission. (Only valid during the UART mode)
- TR1MIE (bit 6)
  - TR1MIE specifies whether to use the SIO1 transmit buffer empty signal as an interrupt request signal.
- TR1NIE (bit 7)
  - TR1NIE specifies whether to use the SIO1 transmit complete signal as an interrupt request signal.



Figure 12-3 ST1CON Configuration

## (2) SIO1 receive control register (SR1CON)

The SIO1 receive control register (SR1CON) is an 8-bit register that controls operation of SIO1 reception.

SR1CON can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), SR1CON becomes 00H and SIO1 reception is disabled.

#### [Note]

If SR1CON is to be modified, first reset SR1REN (bit 7) to "0" and then implement the change. If SR1CON is modified before SR1REN (bit 7) is reset to "0", the current reception and future receptions will not be executed correctly.

Figure 12-4 shows the SR1CON configuration.

[Description of each bit]

• SR1MOD (bit 0)

SR1MOD specifies the SIO1 reception mode (UART or synchronous).

• SR1LN (bit 1)

SR1LN specifies the SIO1 receive data length.

• S1EXC (bit 2)

S1EXC specifies the baud rate clock to be used by SIO1 during the UART mode. (This clock is the same for both transmission and reception. The shift clock has a frequency 1/16th of the clock specified here.)

• SR1SLV (bit 3)

During the synchronous mode, ST1SLV specifies master or slave operation of SIO1. (Only valid during the synchronous mode)

• SR1PEN (bit 4)

SR1PEN specifies whether there is parity during SIO1 reception. (Only valid during the UART mode)

• SR1ODD (bit 5)

SR1ODD specifies the parity bit logic during SIO1 reception. (Only valid during the UART mode)

• RC1IE (bit 6)

RC1IE specifies whether to use the SIO1 receive complete signal as an interrupt request signal.

• SR1REN (bit 7)

SR1REN enables or disables SIO1 reception.



Figure 12-4 SR1CON Configuration

## (3) SIO1 status register (S1STAT)

The SIO1 status register (S1STAT) consists of 6 bits. Bits 0 through 2 save the SIO1 status (normal or error) after reception is completed. Bits 3 through 5 save the status of SIO1 at the start and completion of transmission and reception. However bits 0 through 2 are updated after the reception is completed.

S1STAT can be read from and written to by the program. However, write operations are invalid for bits 6 and 7. If read, a value of "0" will always be obtained for bits 6 and 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), S1STAT becomes 00H.

Figure 12-5 shows the S1STAT configuration.

## [Description of each bit]

• FERR1 (bit 0)

If the stop bit in the data received by SIO1 is "0", FERR1 is set to "1" (framing error). This bit is only valid during the UART mode.

• OERR1 (bit 1)

When the SIO1 reception is complete, if the previously received data has not been read by the program, OERR1 is set to "1" (overrun error).

• PERR1 (bit 2)

If the parity bit in the data received by SIO1 does not match the parity of the data, PERR1 is set to "1" (parity error). This bit is only valid during the UART mode.

• TR1EMP (bit 3)

If the SIO1 transmit buffer empty signal is generated, TR1EMP is set to "1".

• TR1END (bit 4)

If the SIO1 transmit complete signal is generated, TR1EMP is set to "1".

• RC1END (bit 5)

If the SIO1 receive complete signal is generated, RC1END is set to "1".

## [Note]

Once each bit of S1STAT is set to "1", the hardware does not reset the bits to "0". Therefore, reset the bits to "0" with the program.



Figure 12-5 S1STAT Configuration

## (4) SIO1 transmit-receive buffer register (S1BUF)

The SIO1 transmit-receive buffer register (S1BUF) is an 8-bit register that stores the transmit and receive data for serial port transmission and reception. Because S1BUF has a duplex configuration for transmission and reception, it operates as a transmission buffer when written to, and as a reception buffer when read from.

After the transmit data has been written to S1BUF, the transmit data is transferred to the transmit shift register and the transmit buffer empty signal is generated. At that time, SIO1 will begin transmission.

After reception is complete, the contents of the receive shift register are transferred to S1BUF and at that time, the receive complete signal is generated. The contents of S1BUF are saved until the next reception is completed.

During a 7-bit data reception, bit 7 of S1BUF is "1", and the 7 bits from bit 0 through bit 6 are the reception data.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the value of S1BUF is undefined.

#### (5) SIO1 transmit shift register, receive shift register

The transmit shift register and receive shift register are 8-bit shift registers that perform the actual shifting operation during transmission and reception.

The transmit shift register and receive shift register cannot be read from or written to by the program.

Table 12-3 lists SIO1 transmit-receive frame lengths.

0

1

1

1

ST1CON/SR1CON Transmit/Receive Frame Length ST1PEN ST1STB ST1LN ST1MOD SR1LN SR1MOD 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, [bit] START STOP STOP 0 0 0 0 8-bit data STOP STOP 0 0 0 START 7-bit data 1 START 8-bit data STOP 0 1 0 0 0 START 7-bit data STOP 0 1 1 START 8-bit data PARITY STOP STOP 0 0 1 0 START 7-bit data PARITY STOP STOP 1 0 0 1 START PARITY STOP 8-bit data 1 0 1 0 START PARITY STOP 7-bit data 1 1 1 0

Table 12-3 SIO1 Transmit-Receive Frame Lengths

8-bit data

7-bit data

# 12.4.3 Example of SIO1-related Register Settings

#### 12.4.3.1 UART Mode Settings

#### Transmit settings

## (1) Port 8 mode register (P8IO)

If TXD8 (transmit data output) is to be used, set bit 1 (P8IO1) to "1" to configure that port as an output. If the baud rate clock is to be input externally, reset bit 2 (P8IO2) to "0" to configure that port as an input.

## (2) Port 8 secondary function control register (P8SF)

If TXD1 (transmit data output) is to be used, set bit 1 (P8SF1) to "1" to configure that port as a secondary function output. If the baud rate clock is to be input externally, specify with bit 2 (P8SF2) whether the input will be pulled-up.

#### (3) SIO1 transmit control register (ST1CON)

Reset bit 0 (ST1MOD) to "0" to change the mode to UART mode. Specify the transmit data length with bit 1 (ST1LN). Specify the stop bit length with bit 3 (ST1STB). Specify whether there is parity with bit 4 (ST1PEN). If parity is selected, specify the parity bit logic with bit 5 (ST1ODD). With bit 6 (TR1MIE), specify whether interrupt requests are enabled or disabled when a transmit buffer empty signal occurs. With bit 7 (TR1NIE), specify whether interrupt requests are enabled or disabled when a transmit complete signal occurs.

## (4) SIO1 receive control register (SR1CON)

Specify with bit 2 (S1EXC) whether the baud rate clock is internal (overflow output of timer 4) or external (RXC1).

## (5) SIO1 transmit-receive buffer register (S1BUF)

Transmission is started by writing the transmit data to S1BUF.

#### Receive settings

#### (1) Port 8 mode register (P8IO)

If RXD1 (receive data input) is to be used, reset bit 0 (P8IO0) to "0" to configure that port as an input. If the baud rate clock is to be input externally, reset bit 2 (P8IO2) to "0" to configure that port as an input.

## (2) Port 8 secondary function control register (P8SF)

Specify with bit 1 (P8SF0) whether the RXD1 pin will be pulled-up. If the baud rate clock is to be input externally, specify with bit 2 (P8SF2) whether the input will be pulled-up.

## (3) SIO1 receive control register (SR1CON)

Reset bit 0 (SR1MOD) to "0" to change the mode to UART mode. Specify the receive data length with bit 1 (SR1LN). Specify with bit 2 (S1EXC) whether the baud rate clock is internal (overflow output of timer 4) or external (RXC1). Specify whether there is parity with bit 4 (SR1PEN). If parity is selected, specify the parity bit logic with bit 5 (SR1ODD). With bit 7 (RC1IE), specify whether interrupt requests are enabled or disabled when a receive complete signal occurs. If bit 7 (SR1REN) is set to "1", reception is enabled and the reception operation is performed when data arrives.

#### 12.4.3.2 Synchronous Mode Settings

## Transmit settings

## (1) Port 8 mode register (P8IO)

If TXD1 (transmit data output) is to be used, set bit 1 (P8IO1) to "1" to configure that port as an output. If the transmit clock is to be output externally (master mode), set bit 3 (P8IO3) to "1" to configure that port as an output. If the baud rate clock is to be input externally (slave mode), reset bit 3 (P8IO3) to "0" to configure that port as an input.

## (2) Port 8 secondary function control register (P8SF)

If TXD1 (transmit data output) is to be used, set bit 1 (P8SF1) to "1" to configure that port as a secondary function output. If the transmit clock is to be output externally (master mode), set bit 3 (P8SF3) to "1" to configure that port as a secondary function output. If the baud rate clock is to be input externally (slave mode), specify with bit 3 (P8SF3) whether the input will be pulled-up.

## (3) SIO1 transmit control register (ST1CON)

Set bit 0 (ST1MOD) to "1" to specify the mode to synchronous mode. Specify the transmit data length with bit 1 (ST1LN). Specify master or slave mode transmission with bit 3 (ST1STB). With bit 6 (TR1MIE), specify whether interrupt requests are enabled or disabled when a transmit buffer empty signal occurs. With bit 7 (TR1NIE), specify whether interrupt requests are enabled or disabled when a transmit complete signal occurs.

#### (4) SIO1 transmit-receive buffer register (S1BUF)

Transmission is started by writing the transmit data to S1BUF.

#### 12

## · Receive settings

#### (1) Port 8 mode register (P8IO)

If RXD1 (receive data input) is to be used, reset bit 0 (P8IO0) to "0" to configure that port as an input. If the transmit clock is to be output externally (master mode), set bit 2 (P8IO2) to "1" to configure that port as an output. If the transmit clock is to be input externally (slave mode), reset bit 2 (P8IO2) to "0" to configure that port as an input.

#### (2) Port 8 secondary function control register (P8SF)

Specify with bit 0 (P8SF0) whether the RXD1 pin will be pulled-up. If the transmit clock is to be output externally (master mode), set bit 2 (P8SF2) to "1" to configure that port as a secondary function output. If the transmit clock is to be input externally (slave mode), specify with bit 2 (P8SF2) whether the input will be pulled-up.

## (3) SIO1 receive control register (SR1CON)

Set bit 0 (SR1MOD) to "1" to specify the mode to synchronous mode. Specify the receive data length with bit 1 (SR1LN). Specify the master or slave mode with bit 3 (SR1SLV). With bit 6 (RC1IE), specify whether interrupt requests are enabled or disabled when a receive complete signal occurs. If bit 7 (SR1REN) is set to "1", reception is enabled and the reception operation is performed when data arrives.

## 12.4.3.3 Baud Rate Generator (Timer 4) Settings

If overflow of timer 4 is selected for use as the baud rate clock, implement the following settings.

#### (1) General-purpose 8-bit timer 4 counter (TM4C)

Set the timer value that will be valid at the start of counting. When writing to TM4C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 4 register (TM4R).

# (2) General-purpose 8-bit timer 4 control register (TM4CON)

Bits 0 to 2 (TM4C0 to TM4C2) of this register specify the count clock for timer 4. If bit 3 (TM4RUN) is set to "1", timer 4 will begin counting. If reset to "0", timer 4 will halt counting.

#### [Equation to Calculate Baud Rate]

 $B = f_{(TM4)} \times 1/(256 - D) \times 1/n$  B: baud rate [bps]

f<sub>(TM4)</sub>: timer 4 input clock frequency [Hz]

D: reload value (0 to 255)
n: 16 for the UART mode
4 for the synchronous mode

## 12.4.4 SIO1 Interrupt

When any SIO1 interrupt factor occurs, the interrupt request flag (QSIO1) is set to "1". The interrupt request flag (QSIO1) is located in interrupt request register 2 (IRQ2).

Interrupts can be enabled or disabled by the interrupt enable flag (ESIO1). The interrupt enable flag (ESIO1) is located in interrupt enable register 2 (IE2).

Three levels of priority can be set with the interrupt priority setting flags (P0SIO1 and P1SIO1). The interrupt priority setting flags (P0SIO1 and P1SIO1) are located in interrupt priority control register 5 (IP5).

Table 12-4 lists the vector address of the SIO1 interrupt factors and the interrupt processing flags.

Table 12-4 SIO1 Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector         | Interrupt | Interrupt | Priority level |        |
|------------------------------------|----------------|-----------|-----------|----------------|--------|
| interrupt factor                   | address [H]    | request   | enable    | 1              | 0      |
| SIO1 transmit buffer empty         |                |           |           |                |        |
| signal is generated                | 0038           |           |           |                |        |
| SIO1 transmit complete             |                | QSIO1     | ESIO1     | P1SIO1         | P0SIO1 |
| signal is generated                |                | o QSIOT   | E3IO1     | F13101         | P03101 |
| SIO1 receive complete              |                |           |           |                |        |
| signal is generated                |                |           |           |                |        |
| Symbols (byte) of registers that   |                | IRQ2      | IF2       |                | 25     |
| contain interrupt processing flags |                | INQZ      | IE2       | I F            | -0     |
|                                    | Reference page | 17-14     | 17-19     | 17-            | -27    |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

#### 12.5 SIO6

The SIO6 has a UART mode and a synchronous mode. Timer 3 is used as a baud rate generator exclusively for SIO6.

Table 12-5 lists specifications of SIO6.

Table 12-5 SIO6 Specifications

|                         | UART mode                         | Synchronous mode                |  |  |
|-------------------------|-----------------------------------|---------------------------------|--|--|
| Data length             | Selectable as 7 or 8 bits         | Selectable as 7 or 8 bits       |  |  |
| Parity                  | Odd, even, none                   |                                 |  |  |
| Error service           | Parity, overrun, framing          | Overrun                         |  |  |
| Stop bit                | Selectable as 1 or 2 bits         |                                 |  |  |
| Factors that generate   | Transmit buffer empty, transmit   | Transmit buffer empty, transmit |  |  |
| interrupt requests      | complete, receive complete        | complete, receive complete      |  |  |
| Full-duplex             | Possible                          | Possible                        |  |  |
| communication           | Possible                          |                                 |  |  |
| Transmit-receive buffer | Both transmission and reception   | Both transmission and reception |  |  |
| Transmit-receive buller | data are double buffered          | data are double buffered        |  |  |
| Max. communication      | 1 975 Mbno                        | 7.5 Mbps                        |  |  |
| speed (f = 30 MHz)      | 1.875 Mbps                        | 7.5 Mbps                        |  |  |
|                         | LSB first                         | LSB first                       |  |  |
| Other                   | An external clock can be used for | Master mode/ slave mode         |  |  |
|                         | the UART baud rate                |                                 |  |  |

## 12.5.1 SIO6 Configuration

Figure 12-6 shows the SIO6 configuration.



BRG: Baud rate generator (timer 3) S6BUF: Transmit-receive buffer register ST6CON: SIO6 transmit control register

SR6CON: SIO6 receive control register S6STAT: SIO6 status register

1/n: 1/n frequency dividing counter

TXD6: SIO6 transmit data output pin (P15\_1) TXC6: SIO6 transmit clock I/O pin (P15\_3) RXD6: SIO6 receive data input pin (P15\_0)

RXC6: SIO6 receive clock I/O pin (P15\_2)

Figure 12-6 SIO6 Configuration

## 12.5.2 Description of SIO6 Registers

## (1) SIO6 transmit control register (ST6CON)

The SIO6 transmit control register (ST6CON) is a 7-bit register that controls operation of SIO6 transmission.

ST6CON can be read from and written to by the program. However, write operations are invalid for bit 2. If read, a value of "1" will always be obtained for bit 2.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ST6CON becomes 04H, the data length for SIO6 transmission is 8-bits, 2 stop bits are selected and the mode changes to UART mode with no parity.

The baud rate source is the same for transmission and reception. It is set by the receive control register (SR6CON) to be described later.

#### [Note]

If ST6CON is to be modified, make those changes after transmission is complete. If ST6CON is modified before transmission is completed, the current transmission and future transmissions will not be executed correctly.

Figure 12-7 shows the ST6CON configuration.

[Description of each bit]

• ST6MOD (bit 0)

ST6MOD specifies the transmission mode (UART or synchronous).

• ST6LN (bit 1)

ST6LN specifies the SIO6 transmit data length.

• ST6STB/ST6SLV (bit 3)

During the UART mode, ST6STB specifies the SIO6 stop bit length.

During the synchronous mode, ST6SLV specifies master or slave operation.

• ST6PEN (bit 4)

ST6PEN specifies whether there is parity during SIO6 transmission. (Only valid during the UART mode)

• ST6ODD (bit 5)

ST6ODD specifies the parity bit logic during SIO6 transmission. (Only valid during the UART mode)

• TR6MIE (bit 6)

TR6MIE specifies whether to use the SIO6 transmit buffer empty signal as an interrupt request signal.

• TR6NIE (bit 7)

TR6NIE specifies whether to use the SIO6 transmit complete signal as an interrupt request signal.



Figure 12-7 ST6CON Configuration

## (2) SIO6 receive control register (SR6CON)

The SIO6 receive control register (SR6CON) is an 8-bit register that controls operation of SIO6 reception.

SR6CON can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), SR6CON becomes 00H and SIO6 reception is disabled.

#### [Note]

If SR6CON is to be modified, first reset SR6REN (bit 7) to "0" and then implement the change. If SR6CON is modified before SR6REN (bit 7) is reset to "0", the current reception and future receptions will not be executed correctly.

Figure 12-8 shows the SR6CON configuration.

[Description of each bit]

• SR6MOD (bit 0)

SR6MOD specifies the SIO6 reception mode (UART or synchronous).

• SR6LN (bit 1)

SR6LN specifies the SIO6 receive data length.

• S6EXC (bit 2)

S6EXC specifies the baud rate clock to be used by SIO6 during the UART mode. (This clock is the same for both transmission and reception. The shift clock has a frequency 1/16th of the clock specified here.)

• SR6SLV (bit 3)

During the synchronous mode, ST6SLV specifies master or slave operation of SIO6. (Only valid during the synchronous mode)

• SR6PEN (bit 4)

SR6PEN specifies whether there is parity during SIO6 reception. (Only valid during the UART mode)

• SR6ODD (bit 5)

SR6ODD specifies the parity bit logic during SIO6 reception. (Only valid during the UART mode)

• RC6IE (bit 6)

RC6IE specifies whether to use the SIO6 receive complete signal as an interrupt request signal.

• SR6REN (bit 7)

SR6REN enables or disables SIO6 reception.



Figure 12-8 SR6CON Configuration

## (3) SIO6 status register (S6STAT)

The SIO6 status register (S6STAT) consists of 6 bits. Bits 0 through 2 save the SIO6 status (normal or error) after reception is completed. Bits 3 through 5 save the status of SIO6 at the start and completion of transmission and reception. However bits 0 through 2 are updated after the reception is completed.

S6STAT can be read from and written to by the program. However, write operations are invalid for bits 6 and 7. If read, a value of "0" will always be obtained for bits 6 and 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), S6STAT becomes 00H.

Figure 12-9 shows the S6STAT configuration.

## [Description of each bit]

• FERR6 (bit 0)

If the stop bit in the data received by SIO6 is "0", FERR6 is set to "1" (framing error). This bit is only valid during the UART mode.

• OERR6 (bit 1)

When the SIO6 reception is complete, if the previously received data has not been read by the program, OERR6 is set to "1" (overrun error).

• PERR6 (bit 2)

If the parity bit in the data received by SIO6 does not match the parity of the data, PERR6 is set to "1" (parity error). This bit is only valid during the UART mode.

• TR6EMP (bit 3)

If the SIO6 transmit buffer empty signal is generated, TR6EMP is set to "1".

• TR6END (bit 4)

If the SIO6 transmit complete signal is generated, TR6EMD is set to "1".

• RC6END (bit 5)

If the SIO6 receive complete signal is generated, RC6END is set to "1".

## [Note]

Once each bit of S6STAT is set to "1", the hardware does not reset the bits to "0". Therefore, reset the bits to "0" with the program.



Figure 12-9 S6STAT Configuration

## (4) SIO6 transmit-receive buffer register (S6BUF)

The SIO6 transmit-receive buffer register (S6BUF) is an 8-bit register that stores the transmit and receive data for serial port transmission and reception. Because S6BUF has a duplex configuration for transmission and reception, it operates as a transmission buffer when written to, and as a reception buffer when read from.

After the transmit data has been written to S6BUF, the transmit data is transferred to the transmit shift register and the transmit buffer empty signal is generated. At that time, SIO6 will begin transmission.

After reception is complete, the contents of the receive shift register are transferred to S6BUF and at that time, the receive complete signal is generated. The contents of S6BUF are saved until the next reception is completed.

During a 7-bit data reception, bit 7 of S6BUF is "1", and the 7 bits from bit 0 through bit 6 are the reception data.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the value of S6BUF is undefined.

#### (5) SIO6 transmit shift register, receive shift register

The transmit shift register and receive shift register are 8-bit shift registers that perform the actual shifting operation during transmission and reception.

The transmit shift register and receive shift register cannot be read from or written to by the program.

Table 12-6 lists SIO6 transmit-receive frame lengths.

ST6CON/SR6CON Transmit/Receive Frame Length ST6LN ST6MOD SR6LN SR6MOD ST6PEN SR6PEN ST6STB 4 5 6 7 8 9 10 11 12 [bit] 1 , START 8-bit data STOPSTOP 0 0 0 0 START 7-bit data STOP STOP 0 0 1 0 STOP 0 0 0 START 8-bit data 1 START 7-bit data STOP 0 1 1 0 PARITY STOP STOP START 8-bit data 0 1 0 0 PARITY STOP STOP START 7-bit data 1 0 1 0 START 8-bit data PARITY STOP 1 1 0 0 START 7-bit data PARITY STOP 1 1 0 8-bit data 0 1 7-bit data 1 1

Table 12-6 SIO6 Transmit-Receive Frame Lengths

#### 12.5.3 Example of SIO6-related Register Settings

## 12.5.3.1 UART Mode Settings

#### Transmit settings

#### (1) Port 15 mode register (P15IO)

If TXD6 (transmit data output) is to be used, set bit 1 (P15IO1) to "1" to configure that port as an output. If the baud rate clock is to be input externally, reset bit 2 (P15IO2) to "0" to configure that port as an input.

## (2) Port 15 secondary function control register (P15SF)

If TXD6 (transmit data output) is to be used, set bit 1 (P15SF1) to "1" to configure that port as a secondary function output. If the baud rate clock is to be input externally, specify with bit 2 (P15SF2) whether the input will be pulled-up.

#### (3) SIO6 transmit control register (ST6CON)

Reset bit 0 (ST6MOD) to "0" to change the mode to UART mode. Specify the transmit data length with bit 1 (ST6LN). Specify the stop bit length with bit 3 (ST6STB). Specify whether there is parity with bit 4 (ST6PEN). If parity is selected, specify the parity bit logic with bit 5 (ST6ODD). With bit 6 (TR6MIE), specify whether interrupt requests are enabled or disabled when a transmit buffer empty signal occurs. With bit 7 (TR6NIE), specify whether interrupt requests are enabled or disabled when a transmit complete signal occurs.

## (4) SIO6 receive control register (SR6CON)

Specify with bit 2 (S6EXC) whether the baud rate clock is internal (overflow output of timer 3) or external (RXC6).

# (5) SIO6 transmit-receive buffer register (S6BUF)

Transmission is started by writing the transmit data to S6BUF.

#### Receive settings

#### (1) Port 15 mode register (P15IO)

If RXD6 (receive data input) is to be used, reset bit 0 (P15IO0) to "0" to configure that port as an input. If the baud rate clock is to be input externally, reset bit 2 (P15IO2) to "0" to configure that port as an input.

# (2) Port 15 secondary function control register (P15SF)

Specify with bit 1 (P15SF0) whether the RXD6 pin will be pulled-up. If the baud rate clock is to be input externally, specify with bit 2 (P15SF2) whether the input will be pulled-up.

## (3) SIO6 receive control register (SR6CON)

Reset bit 0 (SR6MOD) to "0" to change the mode to UART mode. Specify the receive data length with bit 1 (SR6LN). Specify with bit 2 (S6EXC) whether the baud rate clock is internal (overflow output of timer 3) or external (RXC6). Specify whether there is parity with bit 4 (SR6PEN). If parity is selected, specify the parity bit logic with bit 5 (SR6ODD). With bit 6 (RC6IE), specify whether interrupt requests are enabled or disabled when a receive complete signal occurs. If bit 7 (SR6REN) is set to "1", reception is enabled and the reception operation is performed when data arrives.

# 12.5.3.2 Synchronous Mode Settings

## Transmit settings

# (1) Port 15 mode register (P15IO)

If TXD6 (transmit data output) is to be used, set bit 1 (P15IO1) to "1" to configure that port as an output. If the transmit clock is to be output externally (master mode), set bit 3 (P15IO3) to "1" to configure that port as an output. If the baud rate clock is to be input externally (slave mode), reset bit 3 (P15IO3) to "0" to configure that port as an input.

# (2) Port 15 secondary function control register (P15SF)

If TXD6 (transmit data output) is to be used, set bit 1 (P15SF1) to "1" to configure that port as a secondary function output. If the transmit clock is to be output externally (master mode), set bit 3 (P15SF3) to "1" to configure that port as a secondary function output. If the baud rate clock is to be input externally (slave mode), specify with bit 3 (P15SF3) whether the input will be pulled-up.

## (3) SIO6 transmit control register (ST6CON)

Set bit 0 (ST6MOD) to "1" to specify the mode to synchronous mode. Specify the transmit data length with bit 1 (ST6LN). Specify master or slave mode transmission with bit 3 (ST6STB). With bit 6 (TR6MIE), specify whether interrupt requests are enabled or disabled when a transmit buffer empty signal occurs. With bit 7 (TR6NIE), specify whether interrupt requests are enabled or disabled when a transmit complete signal occurs.

#### (4) SIO6 transmit-receive buffer register (S6BUF)

Transmission is started by writing the transmit data to S6BUF.

#### 12

# · Receive settings

### (1) Port 15 mode register (P15IO)

If RXD6 (receive data input) is to be used, reset bit 0 (P15IO0) to "0" to configure that port as an input. If the transmit clock is to be output externally (master mode), set bit 2 (P15IO2) to "1" to configure that port as an output. If the transmit clock is to be input externally (slave mode), reset bit 2 (P15IO2) to "0" to configure that port as an input.

# (2) Port 15 secondary function control register (P15SF)

Specify with bit 0 (P15SF0) whether the RXD6 pin will be pulled-up. If the transmit clock is to be output externally (master mode), set bit 2 (P15SF2) to "1" to configure that port as a secondary function output. If the transmit clock is to be input externally (slave mode), specify with bit 2 (P15SF2) whether the input will be pulled-up.

#### (3) SIO6 receive control register (SR6CON)

Set bit 0 (SR6MOD) to "1" to specify the mode to synchronous mode. Specify the receive data length with bit 1 (SR6LN). Specify the master or slave mode with bit 3 (SR6SLV). With bit 6 (RC6IE), specify whether interrupt requests are enabled or disabled when a receive complete signal occurs. If bit 7 (SR6REN) is set to "1", reception is enabled and the reception operation is performed when data arrives.

# 12.5.3.3 Baud Rate Generator (Timer 3) Settings

If overflow of timer 3 is selected for use as the baud rate clock, implement the following settings.

#### (1) General-purpose 8-bit timer 3 counter (TM3C)

Set the timer value that will be valid at the start of counting. When writing to TM3C, the same value will also be simultaneously and automatically written to the general-purpose 8-bit timer 3 register (TM3R).

# (2) General-purpose 8-bit timer 3 control register (TM3CON)

Bits 0 to 2 (TM3C0 to TM3C2) of this register specify the count clock for timer 3. If bit 3 (TM3RUN) is set to "1", timer 3 will begin counting. If reset to "0", timer 3 will halt counting.

#### [Equation to Calculate Baud Rate]

 $B = f_{(TM3)} \times 1/(256 - D) \times 1/n$  B: baud rate [bps]

f<sub>(TM3)</sub>: timer 3 input clock frequency [Hz]

D : reload value (0 to 255)n : 16 for the UART mode4 for the synchronous mode

# 12.5.4 SIO6 Interrupt

When any SIO6 interrupt factor occurs, the interrupt request flag (QSIO6) is set to "1". The interrupt request flag (QSIO6) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (ESIO6). The interrupt enable flag (ESIO6) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0SIO6 and P1SIO6). The interrupt priority setting flags (P0SIO6 and P1SIO6) are located in interrupt priority control register 6 (IP6).

Table 12-7 lists the vector address of the SIO6 interrupt factors and the interrupt processing flags.

Table 12-7 SIO6 Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector         | Interrupt | Interrupt | Priority level |        |
|------------------------------------|----------------|-----------|-----------|----------------|--------|
|                                    | address [H]    | request   | enable    | 1              | 0      |
| SIO6 transmit buffer empty         |                |           |           |                |        |
| signal is generated                | 003E           | QSIO6     | ESIO6     | P1SIO6         | P0SIO6 |
| SIO6 transmit complete             |                |           |           |                |        |
| signal is generated                |                |           |           |                |        |
| SIO6 receive complete              |                |           |           |                |        |
| signal is generated                |                |           |           |                |        |
| Symbols (byte) of registers that   |                | IRQ3      | IE3       | IP6            |        |
| contain interrupt processing flags |                |           |           |                |        |
|                                    | Reference page | 17-15     | 17-20     | 17-28          |        |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# 12.6 SIO1, SIO6 Operation

# 12.6.1 Transmit Operation

#### UART mode

Figure 12-10 shows the timing diagram of operation during UART transmission.

The clock pulse from the baud rate generator (timer 3 or timer 4) or from an external input is divided by 16 to generate the transmit shift clock.

If an external clock is to be used with the UART mode, input the clock to the receive clock I/O pin (RXCn) for SIOn. The externally input clock is processed as shown in figure 12-11, and is input to the 1/n dividing counter as the baud rate clock.

In synchronization with the transmit shift clock that has been generated, the transmission circuit controls transmission of the transmit data.

The SnBUF write signal (a signal that is output when an instruction to write to SnBUF is executed, for example "STB A, SnBUF") acts as a trigger to start transmission.

One CPU clock after the write signal is generated, transmit data in SnBUF is set in the transmit shift register. At this time, synchronized to the signal indicating the beginning of an instruction (M1S1), a transmit buffer empty signal is generated.

After the transmit data is set (after the fall of the data transfer signal to the transmit shift register), synchronized to the falling edge of the next transmit shift clock, the start bit is output from the transmit data output pin (TXDn). Thereafter, as specified by STnCON, the transmit data (LSB first), parity bit, and finally the stop bit are output to complete the transmission of one frame.

At this time, if the next transmit data has not been written to SnBUF, a transmit complete signal is generated in synchronization with M1S1, and the transmission is completed.

Because generation of the transmit shift clock is always unrelated to writes to SnBUF, from the time when transmit data is written to SnBUF until the start bit is output, there is a delay of a maximum of 16 baud rate clocks.

Because each of SIO1 and SIO6 has SnBUF and the transmit shift register which are designed in a duplex construction, during a transmission it is possible to write the next transmit data to SnBUF. If SnBUF is written to during a transmission, after the current one frame transmission is completed, the next transmit data will be automatically set in the transmit shift register, and the data transmission will continue. After one frame of data is transmit, if the next data to be transmit has been written to SnBUF, the transmit complete signal will not be generated.

Figure 12-14 shows the timing diagram of operation during continuous transmission.

# • Synchronous mode (SIO1, SIO6)

#### [Master mode]

Figure 12-12 shows the timing diagram of operation during master mode transmission.

The clock pulse from the baud rate generator (timer 4 for SIO1 timer 3 for SIO6) is divided by 4 to generate the transmit shift clock.

In synchronization with the transmit shift clock that has been generated, the transmission circuit controls transmission of the transmit data.

The SnBUF write signal (the signal that is output when an instruction to write to SnBUF is executed, for example "STB A, SnBUF") acts as a trigger to start transmission.

One CPU clock after the write signal is generated, transmit data in SnBUF is set in the transmit shift register. At this time, synchronized to the signal indicating the beginning of an instruction (M1S1), a transmit buffer empty signal is generated.

After the transmit data is set (after the fall of the data transfer signal to the transmit shift register), synchronized to the falling edge of the next transmit shift clock, the external output clock begins to be output from the transmit clock I/O pin (TXCn). At the same time, transmit data is output LSB first from the transmit data output pin (TXDn). Thereafter, as specified by STnCON and synchronized to the transmit shift clock, transmit data is output to complete the transmission of one frame.

At this time, if the next transmit data has not been written to SnBUF, a transmit complete signal is generated in synchronization with M1S1, and the transmission is completed.

TXDn changes at the falling edge of TXCn. Therefore, at the receive side, TXDn is fetched at the rising edge of TXCn.

Because generation of the transmit shift clock is always unrelated to writes to SnBUF, from the time when transmit data is written to SnBUF until the first data is output, there is a delay of a maximum of 4 baud rate clocks.

Because each of SIO1 and SIO6 has SnBUF and the transmit shift register which are designed in a duplex construction, during a transmission it is possible to write the next transmit data to SnBUF. If SnBUF is written to during a transmission, after the current one frame transmission is completed, the next transmit data will be automatically set in the transmit shift register, and the data transmission will continue. After one frame of data is transmit, if the next data to be transmit has been written to SnBUF, the transmit complete signal will not be generated.

Figure 12-14 shows the timing diagram of operation during continuous transmission.

# [Note]

During continuous transmission, there is a time lag of 1 bit between the current data transmission and the next data transmission, in which to set the next data. During this interval, TXDn is forced to a High level.

# [Slave mode]

Figure 12-13 shows the timing diagram of operation during slave mode transmission.

In the slave mode, the transmit clock is input from the transmit clock I/O pin (TXCn). This external input clock is detected with the edge of CPU clock to generate the transmit shift clock.

In synchronization with the transmit shift clock that has been generated, the transmission circuit controls transmission of the transmit data.

The SnBUF write signal (the signal that is output when an instruction to write to SnBUF is executed, for example "STB A, SnBUF") acts as a trigger to start transmission.

One CPU clock after the write signal is generated, transmit data in SnBUF is set in the transmit shift register. At this time, synchronized to the signal indicating the beginning of an instruction (M1S1), a transmit buffer empty signal is generated.

After the transmit data is set (after the fall of the data transfer signal to the transmit shift register), synchronized to the falling edge of the next transmit shift clock, the transmit data is output LSB first from the transmit data output pin (TXDn). Thereafter, as specified by STnCON and synchronized to the transmit shift clock, transmit data is output to complete the transmission of one frame.

At this time, if the next transmit data has not been written to SnBUF, a transmit complete signal is generated in synchronization with M1S1, and the transmission is completed.

TXDn changes at the falling edge of the transmit shift clock that has been generated from the detected edge of the externally input TXCn. Therefore, at the receive side, TXDn is fetched at the rising edge of TXCn.

Because each of SIO1 and SIO6 has SnBUF and the transmit shift register which are designed in a duplex construction, during a transmission it is possible to write the next transmit data to SnBUF. If SnBUF is written to during a transmission, after the current one frame transmission is completed, the next transmit data will be automatically set in the transmit shift register, and the data transmission will continue. After one frame of data is transmit, if the next data to be transmit has been written to SnBUF, the transmit complete signal will not be generated.

Figure 12-14 shows the timing diagram of operation during continuous transmission.

# [Note]

During continuous transmission, there is a time lag of 2 CPU clocks between the current data transmission and the data next transmission, in which to set the next data. During this interval, TXDn is forced to a High level. If an external clock is supplied, insert a margin of 2 or more CPU clocks between the current data transmission and the next data transmission.



Figure 12-10 Transmission Timing Diagram (UART Mode)

Figure 12-11 Timing Diagram of Baud Rate Clock Generation by External Clock (UART Mode, Transmission and Reception)



12-31



Figure 12-12 Transmission Timing Diagram (Synchronous Master Mode)



Figure 12-13 Transmission Timing Diagram (Synchronous Slave Mode)



Figure 12-14 Transmission Timing Diagram (During Continuous Transmission)

### 12.6.2 Receive Operation

#### UART mode

Figure 12-15 shows the timing diagram of operation during UART reception.

The clock pulse from the baud rate generator (timer 3 or timer 4) or from an external input is divided by 16 to generate the shift clock.

If an external clock is to be used with the UART mode, input the clock to the receive clock I/O pin (RXCn) for SIOn. The externally input clock is processed as shown in figure 12-11, and is input to the 1/n dividing counter as the baud rate clock.

The 1/n dividing circuit remains halted in its reset state until reception begins. The 7th, 8th and 9th pulses of the 1/16 divider (values 6, 7 and 8 of the baud rate (1/16) counter in figure 12-15) become the sampling clock for the receive data input pin (RXDn). The 10th pulse (value 9 of the baud rate (1/n) counter in figure 12-15) becomes the receive shift clock.

In synchronization with the receive shift clock, the reception circuit controls reception of the receive data.

A change in the receive data input pin (RXDn) from a High to Low level triggers the reception operation to start (at this time, SRnREN (bit 7) of SRnCON should be "1").

If the input signal to the receive data input pin (RXDn) is detected to have changed from a High to Low level, the 1/16 dividing counter that had been halted in its reset state now begins to operate. The start bit (L level) is sampled at the three sampling clocks of the 7th, 8th, and 9th pulses from the 1/16 dividing counter. If the start bit is at a Low level for two or more samples, it is judged to be valid. If not, the start bit is judged invalid, reception operation is initialized and then halted.

In a similar manner, receive data is sampled at the 7th, 8th, and 9th pulses from the 1/16 dividing counter. Data that is judged valid is shifted by the 10th clock, or in other words, by the receive shift clock, into the receive shift register as receive data. Thereafter, data reception continues as specified by SRnCON. The first stop bit (the 1st bit in the case of 2 stop bits) is received and the reception of one frame is completed.

At this time, if the received stop bit is "0", a framing error is issued. If the parity is incorrect, a parity error is issued. And, if the previously received data has not been read, an overrun error is issued (the previously received data will be overwritten).

However, at this time, the status register (SnSTAT) is not be updated of the detected error. Later, the contents of the receive shift register are transferred to SnBUF, a receive complete signal is generated in synchronization with M1S1 that indicates the beginning of the next instruction, and at the same timing, the status register (SnSTAT) is updated by the receive complete signal and each error signal. The series of receptions is completed.

### · Synchronous mode

#### [Master mode]

Figure 12-16 shows the timing diagram of operation during master mode reception.

The clock pulse from the baud rate generator (timer 4 for SIO1 and timer 3 for SIO6) is divided by 4 to generate the external output clock. The 3rd pulse of the 1/4 divider (value 2 of the baud rate (1/4) counter in figure 12-16) becomes the sampling clock for the receive data input pin (RXDn). The 4th pulse (value 3 of the baud rate (1/4) counter in figure 12-16) becomes the receive shift clock.

In synchronization with the receive shift clock, the reception circuit controls reception of the receive data.

The falling edge of the receive shift clock immediately after SRnREN (bit 7) of SRnCON is set to "1" triggers the reception operation to start and the external output clock is output from the receive clock I/O pin (RXCn). At the next receive shift clock, receive data that was sampled at the prior sampling clock is shifted into the receive shift register.

At the falling edge of the external output clock, the transmit side transmits data. That data is shifted into the receive side at the falling edge of the transmit shift clock. Receive data is sampled only once. Thereafter, data reception continues as specified by SRnCON. After the last receive shift clock is output, the contents of the receive shift register are transferred to SnBUF, and a receive complete signal is generated in synchronization with M1S1, the signal that indicates the beginning of an instruction. At this time, an overrun error will be generated if the previously received data has not been read (the previously received data will be overwritten).

Finally, SRnREN of SRnCON is automatically cleared to "0" to complete the reception series.

#### [Slave mode]

Figure 12-17 shows the timing diagram of operation during slave mode reception.

In the slave mode, the receive clock is input externally (from the receive clock I/O pin (RXCn)). This external input clock is detected with the edge of CPU clock to generate the receive shift clock.

In synchronization with the receive shift clock that has been generated, the reception circuit controls receiving the receive data.

Reception operation is triggered to begin when SRnREN (bit 7) of SRnCON is set to "1" and the external input clock is input to the receive clock I/O pin (RXCn).

While the external input clock is at a Low level, the value of the receive data input pin (RXDn) is sampled. The sampled receive data is shifted into the receive shift register at the next receive shift clock. Thereafter, data reception continues as specified by SRnCON. After the last receive data is shifted in, the contents of the receive shift register are transferred to SnBUF, and a receive complete signal is generated in synchronization with M1S1, the signal that indicates the beginning of an instruction. At this time, an overrun error will be generated if the previously received data has not been read (the previously received data will be overwritten). This completes a one frame reception.

In the slave mode, SRnREN is not automatically cleared to "0" after completing the reception. If the receive shift clock continues to be input, the receive operation will restart.



Figure 12-15 Reception Timing Diagram (UART Mode)





Figure 12-16 Reception Timing Diagram (Synchronous Master Mode)



Figure 12-17 Reception Timing Diagram (Synchronous Slave Mode)



#### 12.7 SIO4

SIO4 is an 8-bit auto transfer serial port used for clocked synchronous communication. Synchronized to the clock specified by the SIO4 control register (SIO4CON), SIO4 continuously transmits and receives 8 bits of data LSB first. When transmission and reception are complete, a transmit-receive interrupt is requested.

The maximum communication speed at f = 30 MHz is 5 Mbps.

#### 12.7.1 SIO4 Configuration

Figure 12-18 shows the SIO4 configuration.



SIO4CON: SIO4 control register FIFOCON: FIFO control register

SIN4: SIO4 serial input FIFO data register SOUT4: SIO4 serial output FIFO data register SIOCK4: SIO4 transmit-receive clock input pin (P10\_3)

SIOO4: SIO4 transmit data output pin (P10\_4) SIOI4: SIO4 receive data input pin (P10\_5)

Figure 12-18 SIO4 Configuration

# 12.7.2 Description of SIO4 Registers

### (1) SIO4 control register (SIO4CON)

The SIO4 control register (SIO4CON) is an 8-bit register that controls SIO4 operation.

SIO4CON can be read from and written to by the program. However, write operations are invalid for bit 7. If read, a value of "1" will always be obtained for bit 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), SIO4CON becomes 80H.

Figure 12-19 shows the SIO4CON configuration.

[Description of each bit]

- SIO4C0 to SIO4C2 (bits 0 to 2)
   During the master mode, SIO4C0 to SIO4C2 select SIO4 clock. In the slave mode, these bits are invalid.
- SIO4SL (bit 3)
   SIO4SL specifies master or slave operation of SIO4.
- TEN4 (bit 4)
   When TEN4 is set to "1", transmission and reception begin. When transmission and reception are completed, it is automatically reset to "0".
- ICK4 (bit 5) ICK4 specifies whether there is a SIO4 interval clock. (Only valid during the master mode)
- BUSY4 (bit 6)
   BUSY4 indicates a transfer operation status. This can be used to determine the waiting time from setting TEN4 to "1" to transmission and reception start at multi-byte continuous transfer in the B mode of FIFO mode selection using SIO4 and SIO5 alternatively.



When read, its value will be "1".

Figure 12-19 SIO4CON Configuration

# (2) FIFO control register (FIFOCON)

The FIFO control register (FIFOCON) controls operation of the FIFO registers that are internal to SIO4 and SIO5.

FIFOCON can be read from and written to by the program. However, write operations to bits 0, 1, 4 and 5 are invalid.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the value of FIFOCON becomes 11H.

Figure 12-20 shows the FIFOCON configuration.

# [Description of each bit]

• EMP4 (bit 0)

EMP4 indicates the empty status of the SIO4's FIFO register. Due to SRES operation and at reset, the FIFO is cleared and enters the empty state. If all data in the FIFO register is read, the empty state is entered.

• FUL4 (bit 1)

FUL4 indicates the full status of the SIO4's FIFO register. If 32 bytes of data are completely stored in the FIFO register, the FIFO full state (FUL = 1) is entered.

• ORE4 (bit 2)

ORE4 indicates the overflow status of the SIO4's FIFO register (only valid during the slave mode). After completing reception of the number of bytes that were written to the FIFO register before the transfer, if an external clock is input, ORE4 is set to "1". In this case, because the FIFO register contents cannot be guaranteed, it is necessary to transfer the data again. ORE4 can be reset to "0" by setting SRE4 (bit 3) to "1".

• SRE4 (bit 3)

SRE4 initializes SIO4. If SRE4 is set to "1", SIO4 will be initialized. After initialization, SRE4 is automatically reset to "0".

• EMP5 (bit 4)

EMP5 indicates the empty status of the SIO5's FIFO register. Due to SRES operation and at reset, the FIFO is cleared and enters the empty state. If all data in the FIFO register is read, the empty state is entered.

• FUL5 (bit 5)

FUL5 indicates the full status of the SIO5's FIFO register. If 32 bytes of data are completely stored in the FIFO register, the FIFO full state (FUL = 1) is entered.

• ORE5 (bit 6)

ORE5 indicates the overflow status of the SIO5's FIFO register (only valid during the slave mode). After completing reception of the number of bytes that ware written to the FIFO register before the transfer, if an external clock is input, ORE5 is set to "1". In this case, because the FIFO register contents cannot be guaranteed, it is necessary to transfer the data again. ORE5 can be reset to "0" by setting SRE5 (bit 7) to "1".

• SRE5 (bit 7)

SRE5 initializes SIO5. If SRE5 is set to "1", SIO5 will be initialized. After initialization, SRE5 is automatically reset to "0".



monroad, no valdo viii

Figure 12-20 FIFOCON Configuration

# (3) Serial input FIFO data register (SIN4)

The serial input FIFO data register (SIN4) is used to read 8-bit data received from the SIO pin. Since SIN4 is read-only, do not attempt to write to this register.

When 1 byte of received data has been gathered in the shift register, it is automatically loaded into the FIFO register. When transfer of the specified number of bytes is complete, an interrupt is generated. After the interrupt is generated, by reading SIN4, data can be read in order from the earliest received data. Because incorrect transmission or reception will occur if SIN4 is read during serial transmission or reception, do not attempt to read SIN4 while a transmission or reception is in progress.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of SIN4 are undefined.

# (4) Serial output FIFO data register (SOUT4)

The serial output FIFO data register (SOUT4) is used to write the 8-bit serial data to be output from the SIOO4 pin. Since SOUT4 is write-only, do not attempt to read this register.

After data written to the SOUT4 register has been stored in the FIFO register, the start of transmission or reception causes that data to be sequentially loaded into a shift register.

Because incorrect transmission or reception will occur if SOUT4 is written to during serial transmission or reception, do not attempt to write to SOUT4 while a transmission or reception is in progress.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of SOUT 4 are undefined.

### 12.7.3 Example of SIO4-related Register Settings

# · Master mode settings

# (1) Port 10 mode register (P10IO)

If SIOCK4 (clock output) is to be used, set bit 3 (P10IO3) to "1" to configure the port as an output. Also if SIOO4 (transmit data output) is to be used during transmission, set bit 4 (P10IO4) to "1" to configure the port as an output, and if SIOI4 (receive data input) is to be used during reception, reset bit 5 (P10IO5) to "0" to configure the port as an input.

### (2) Port 10 secondary function control register (P10SF)

If SIOCK4 (clock output) is to be used, set bit 3 (P10IO3) to "1" to configure the port as a secondary function output. Also, if SIOO4 (transmit data output) is to be used during transmission, set bit 4 (P10SF4) to "1" to configure the port as a secondary function output, and if SIOI4 (receive data input) is to be used during reception, reset bit 5 (P10SF5) to "0" to configure the port as a secondary function input.

# (3) Serial output FIFO data register (SOUT4)

Write transmit data to SOUT4 (serial output FIFO data register).

# [Note]

Writing to SOUT4 register and reading SIN4 are disabled during transmission or reception. It is necessary to write dummy data of transmission bytes beforehand for only reception, and it is necessary to read dummy data for transmission bytes after transmission only for transmission.

# (4) SIO4 control register (SIO4CON)

Set SIO4 clock with bits 0 to 2 (SIO4C0 to SIO4C2). Reset bit 3 (SIO4SL) to "0" to set master mode. Specify whether there is an interval clock with bit 5 (ICK4). Transmission and reception are started by setting bit 4 (TEN4) to "1".

# Slave mode settings

#### (1) Port 10 mode register (P10IO)

If SIOCK4 (clock output) is to be used, reset bit 3 (P10IO3) to "0" to configure the port as an input. Also, if SIOO4 (transmit data output) is to be used during transmission, set bit 4 (P10IO4) to "1" to configure the port as an output, and if SIOI4 (receive data input) is to be used during reception, reset bit 5 (P10IO5) to "0" to configure the port as an input.

### (2) Port 10 secondary function control register (P10SF)

If SIOCK4 (clock output) is to be used, reset bit 3 (P10IO3) to "0" to configure the port as a secondary function input. Also, if SIOO4 (transmit data output) is to be used during transmission, set bit 4 (P10SF4) to "1" to configure the port as a secondary function output, and if SIOI4 (receive data input) is to be used during reception, reset bit 5 (P10SF5) to "0" to configure the port as a secondary function input.

# (3) Serial output FIFO data register (SOUT4)

Write transmit data to SOUT4 (serial output FIFO data register).

#### [Note]

Writing to SOUT4 register is disabled during transmission or reception. It is necessary to write dummy data of transmission bytes beforehand for only reception.

### (4) SIO4 control register (SIO4CON)

SIO4 clock settings and specification of whether there is an interval clock with bit 5 (ICK4) are invalid. Set bit 3 (SIO4SL) to "1" to set slave mode. Transmission and reception are started by setting bit 4 (TEN4) to "1".

# 12.7.4 SIO4 Interrupt

When the SIO4 interrupt factor occurs, the interrupt request flag (QSIO4) is set to "1". The interrupt request flag (QSIO4) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (ESIO4). The interrupt enable flag (ESIO4) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0SIO4 and P1SIO4). The interrupt priority setting flags (P0SIO4 and P1SIO4) are located in interrupt priority control register 6 (IP6).

Table 12-8 lists the vector address of the SIO4 interrupt factor and the interrupt processing flags.

Table 12-8 SIO4 Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector         | Interrupt | Interrupt | Priority level |        |
|------------------------------------|----------------|-----------|-----------|----------------|--------|
|                                    | address [H]    | request   | enable    | 1              | 0      |
| SIO4 transmit-receive              | 0040           | QSIO4     | ESIO4     | P1SIO4         | P0SIO4 |
| complete signal is generated       |                |           |           |                |        |
| Symbols (byte) of registers that   |                | IRQ3      | IE3       | IP6            |        |
| contain interrupt processing flags |                |           |           |                |        |
|                                    | Reference page | 17-15     | 17-20     | 17-28          |        |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# 12.7.5 SIO4 Operation

SIO4 can select the master mode or slave mode, and can transfer a maximum of 32-byte transmit data continuyously.

In the master mode, the clock selected by bits 2 to 0 of SIO4CON is SIO4 clock. The SIO4 clock is output from the SIOCK4 pin.

In the slave mode, the clock input from the SIOCK4 pin is the SIO4 clock.

In both the master and slave modes, synchronized with the falling edge of the SIO4 clock, SIO4 outputs serial-out data from the SIO04 pin. Synchronized with the rising edge of the SIO4 clock, serial-in data is input from the SIO14 pin.

It is assumed that external devices change the serial-in data at the falling edge of the SIO4 clock and fetch the serial-out data at the rising edge of the SIO4 clock. Communication is executed in an LSB first mode.

Transfer operation is started by setting bit 4 (TEN4) of SIO4CON to "1" after writing transmit data to FIFO. When transfer is completed, bit TEN4 is reset to "0" and interrupt request flag (QSIO4) is set to "1" at the beginning of the next instruction (M1S1).

If bit TEN4 is reset to "0" during transfer, transmission and reception are immediately interrupted and SIO4 is initialized. The contents previously transferred are not assured. In the slave mode, set bit TEN4 to "1" when the SIOCK4 pin is at a high level to start transfer.

Figure 12-21 shows the timing of SIO4 operation during continuous transmission.



#### 12.8 SIO5

SIO5 is an 8-bit auto transfer serial port used for clocked synchronous communication. Synchronized to the clock specified by the SIO5 control register (SIO5CON), SIO5 continuously transmits and receives 8 bits of data in an LSB first mode. When transmission and reception are complete, a transmit-receive interrupt is requested.

The maximum communication speed at f = 30 MHz is 5 Mbps.

#### 12.8.1 SIO5 Configuration

Figure 12-22 shows the SIO5 configuration.



SIO5CON: SIO5 control register FIFOCON: FIFO control register

SIN5: SIO5 serial input FIFO data register SOUT5: SIO5 serial output FIFO data register SIOCK5: SIO5 transmit-receive clock input pin (P14\_0)

SIOO5: SIO5 transmit data output pin (P14\_1) SIOI5: SIO5 receive data input pin (P14\_2)

Figure 12-22 SIO5 Configuration

# 12.8.2 Description of SIO5 Registers

#### (1) SIO5 control register (SIO5CON)

The SIO5 control register (SIO5CON) is an 8-bit register that controls SIO5 operation.

SIO5CON can be read from and written to by the program. However, write operations are invalid for bit 7. If read, a value of "1" will always be obtained for bit 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), SIO5CON becomes 80H.

Figure 12-23 shows the SIO5CON configuration.

[Description of each bit]

- SIO5C0 to SIO5C2 (bits0 to 2)
   During the master mode, SIO5C0 to SIO5C2 select SIO5 clock. In the slave mode, these bits are invalid.
- SIO5SL (bit 3)
   SIO5SL specifies master or slave operation of SIO5.
- TEN5 (bit 4)
   When TEN5 is set to "1", transmission and reception begin. When transmission and reception are completed, it is automatically reset to "0".
- ICK5 (bit 5)
  ICK5 specifies whether there is a SIO5 interval clock. (Only valid during the master mode)
- BUSY5 (bit 6)
  BUSY5 indicates a transfer operation status. This can be used to determine the waiting time from setting TEN5 to "1" to transmission and reception start at multi-byte continuous transfer using SIO4 and SIO5 alternatively.



Figure 12-23 SIO5CON Configuration

# (2) Serial input FIFO data register (SIN5)

The serial input FIFO data register (SIN5) is used to read 8-bit serial data received from the SIO pin. Since SIN5 is read-only, do not attempt to write to this register.

When 1 byte of received data has been gathered in the shift register, it is automatically loaded into the FIFO register. When transfer of the specified number of bytes is complete, an interrupt is generated. After the interrupt is generated, by reading SIN5, data can be read in order from the earliest received data. Because incorrect transmission or reception will occur if SIN5 is read during serial transmission or reception, do not attempt to read SIN5 while a transmission or reception is in progress.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of SIN5 are undefined.

### (3) Serial output FIFO data register (SOUT5)

The serial output FIFO data register (SOUT5) is used to write the 8-bit serial data to be output from the SIOO5 pin. Since SOUT5 is write-only, do not attempt to read this register. After data written to the SOUT5 register has been stored in the FIFO register, the start of transmission or reception causes that data to be sequentially loaded into a shift register. Because incorrect transmission or reception will occur if SOUT5 is written to during serial transmission or reception, do not attempt to write to SOUT5 while a transmission or reception is in progress.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the contents of SOUT5 are undefined.

#### (4) FIFO mode control register (FIFOMOD)

The FIFO mode control register (FIFOMOD) is a 2-bit register that specifies the mode of combined SIO4 and SIO5 usage. However, write operations to bits 2 through 7 are invalid. If bits 2 through 7 are read, a value of "1" will always be obtained.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), FIFOMOD becomes FCH.

Bits 0 and 1 (FMOD0, FMOD1) select the mode of combined SIO4 and SIO5 usage. Change these flags when neither SIO4 nor SIO5 is transferring data.

#### 1) A mode

This mode operates SIO4 and SIO5 independently.

# 2) B mode

This mode alternates usage of SIO4 and SIO5 through the SIO4 port interface to consecutively transfer multiple bytes of data without limitation due to the number of FIFO stages. In this mode, operation of only master mode transmission and reception is possible. In this mode, while a transfer is in progress for one SIO, even if the TEN flag of the other SIO is set, that SIO's transfer will wait until the first SIO transfer is completed. After the first SIO transfer is completed, the other SIO transfer will automatically start. This provides for uninterrupted transfer.

In this mode, be sure to alternate usage of SIO4 and SIO5. For example, if SIO4 $\rightarrow$ SIO5 $\rightarrow$ SIO4 was used, then use SIO5 $\rightarrow$ SIO4 $\rightarrow$ SIO5 next. If B mode usage is intermixed with other modes, for example, if SIO5 $\rightarrow$ SIO4 $\rightarrow$ SIO5 (B mode) is used, after setting and using another mode, upon returning to the B mode, use SIO4 $\rightarrow$ SIO5 $\rightarrow$ SIO4 as the next sequence.

Interval clock settings (ICK) are invalid in this mode.

#### 3) C mode

Via the SIO5 port interface, this mode can monitor the SIO4 transfer operation performed through the SIO4 interface.

SIO5 itself cannot be used with this mode.

#### 4) D mode

Via the SIO4 port interface, this mode can monitor the SIO4 transfer operation performed through the SIO5 interface.

SIO5 itself cannot be used with this mode.

Using the C or D modes, two systems of port interfaces can be connected to SIO4. Using the A or D modes, two systems of SIOs (SIO4/SIO5) can be connected to the single SIO4 port interface.

Figure 12-24 shows the FIFOMOD configuration and Figure 12-25 shows the B, C, and D mode configurations.



"—" indicates a nonexistent bit. When read, its value will be "0."

Figure 12-24 FIFOMOD Configuration



Figure 12-25 Mode Configuration

### 12.8.3 Example of SIO5-related Register Settings

#### · Master mode settings

# (1) Port 14 mode register (P14IO)

If SIOCK5 (clock output) is to be used, set bit 0 (P14IO0) to "1" to configure the port as an output. Also, if SIOO5 (transmit data output) is to be used during transmission, set bit 1 (P14IO1) to "1" to configure the port as an output, and if SIOI5 (receive data input) is to be used during reception, reset bit 2 (P14IO2) to "0" to configure the port as an input.

### (2) Port 14 secondary function control register (P14SF)

If SIOCK5 (clock output) is to be used, set bit 0 (P14IO0) to "1" to configure the port as a secondary function output. Also, if SIOO5 (transmit data output) is to be used during transmission, set bit 1 (P14SF1) to "1" to configure the port as a secondary function output, and if SIOI5 (receive data input) is to be used during reception, reset bit 2 (P14SF2) to "0" to configure the port as a secondary function input.

# (3) Serial output FIFO data register (SOUT5)

Write transmit data to SOUT5 (serial output FIFO data register).

# [Note]

Writing to SOUT5 register is disabled during transmission or reception. It is necessary to write dummy data of transmission bytes beforehand for only reception.

# (4) SIO5 control register (SIO5CON)

Set SIO5 clock with bits 0 to 2 (SIO5C0 to SIO5C2). Reset bit 3 (SIO5SL) to "0" to set master mode. Specify whether there is an interval clock with bit 5 (ICK5). Transmission and reception are started by setting bit 5 (TEN5) to "1".

# · Slave mode settings

### (1) Port 14 mode register (P14IO)

If SIOCK5 (clock output) is to be used, reset bit 0 (P14IO0) to "0" to configure the port as an input. Also, if SIOO5 (transmit data output) is to be used during transmission, set bit 1 (P14IO1) to "1" to configure the port as an output, and if SIOI5 (receive data input) is to be used during reception, reset bit 2 (P14IO2) to "0" to configure the port as an input.

### (2) Port 14 secondary function control register (P14SF)

If SIOCK5 (clock output) is to be used, reset bit 0 (P14IO0) to "0" to configure the port as a secondary function input. Also, if SIOO5 (transmit data output) is to be used during transmission, set bit 1 (P14SF1) to "1" to configure the port as a secondary function output, and if SIOI5 (receive data input) is to be used during reception, reset bit 2 (P14SF2) to "0" to configure the port as a secondary function input.

#### (3) Serial output FIFO data register (SOUT5)

Write transmit data to SOUT5 (serial output FIFO data register).

### [Note]

Writing to SOUT5 register is disabled during transmission or reception. Reading SIN5 is also disabled. It is necessary to write dummy data of transmission bytes beforehand for only reception, and it is necessary to read dummy data for transmission bytes after transmission only for transmission.

# (4) SIO5 control register (SIO5CON)

SIO5 clock settings and specification of whether there is an interval clock with bit 5 (ICK5) are invalid. Set bit 3 (SIO5SL) to "1" to set slave mode. Transmission and reception are started by setting bit 4 (TEN5) to "1".

# 12.8.4 SIO5 Interrupt

When the SIO5 interrupt factor occurs, the interrupt request flag (QSIO5) is set to "1". The interrupt request flag (QSIO5) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (ESIO5). The interrupt enable flag (ESIO5) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0SIO5 and P1SIO5). The interrupt priority setting flags (P0SIO5 and P1SIO5) are located in interrupt priority control register 6 (IP6).

Table 12-9 lists the vector address of the SIO5 interrupt factor and the interrupt processing flags.

Table 12-9 SIO5 Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector         | Interrupt | Interrupt | Priority level |        |
|------------------------------------|----------------|-----------|-----------|----------------|--------|
|                                    | address [H]    | request   | enable    | 1              | 0      |
| SIO5 transmit-receive              | 003C           | QSIO5     | ESIO5     | P1SIO5         | P0SIO5 |
| complete signal is generated       |                |           |           |                |        |
| Symbols (byte) of registers that   |                | IRQ3      | IE3       | IP6            |        |
| contain interrupt processing flags |                |           |           |                |        |
|                                    | Reference page | 17-15     | 17-20     | 17-28          |        |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

# 12.8.5 SIO5 Operation

SIO5 can select the master mode or slave mode, and can transfer a maximum of 32-byte transmit data continuously.

In the master mode, the clock selected by bits 2 to 0 of SIO5CON is SIO5 clock. The SIO5 clock is output from the SIOCK5 pin.

In the slave mode, the clock input from the SIOCK5 pin is the SIO5 clock.

In both the master and slave modes, synchronized with the falling edge of the SIO5 clock, SIO5 outputs serial-out data from the SIO05 pin. Synchronized with the rising edge of the SIO5 clock, serial-in data is input from the SIO15 pin.

It is assumed that external devices change the serial-in data at the falling edge of the SIO5 clock and fetch the serial-out data at the rising edge of the SIO5 clock. Communication is executed in an LSB first mode.

Transfer operation is started by setting bit 4 (TEN5) of SIO5CON to "1" after writing transmit data to FIFO. When transfer is completed, bit TEN5 is reset to "0" and interrupt request flag (QSIO5) is set to "1" at the beginning of the next instruction (M1S1).

If bit TEN5 is reset to "0" during transfer, transmission and reception are immediately interrupted and SIO5 is initialized. The contents previously transferred are not assured. In the slave mode, set bit TEN5 to "1" when the SIOCK5 pin is at a high level to start transfer.

Figure 12-26 shows the timing of SIO5 operation during continuous transmission.

TEN5 TINT T<sub>CLK</sub> SIOCK5 D119 \D120 \D121 \D122 SIOO5 D0 D1 D2 D3 D5 D6 D7 D8 D9 D10 D11 D12 D13 X D14 D15 D4 SIOI5 D7 D8 D9 D10 ( D11 ) D12 | D13 | D14 | D15 D0 D1 D2 D3 D4 D5 D6 `D119 | D120 | D121 | D122 D127 Contents of receive data to be written to FIFO last Contents of receive data to be written to FIFO first

## Chapter 13

# A/D Converter Functions

## 13. A/D Converter Functions

### 13.1 Overview

The MSM66577 family has an internal 8-channel A/D converter with 10-bit resolution.

The A/D converter can operate in a scan mode that sequentially converts several selected channels, or in a select mode that converts one selected channel.

A successive comparison method with a sample and hold function is used to convert analog quantities to digital quantities.

## 13.2 A/D Converter Configuration

Figure 13-1 shows the A/D converter configuration.



Al0 to Al7: analog input pins (P12\_0 to P12\_7) ADR00 to ADR07: A/D result register (10 bits) ADINT0: A/D interrupt control register 0 ADCON0H: A/D control register 0H ADCON0L: A/D control register 0L

AGND: analog GND pin

V<sub>REF</sub>: analog reference voltage pin

Figure 13-1 A/D Converter Configuration

## 13.3 A/D Converter Registers

Table 13-1 lists a summary of SFRs for control of the A/D converter.

Table 13-1 Summary of SFRs for A/D Converter Control

| Address | Name                             | Symbol  | Symbol  | R/W  | 8/16      | Initial    | Reference |
|---------|----------------------------------|---------|---------|------|-----------|------------|-----------|
| [H]     | Name                             | (byte)  | (word)  | H/VV | Operation | value [H]  | page      |
| 009C☆   | A/D control register 0L          | ADCON0L | _       | R/W  | 8         | 80         | 13-3      |
| 009D☆   | A/D control register 0H          | ADCON0H | _       | R/W  | 8         | 00         | 13-5      |
| 009E☆   | A/D interrupt control register 0 | ADINT0  |         | R/W  | 8         | F0         | 13-7      |
| 00A0    | A/D recult register 00           | _       | ADR00   | R    | 16        | Undefined  | 13-8      |
| 00A1    | A/D result register 00           | _       | ADRUU   | n    | 10        | Undelined  | 13-6      |
| 00A2    | A/D recult register 01           | _       | ADR01   | R    | 16        | Undefined  | 13-8      |
| 00A3    | A/D result register 01           | _       | ADRUI   | n    | 16        | Undelined  | 13-0      |
| 00A4    | A/D recult register 00           | _       | ADR02   | R    | 16        | Undefined  | 13-8      |
| 00A5    | A/D result register 02           | _       | ADNUZ N | 10   | Ondelined | 10-0       |           |
| 00A6    | A/D regult register 02           | _       | ADR03   | R    | 16        | Undefined  | 13-8      |
| 00A7    | A/D result register 03           |         | ADNUS   | n    |           | Ondelined  |           |
| 8A00    | A/D result register 04           | _       | ADR04   | R    | 16        | Undefined  | 13-8      |
| 00A9    | A/D result register 04           | _       | ADNU4   | n    | 10        | Ondenned   | 13-6      |
| 00AA    | A/D regult register 05           | -       | ADR05   | R    | 16        | Undefined  | 13-8      |
| 00AB    | A/D result register 05           | _       | ADNUS   | n    | 10        | Ondelined  | 13-6      |
| 00AC    | A/D regult register 06           | _       | ADR06   | R    | 16        | Undefined  | 13-8      |
| 00AD    | A/D result register 06           | _       | ADRUG   | n    | 10        | Unidelined | 13-6      |
| 00AE    | A/D regult register 07           |         | ADD07   | R    | 2 40      | Undofined  | 13-8      |
| 00AF    | A/D result register 07           | _       | ADR07   | ĸ    | 16        | Undefined  | 13-0      |

## [Notes]

- 1. Addresses are not consecutive in some places.
- 2. A star (☆) in the address column indicates a missing bit.
- 3. Do not write to ADR00 through ADR07. If written to, the contents of all the registers from ADR00 through ADR07 may be overwritten.
- 4. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

## 13.3.1 Description of A/D Converter Registers

## (1) A/D control register 0L (ADCON0L)

A/D control register 0L (ADCON0L) consists of 6 bits and specifies settings for the scan mode.

ADCONOL can be read from and written to by the program. However, write operations are invalid for bit 7. Also, if bit 3 is to be written to, a value of "0" must be written. If read, bit 3 is always "0" and bit 7 is always "1".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ADCON0L becomes 80H.

Figure 13-2 shows the ADCON0L configuration.

## [Description of each bit]

• ADSNM00 to ADSNM02 (bits 0 to 2)

ADSNM00 to ADSNM02 specify the scan channels of the scan mode.

Change the scan channels while the A/D converter is halted.

Changes of the scan channels are valid only when ADRUN0 (bit 4) is "0".

• ADRUN0 (bit 4)

ADRUN0 starts and stops A/D conversion in the scan mode.

If set to "1", A/D conversion will begin. If reset to "0", conversion will be stopped. The ADRUNO bit specifies to operate or to halt A/D conversion and is not a status flag indicating whether conversion is in progress or is halted.

• SNEX0 (bit 5)

SNEX0 specifies the factor that activates A/D conversion in the scan mode.

When SNEX0 is "0", after A/D conversion of the previous channel is complete, conversion of the next channel begins. When SNEX0 is "1", after A/D conversion of the previous channel is complete, 1 channel of A/D conversion is performed for each valid edge of the signal at the external interrupt input pin (EXINT1).

• SCNC0 (bit 6)

SCNC0 specifies the operating mode after one cycle of scanning.

When SCNC0 is "0", after one cycle of the specified scanning channels, A/D conversion starts again at the first channel.

When SCNC0 is "1", after one cycle of the specified scanning channels, A/D conversion is stopped.

If used in the "SCNC0 = 1" mode, A/D conversion is reactivated by resetting to "0" the INTSN0 flag that is located in ADINT0 and indicates when one cycle of scanning is complete. (Control with the ADRUN0 bit is unnecessary. With ADRUN0 set to "1", A/D conversion can be activated by resetting INTSN0 to "0".)

If the mode is to be switched to "SCNC0 = 0" (the "after one cycle, start the next conversion" mode), reactivate the A/D conversion by resetting SCNC0 to "0". (Control with the ADRUN0 bit is unnecessary.)

#### [Note]

If used in the "after one cycle of scanning, stop the conversion" mode, A/D conversion can not be reactivated by resetting to "0" and then setting to "1" the ADRUN0 bit.



<sup>&</sup>quot;—" indicates a nonexistent bit. When read, its value will be "1."

Figure 13-2 ADCON0L Configuration

<sup>&</sup>quot;0" indicates that this bit must be written as "0." When read, its value will be "0."

## (2) A/D control register 0H (ADCON0H)

ADCON0H is a 7-bit register that mainly controls the select mode of the A/D converter.

ADCON0H can be read from and written to by the program. However, if bit 3 is to be written to, a value of "0" must be written. If read, bit 3 is always "0".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ADCON0H becomes 00H.

Figure 13-3 shows the ADCON0H configuration.

[Description of each bit]

- ADSTM00 to ADSTM02 (bits 0 to 2)
   ADSTM00 to ADSTM02 specify the A/D conversion channel of the select mode.
  - Change the A/D conversion channel of the select mode while the A/D converter is halted. Changes of the conversion channel of the select mode are valid only when STS0 (bit 4) is "0".
- STS0 (bit 4)
  - STS0 starts and stops A/D conversion in the select mode.
  - If set to "1", A/D conversion will begin. If reset to "0", the conversion will be halted. When A/D conversion in the select mode is completed, STS0 is automatically reset to "0" by the hardware.
- ADTM00 to ADTM02 (bits 5 to 7)
  - ADTM00 and ADTM01 specify the number of clocks required for the A/D conversion of 1 channel.
  - Select an appropriate number of A/D conversion clocks based on the impedance of the analog input signal source and the frequency of the source.
  - For further details, refer to Section 13.5, "Notes Regarding Usage of A/D Converter". During A/D conversion, changes to the number of clocks will be ignored.

|          | 7      | 6 | 5 | 4    | 3   | 2       | 1 |   | 0 |          |     | 24d  | ress: 009D [H]                  |
|----------|--------|---|---|------|-----|---------|---|---|---|----------|-----|------|---------------------------------|
| ADCON0H  | ADTM02 |   |   | STS0 | "0" | ADSTM02 |   |   |   | ı        |     |      | cess: R/W                       |
| At reset | 0      | 0 | 0 | 0    | 0   | 0       | 0 | ) | 0 | ΑΓ       | STN | M0   |                                 |
|          |        |   |   |      |     |         |   |   |   | 2        | 1   | 0    | A/D select channel              |
|          |        |   |   |      |     |         |   |   |   | 0        | 0   | 0    | ch0                             |
|          |        |   |   |      |     |         |   |   |   | 0        | 0   | 1    | ch1                             |
|          |        |   |   |      |     |         |   |   |   | 0        | 1   | 0    | ch2                             |
|          |        |   |   |      |     |         |   |   |   | 0        | 1   | 1    | ch3                             |
|          |        |   |   |      |     |         |   |   | · | 1        | 0   | 0    | ch4                             |
|          |        |   |   |      |     |         |   |   |   | 1        | 0   | 1    | ch5                             |
|          |        |   |   |      |     |         |   |   |   | 1        | 1   | 0    | ch6                             |
|          |        |   |   |      |     |         |   |   |   | 1        | 1   | 1    | ch7                             |
|          |        |   |   |      |     |         |   |   |   | 0        | Sto | n c  | elect mode A/D conversion       |
|          |        |   |   |      |     |         |   |   |   | 1        |     | •    | te select mode A/D conversion   |
|          |        |   |   |      |     |         |   |   |   | _        | ОР  | Ciai | e select mode / v b conversion  |
|          |        |   |   |      |     |         |   |   |   | $\vdash$ | DTM |      | Number of A/D conversion clocks |
|          |        |   |   |      |     |         |   |   |   | 2        | 1   | 0    | for 1 channel (when f = 30 MHz) |
|          |        |   |   |      |     |         |   |   |   | 0        | 0   | 0    | 1536 CPUCLK (51.2 μs)           |
|          |        |   |   |      |     |         |   |   |   | 0        | 0   | 1    | 1024 CPUCLK (34.1 μs)           |
|          |        |   |   |      |     |         |   |   |   | 0        | 1   | 0    | 768 CPUCLK (25.6 μs)            |
|          |        |   |   |      |     |         |   |   |   | 0        | 1   | 1    | 512 CPUCLK (17.1 μs)            |
|          |        |   |   |      |     |         |   |   |   | 1        | 0   | 0    | 384 CPUCLK (12.8 μs)            |
|          |        |   |   |      |     |         |   |   |   | 1        | 0   | 1    | 256 CPUCLK (8.5 μs)             |
|          |        |   |   |      |     |         |   |   |   | 1        | 1   | 0    | 192 CPUCLK (6.4 μs)             |
|          |        |   |   |      |     |         |   |   |   | 1        | 1   | 1    | 128 CPUCLK (4.3 μs)             |

<sup>&</sup>quot;0" indicates that this bit must be written as "0." When read, its value will be "0."  $\,$ 

Figure 13-3 ADCON0H Configuration

## (3) A/D interrupt control register (ADINT0)

ADINT0 is a 4-bit register that mainly controls the generation of interrupt requests by the A/D converter.

ADINTO can be read from and written to by the program. However, write operations are invalid for bits 4 through 7. If read, a value of "1" will always be obtained for bits 4 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), ADINTO becomes F0H.

Figure 13-4 shows the ADINT0 configuration.

## [Description of each bit]

• INTSN0 (bit 0)

INTSN0 indicates whether one cycle of the scan channels has been completed. When INTSN0 is "0", then "one cycle is not complete". If "1", then "one cycle is complete". Here, "one cycle is complete" signifies that in the scan mode, A/D conversion of channel 7 is complete. INTSN0 must be reset to "0" by the program.

- INTST0 (bit 1)
  - INTST0 indicates whether A/D conversion in the select mode is complete. When INTST0 is "1", then A/D conversion is complete. INTST0 must be reset to "0" by the program.
- ADSNIE0 (bit 2)
   ADSNIE0 enables or disables interrupt requests when one cycle of scan channels is complete. Here, "one cycle is complete" signifies that in the scan mode, A/D conversion of channel 7 is complete.
- ADSTIE0 (bit 3)
   ADSTIE0 enables or disables interrupt requests when A/D conversion is completed in the select mode.



Figure 13-4 ADINTO Configuration

۱۱۱ م

## (4) A/D result registers (ADR00 to ADR07)

A/D result registers (ADR00 to ADR07) consist of 10 bits and store the A/D conversion results.

A/D result registers (ADR00 to ADR07) can only be read in word access operations by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), the value of ADR00 to ADR07 is undefined.

Figure 13-5 shows the configuration of the A/D result registers (ADR00 to ADR07).

R/W access: R (word access only)

|         | Address [H | ] 7  | 6    | 5    | 4    | 3    | 2    | 1    | 0    |            |
|---------|------------|------|------|------|------|------|------|------|------|------------|
| ADD07   | 00AF       | _    | _    | _    | _    | _    | _    | bit9 | bit8 | bit9 : MSB |
| ADR07   | 00AE       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 | bit0 : LSB |
| ADR06   | 00AD       | _    |      | _    | _    | _    | _    | bit9 | bit8 |            |
| ADITIOO | 00AC       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR05   | 00AB       | _    | _    | _    | _    | _    | _    | bit9 | bit8 |            |
| ADNUS   | 00AA       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR04   | 00A9       | _    | _    | _    | _    | _    | _    | bit9 | bit8 |            |
| ADNU4   | 00A8       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR03   | 00A7       | _    | _    | _    | _    | _    | _    | bit9 | bit8 |            |
| ADNUS   | 00A6       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR02   | 00A5       | _    | _    | _    | _    | _    | _    | bit9 | bit8 |            |
| ADNUZ   | 00A4       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR01   | 00A3       | _    |      | _    |      | _    | _    | bit9 | bit8 |            |
| ADRUI   | 00A2       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |
| ADR00   | 00A1       | _    | _    |      | _    | _    | _    | bit9 | bit8 |            |
| ADDOO   | 00A0       | bit7 | bit6 | bit5 | bit4 | bit3 | bit2 | bit1 | bit0 |            |

<sup>&</sup>quot;—" indicates a nonexistent bit. When read, its value will be "0."

Figure 13-5 A/D Result Registers (ADR00 to ADR07) Configuration

## [Note]

Do not write to the A/D result registers (ADR00 to ADR07). If written to, all the registers from ADR00 to ADR07 may be overwritten.

## 13.3.2 Example of A/D Converter-related Register Settings

## · Scan mode setting

## (1) A/D control register 0H (ADCON0H)

With bits 5 to 7 (ADTM00 to ADTM02), specify the number of clocks required for the A/D conversion per channel.

## (2) A/D interrupt control register (ADINT0)

Specify that one cycle of the scan channels is not complete by resetting bit 0 (INTSN0) to "0". With bit 2 (ADSNIE0), enable or disable the generation of interrupts when one cycle of the scan channels is complete (INTSN0).

## (3) A/D control register 0L (ADCON0L)

Specify the scan channels with bits 0 to 2 (ADSNM00 to ADSNM02). With bit 5 (SNEX0), specify the factor that will start A/D conversion. With bit 6 (SCNC0), specify operation after completion of one cycle of the scan channels. Set bit 4 (ADRUN0) to "1" to start the A/D conversion. If reset to "0", the A/D conversion can be stopped before completion.

#### Select mode setting

## (1) A/D interrupt control register (ADINT0)

Specify that the AD conversion in the select mode is not complete by resetting bit 1 (INTST0) to "0". With bit 3 (ADSTIE0), enable or disable the generation of interrupts when A/D conversion is completed in the select mode (INTST0).

## (2) A/D control register 0H (ADCON0H)

Specify the A/D conversion channel with bits 0 to 2 (ADSTM00 to ADSTM02). With bits 5 to 7 (ADTM00 to ADTM02), specify the number of clocks required for the A/D conversion per channel. Set bit 4 (STS0) to "1" to start the A/D conversion. If reset to "0", the A/D conversion can be stopped before completion.

## 13.4 A/D Converter Operation

The A/D converter has two operating modes, the scan mode and the select mode.

The scan mode sequentially performs A/D conversion of channels from an arbitrary channel to ch7. In the scan mode, when the A/D conversion of ch7 is complete, A/D conversion can be selected to either stop, or to automatically restart beginning at a specified channel.

Figure 13-6 shows an example of scan mode operation.

During scan mode operation, it is also possible to operate the select mode. In this case, when the select mode is activated, A/D conversion is halted for the channel being converted in scan mode, and A/D conversion of the specified channel is performed in the select mode. When the A/D conversion in the select mode is complete, scan mode A/D conversion is restarted for the channel that was previously halted.

The timing diagram of Figure 13-7 shows the select mode being executed during the scan mode.

While the A/D converter is stopped and also during the STOP mode, the circuitry is controlled so that there is no current flow between  $V_{REF}$  and AGND. Therefore, it is not necessary to turn off the  $V_{REF}$  supply externally when it is not in use.



Figure 13-6 Example Operation During Scan Mode



- (1) Terminate A/D conversion of ch2 Start A/D conversion of ch4 in select mode
- (2) Complete A/D conversion of ch4 Restart A/D conversion in scan mode beginning with ch2

Figure 13-7 Timing Diagram of Select Mode Execution During Scan Mode

## 13.5 Notes Regarding Usage of A/D Converter

## 13.5.1 Considerations When Setting the Conversion Time

Figure 13-8 shows an equivalent circuit of the analog input section of the A/D converter.

Because a successive comparison method with a sample and hold function is used in the converter, the internal sampling capacitor must be charged or discharged within a fixed sampling time to reach a voltage level that corresponds to the required precision.

The number of clocks required for the A/D conversion of 1 channel can be specified with ADTM00 and ADTM01 of the A/D control register 0H (ADCON0H).

Table 13-2 lists the clock allocation for the A/D conversion processes of 1 channel. Because the actual sampling time is determined by the operating frequency of the microcomputer, actual sampling times can be computed from the numeric values in this table.



Figure 13-8 Equivalent Circuit of Analog Input Section

Table 13-2 Clock Allocation in A/D Conversion Processes

|   | ADTM0 | ) | Number of clocks for A/D | Number of cl | locks required by | each process |
|---|-------|---|--------------------------|--------------|-------------------|--------------|
| 2 | 1     | 0 | conversion of 1 channel  | Sampling     | A/D conversion    | Other        |
| 0 | 0     | 0 | 1536                     | 935          | 314               | 287          |
| 0 | 0     | 1 | 1024                     | 623          | 210               | 191          |
| 0 | 1     | 0 | 768                      | 467          | 158               | 143          |
| 0 | 1     | 1 | 512                      | 311          | 106               | 95           |
| 1 | 0     | 0 | 384                      | 233          | 80                | 71           |
| 1 | 0     | 1 | 256                      | 155          | 54                | 47           |
| 1 | 1     | 0 | 192                      | 116          | 41                | 35           |
| 1 | 1     | 1 | 128                      | 77           | 28                | 23           |

Units: CPUCLK

## MSM66577 Family User's Manual Chapter 13 A/D Converter Functions

The following factors affect the conversion precision of the A/D converter.

- 1) Signal source impedance of the analog input → depends upon external circuit
- 2) Sampling time → depends upon ADTM00, ADTM01 settings
- 3) Actual precision of the A/D converter (comparator, CR precision, etc.)

The overall precision of the A/D converter is determined by the precision during sampling (items 1 and 2 above) and the actual precision of the A/D converter.

In consideration of the precision during sampling (dependent upon the signal source impedance), it is desirable to set a long sampling time. If the sampling time is short, it is difficult to maintain precision. In practical applications, set the conversion clock (sampling time) and design external circuitry that will satisfy the optimum requirements for "conversion time" and "conversion precision".

## 13.5.2 Noise-Suppression Measures

Based on the voltage difference between the analog reference voltage ( $V_{REF}$ ) pin and the analog ground (AGND), the A/D converter in the MSM66577 family converts an analog voltage at the analog input pin into digital data. Because this type of A/D converter does not have a reference voltage source inside the microcomputer, "stability" and "noise-suppression measures" for  $V_{REF}$  and AGND are important.

As noise-suppression measures, insert a bypass capacitor between the analog reference voltage ( $V_{REF}$ ) pin and the analog ground (AGND) pin. Also, connect the analog ground (AGND) to a stable GND on the circuit board.

If the digital and analog layouts can be separated on the circuit board, separate the circuit into a digital system (V<sub>DD</sub>/GND) and an analog system (V<sub>REF</sub>/AGND). Connect bypass capacitors to each system to reduce the circulation of GND noise in the digital system. Divide the circuit board into separate GND planes for the digital and analog systems, and then connect each GND plane to a common location where there is a stable GND supply.

In addition to inserting a bypass capacitor of 10  $\mu$ F to 47  $\mu$ F or larger between V<sub>REF</sub> and AGND, the stability of V<sub>REF</sub> can be maintained by connecting a 0.01  $\mu$ F to 0.1  $\mu$ F high-pass capacitor in parallel. Because the V<sub>REF</sub> voltage supply is used to avoid the effect of digital noise on the comparator used in A/D conversion, adding a high-pass capacitor is effective in reducing V<sub>REF</sub> fluctuations.

Figure 13-9 shows an example of noise-suppression measures.



Figure 13-9 Example of Noise-Suppression Measures

## 13.6 A/D Converter Interrupt

When each of A/D converter interrupt factors occurs, the interrupt request flag (QAD) is set to "1". The interrupt request flag (QAD) is located in interrupt request register 3 (IRQ3).

Interrupts can be enabled or disabled by the interrupt enable flag (EAD). The interrupt enable flag (EAD) is located in interrupt enable register 3 (IE3).

Three levels of priority can be set with the interrupt priority setting flags (P0AD and P1AD). The interrupt priority setting flags (P0AD and P1AD) are located in interrupt priority control register 7 (IP7).

Table 13-3 lists the vector address of the A/D converter interrupt factors and the interrupt processing flags.

Table 13-3 A/D Converter Vector Address and Interrupt Processing Flags

| Interrupt factor                   | Vector         | Interrupt | Interrupt | rupt Priority level |      |
|------------------------------------|----------------|-----------|-----------|---------------------|------|
| Interrupt factor                   | address [H]    | request   | enable    | 1                   | 0    |
| A/D conversion of one cycle of     |                |           |           |                     |      |
| the scan channels is complete      | 0044           | QAD       | EAD       | P1AD                | POAD |
| A/D conversion of the              | 0044           |           |           |                     |      |
| select mode is complete            |                |           |           |                     |      |
| Symbols (byte) of reg              | isters that    | IDOS      | IEO       | 10.7                |      |
| contain interrupt processing flags |                | IRQ3      | IE3       | IP7                 |      |
|                                    | Reference page | 17-15     | 17-20     | 17-                 | -29  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

## Chapter 14

# D/A Converter Functions

## 14. D/A Converter Functions

### 14.1 Overview

The MSM66577 family has an internal 2-channel 8-bit D/A converter. The D/A conversion method utilizes ladder resistors. If values desired to be output are written to 8-bit DA registers (DAR0, DAR1), the converted analog levels will be output from the port secondary function output pins.

## 14.2 D/A Converter Configuration

Figure 14-1 shows the D/A converter configuration.



DAR0: DA register 0
DAR1: DA register 1
DACON: DA control register

DAOUT0: D/A conversion output 0 (P14\_6) DAOUT1: D/A conversion output 1 (P14\_7)

Figure 14-1 8-Bit D/A Converter Configuration

## 14.3 D/A Converter Registers

Table 14-1 lists a summary of SFRs for control of the D/A converter.

Table 14-1 Summary of SFRs for D/A Converter Control

| Address | Name                 | Symbol | Symbol | R/W    | 8/16      | Initial value | Reference |
|---------|----------------------|--------|--------|--------|-----------|---------------|-----------|
| [H]     | Name                 | (byte) | (word) | 11/ 44 | operation | [H]           | page      |
| 00DD    | D/A control register | DACON  | _      | R/W    | 8         | FE            | 14-2      |
| 00DE    | DA register 0        | DAR0   | _      | R/W    | 8         | 00            | 14-2      |
| 00DF    | DA register 1        | DAR1   | _      | R/W    | 8         | 00            | 14-2      |

## 14.3.1 Description of D/A Converter Registers

## (1) DA registers (DAR0, DAR1)

DA registers (DAR0, DAR1) consist of 8 bits. After configuring the corresponding port as a secondary function output and selecting AOn, if the desired output value is written to a DA register, the converted analog level will be output from the corresponding port.

If a value other than 00H is written to a DA register, the DA section will consume power to perform the conversion. Therefore, when not using D/A converters, write 00H to the DA registers.

DA registers can be read from and written to by the program,.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), DAR0 and DAR1 become 00H.

#### (2) DA control register (DACON)

The DA control register (DACON) consists of 1 bit. Bit 0 (DAON) of DACON specifies whether D/A conversion operates or is halted during standby.

If the STOP mode is transferred to while DAON is "0", even if the port secondary function has been set and AOn selected, D/A conversion output will be discontinued while stopped, and current that is consumed at the D/A section will be cut. At that time, DA register contents will be preserved.

If DAON is set to "1" and the STOP mode transferred to, AOn will continue to be output.

DACON can be read from and written to by the program. However, write operations are invalid for bits 1 to 7. If read, bits 1 to 7 are always "1".

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), DACON becomes FEH.

Figure 14-2 shows the DACON configuration.



Figure 14-2 DACON Configuration

## 14.3.2 Example of D/A Converter-related Register Settings

## (1) Port 14 mode register (P14IO)

If D/A conversion output is to be used, set bits 6 and 7 (P14IO6, P14IO7) to "1" to configure the ports as outputs.

## (2) Port 14 secondary function control register (P14SF)

If D/A conversion output is to be used, set bits 6 and 7 (P14SF6, P14SF7) to "1" to configure the ports as secondary function outputs.

## (3) DA registers (DAR0, DAR1)

Write a digital value to DAR0 that is equivalent to the analog level desired to be output from pin AO0.

Write a digital value to DAR1 that is equivalent to the analog level desired to be output from pin AO1.

## (4) DA control register (DACON)

With bit 0 (DAON), specify whether D/A conversion will operate or be halted during standby.

## 14.3.3 D/A Converter Operation

The 8-bit DA registers (DAR0, DAR1) are initialized to 00H. While in this state, if ports 14\_6 and 14\_7 (DAOUT0, DAOUT1) are configured as secondary function outputs, the output will be at GND level (there is no current path in this state). At this time, if the port data registers are read, a value of "1" will be obtained regardless of the D/A output level. If the desired output value is written to DA registers (DAR0, DAR1), the converted analog level will be output from the corresponding port. Since the analog output is not buffered inside the chip, current cannot be drawn out. Therefore, connect a buffering amp if necessary.

Bit 0 (DAON) of the DA control register (DACON) is initialized to 0. At this time, if bit 2 (FLT) of SBCON is set to "1" and the STOP mode entered, ports 14\_6 and 14\_7 (DAOUT0, DAOUT1) will float, the D/A converter will halt, and the current path will be cut. DA register (DAR0, DAR1) contents will be preserved.

With bit 0 (DAON) of the DA control register (DACON) set to "1", if the STOP mode is entered, the D/A converter will not halt, and analog levels will continue to be output from ports 14\_6 and 14\_7 (DAOUT0, DAOUT1).

If a value n is written to DA registers (DAR0, DAR1), the analog level obtained is expressed as the following.

$$V_{DD} \times n/256$$
 [V]

When  $V_{DD}$  is 5 V, even if 0FFH is written to DA registers (DAR0, DAR1), the analog output will be approximately 4.98 V. A 5 V full-scale result cannot be obtained. Therefore, if a 5 V full-scale analog level is necessary, reconfigure the port as a primary function output.

## Chapter 15

# Peripheral Functions

## 15. Peripheral Functions

#### 15.1 Overview

The MSM66577 family has the following functions to service peripheral ICs: a clock out function, an external XTCLK input control function, a HOLD input control function, and a WAIT input control function. These functions can be specified with the peripheral control register (PRPHCON).

## 15.2 Description of Each Peripheral Function

#### 15.2.1 Clock Out Function

The clock out function has following two functions:

- To output a frequency divided clock of the main clock (OSCCLK) via the CLKOUT pin.
- To output the subclock (XTCLK) via the XTOUT pin.

The main clock frequency division ratio is specified with bit 0 and bit 1 (CLKO0 and CLKO1) of the peripheral control register (PRPHCON).

When the CLKOUT pin is to be used, P11\_2 must be configured as a secondary function output.

When the XTOUT pin is used to output the subclock (XTCLK), P11\_3 must be configured as a secondary function output.

## 15.2.2 External XTCLK Input Control Function

Because XT oscillation operates on an internally regulated voltage, an external CLK cannot normally be input to the oscillation pin. However, if bit 4 (EXTXT) of the peripheral control register (PRPHCON) is set to "1", the internally regulated voltage is switched to  $V_{DD}$  and the oscillation feedback resistor is turned off, enabling the input of an external XTCLK ( $V_{DD}$  level) to the XT pin.

## 15.2.3 HOLD Input Control Function

If the HOLD mode, a standby function, is to be used, set bit 5 (HOLD) of the peripheral control register (PRPHCON) to "1". Configuring P9\_7 as a secondary function output (HLDACK) enables the output of a signal that indicates availability of the bus (to transfer to the HOLD mode).

### 15.2.4 WAIT Input Control Function

Setting bit 6 (WAIT) of the peripheral control register (PRPHCON) to "1" enables wait cycles to be inserted by an external device when accessing an external data memory area.

## 15.3 Peripheral Control Register (PRPHCON)

The peripheral control register (PRPHCON) consists of 5 bits.

Bits 0 and 1 (CLKO0 and CLKO1) specify the frequency division ratio of OSCCLK that is output from the CLKOUT pin. If bit 4 (EXTXT) is set to "1", an external clock can be input to the XT oscillation circuit. Bit 5 (HOLD) enables or disables the HOLD pin input. Bit 6 (WAIT) enables or disables the WAIT pin input.

PRPHCON can be read from and written to by the program. However, write operations are invalid for bits 2, 3 and 7. If read, a value of "1" will always be obtained for bits 2, 3 and 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), PRPHCON becomes 8CH.

Figure 15-1 shows the PRPHCON configuration.



Figure 15-1 PRPHCON Configuration

## Chapter 16

# **External Interrupt Functions**

## 16. External Interrupt Functions

#### 16.1 Overview

The MSM66577 family is equipped with 9 external interrupt inputs that can be classified into 2 categories. One category is maskable interrupts, of which there are 8 (EXINTO to EXINT7). The other category is non-maskable interrupts, and there is 1 (NMI).

EXINT0 to EXINT7 are assigned as secondary functions of ports P6\_0 to P6\_3 and P9\_0 to P9\_3. If EXINT are to be used, configure the corresponding ports as inputs.

NMI has its own dedicated pin.

## 16.2 External Interrupt Registers

Table 16-1 lists a summary of SFRs for the control of external interrupts.

Table 16-1 Summary of SFRs for External Interrupt Control

| Address | Nome                       | Symbol  | Symbol | R/W    | 8/16      | Initial   | Reference |
|---------|----------------------------|---------|--------|--------|-----------|-----------|-----------|
| [H]     | Name                       | (byte)  | (word) | H/VV   | Operation | value [H] | page      |
| 0058    | External Interrupt Control | EXI0CON |        | R/W    | 8         | 00        | 16-2      |
| 0058    | Register 0                 | EXIOCON |        | 11/ // | 0         |           |           |
| 0059☆   | External Interrupt Control | EXI1CON | _      | R/W    | 8         | 00        | 16-3      |
| 0009 %  | Register 1                 | EXITOON |        |        |           |           |           |
| 005A☆   | External Interrupt Control | EXI2CON |        | DAM    | 8         | 0C/4C     | 16-4      |
|         | Register 2                 | ENIZOUN | _      | R/W    | 0         | 00/40     | 10-4      |

### [Notes]

- 1. A star (☆) in the address column indicates a missing bit.
- 2. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

## 16.2.1 Description of External Interrupt Registers

## (1) External interrupt control register 0 (EXI0CON)

The external interrupt control register 0 (EXI0CON) consists of 8 bits and sets external interrupts EXINT0 to EXINT3. For each external interrupt setting, EXI0CON specifies the valid edge (falling edge, rising edge, or both edges) or the interrupt input invalid.

EXIOCON can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), EXIOCON becomes 00H.

Figure 16-1 shows the configuration of EXIOCON.



Figure 16-1 EXIOCON Configuration

## (2) External interrupt control register 1 (EXI1CON)

The external interrupt control register 1 (EXI1CON) consists of 8 bits and sets external interrupts EXINT4 to EXINT7. For each external interrupt setting, EXI1CON opecifies the valid edge (falling edge, rising edge, or both edges) or the interrupt input invalid.

EXI1CON can be read from and written to by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), EXI1CON becomes 00H.

Figure 16-2 shows the configuration of EXI1CON.



"—" indicates a nonexistent bit. When read, its value will be "1."

Figure 16-2 EXI1CON Configuration

## (3) External interrupt control register 2 (EXI2CON)

The external interrupt control register 2 (EXI2CON) consists of 4 bits. Bits 4 and 5 (NMIM0 and NMIM1) specify the valid edge for NMI. Bit 7 (MIPF) enables or disables priority control for all maskable interrupts. Bit 6 (NMIRD) monitors the NMI pin.

EXI2CON can be read from and written to by the program. However, write operations to the lower 4 bits and bit 6 are invalid. If read, bits 0 and 1 will always be "0", and bits 2 and 3 will be "1". The NMI pin level is read from bit 6 (NMIRD). This bit can be conveniently used by the program to read the pin level during a NMI routine.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), EXI2CON becomes 0CH if the NMI pin is at a low level, or 4CH if the NMI pin is at a high level.

Figure 16-3 shows the configuration of EXI2CON.



Figure 16-3 EXI2CON Configuration

## 16.2.2 Example of External Interrupt-related Register Settings

## (1) Port 6 mode register (P6IO)

If EXINT0 to EXINT3 are to be used, reset the corresponding bits 0 to 3 (P6IO0 to P6IO3) to "0" to configure those ports as inputs.

## (2) Port 9 mode register (P9IO)

If EXINT4 and/or EXINT5 are to be used, reset the corresponding bits 0 to 3 (P9IO0 to P9IO3) to "0" to configure those ports as inputs.

## (3) Port 6 secondary function control register (P6SF)

If EXINT0 to EXINT3 are to be used, enable or disable pull-up resistors with the corresponding bits 0 to 3 (P6SF0 to P6SF3).

## (4) Port 9 secondary function control register (P9SF)

If EXINT4 and/or EXINT5 are to be used, enable or disable pull-up resistors with the corresponding bits 0 to 3 (P9SF0 to P9SF3).

## (5) External interrupt control register 0 (EXI0CON)

If EXINT0 is to be used, specify the valid edge with bits 0 and 1 (EX0M0, EX0M1). If EXINT1, EXINT2 and/or EXINT3 are to be used, specify a valid edge for each with bits 2 and 3 (EX1M0, EX1M1), bits 4 and 5 (EX2M0, EX2M1), and bits 6 and 7 (EX3M0, EX3M1).

## (6) External interrupt control register 1 (EXI1CON)

If EXINT4 is to be used, specify the valid edge with bits 0 and 1 (EX4M0, EX4M1). If EXINT5, EXINT6 and EXINT7 are to be used, specify the valid edge with bits 2 and 3 (EX5M0, EX5M1), bits 4 and 5 (EX6M0, EX6M1), and bits 6 and 7 (EX7M0, EX7M1).

## (7) External interrupt control register 2 (EXI2CON)

Specify the NMI valid edge with bits 4 and 5 (NMIM0, NMIM1). If interrupt priority is to be used, set bit 7 (MIPF) to "1".

## 16.3 EXINTO to EXINT7 Interrupts

When a valid edge is input to each external interrupt input pin, the corresponding interrupt request flag is set to "1". The interrupt request flags are located in interrupt request registers 0 to 2 (IRQ0 to IRQ2).

Interrupts can be enabled or disabled by the interrupt enable flag that corresponds to each pin input. The interrupt enable flags are located in interrupt enable registers 0 to 2 (IE0 to IE2).

Three levels of priority can be set with the interrupt priority setting flags that correspond to each pin input. The interrupt priority setting flags are located in interrupt priority control registers 0, 2 and 4 (IP0, IP2 and IP4).

Table 16-2 lists the vector addresses for each pin input of EXINT0 to EXINT7 and the interrupt processing flags.

\*n (n = 1 to 9) in the above table indicates the register in which each flag is allocated.

Table 16-2 EXINTO to EXINT7 Vector Addresses and Interrupt Processing Flags

| latamant factors                   | Vector         | Interrupt                      | Interrupt            | Priorit                                 | y level          |  |
|------------------------------------|----------------|--------------------------------|----------------------|-----------------------------------------|------------------|--|
| Interrupt factor                   | address [H]    | request                        | enable               | 1                                       | 0                |  |
| EXINT0 pin input                   | 000A           | QINT0 *1                       | EINTO *4             | P1INT0                                  | POINTO *7        |  |
| (external interrupt 0)             | 000A           | QIIVIO                         | LINTO                | 1 111110                                | POINTO           |  |
| EXINT1 pin input                   | 001C           | QINT1 *2                       | EINT1 *5             | P1INT1                                  | POINT1 *8        |  |
| (external interrupt 1)             | 0010           | QIIVII                         | EINTT                | FINIT                                   | FOINTI           |  |
| EXINT2 pin input                   | 001E           | QINT2                          | EINT2                | P1INT2                                  | DOINTO           |  |
| (external interrupt 2)             | OUTE           | QINIZ                          | EINIZ                | FINIZ                                   | P0INT2           |  |
| EXINT3 pin input                   | 0020           | QINT3                          | EINT3                | P1INT3                                  | P0INT3           |  |
| (external interrupt 3)             | 0020           | QINTS                          | EINTS                | PIINIS                                  | FOINTS           |  |
| EXINT4 pin input                   | 002A           | QINT4 *3                       | EINT4 *6             | P1INT4                                  | P0INT4 *9        |  |
| (external interrupt 4)             | 002A           | QIN14                          | EIN14                | PIINI4                                  |                  |  |
| EXINT5 pin input                   | 002C           | QINT5                          | EINT5                | P1INT5                                  | DOINTE           |  |
| (external interrupt 5)             | 0020           | QINTS                          | EINIS                | PIINIS                                  | P0INT5           |  |
| EXINT6 pin input                   | 002E           | QINT6                          | EINT6                | P1INT6                                  | POINT6           |  |
| (external interrupt 6)             | 002E           | QINTO                          | EINIO                | FINIO                                   | PUINTO           |  |
| EXINT7 pin input                   | 0030           | QINT7                          | EINT7                | P1INT7                                  | P0INT7           |  |
| (external interrupt 7)             | 0030           | QINT7                          | EIN17                | PIINI7                                  | PUINT7           |  |
| Symbols (byte) of reg              | isters that    | IRQ0 *1<br>IRQ1 *2             | IE0 *4<br>IF1 *5     |                                         | 0 *7<br>22 *8    |  |
| contain interrupt processing flags |                | IRQ1 2<br>IRQ2 *3              | IE1 5<br>IE2 *6      |                                         | 24 *9            |  |
|                                    | Poforonco paga | 17-12 *1<br>17-13 *2           | 17-17 *4<br>17-18 *5 |                                         | -22 *7<br>-24 *8 |  |
|                                    | Reference page | 17-13 <sup>2</sup><br>17-14 *3 | 17-16 3<br>17-19 *6  | • • • • • • • • • • • • • • • • • • • • | -24 ° ° -26 *9   |  |

For further details regarding interrupt processing, refer to Chapter 17, "Interrupt Processing Functions".

### Chapter 17

# Interrupt Processing Functions

### 17. Interrupt Processing Functions

#### 17.1 Overview

The MSM66577 family has 39 types of interrupts (9 external and 30 internal). These are assigned to 30 vectors. One of the external interrupts is a non-maskable interrupt. Three levels of priority can be set for maskable interrupts.

Table 17-1 lists interrupts and their corresponding vector addresses.

Table 17-1 Interrupts and Their Corresponding Vector Addresses

| Interrupt                                           | Vector address [H] |  |
|-----------------------------------------------------|--------------------|--|
| NMI pin input (non-maskable interrupt)              | 0008               |  |
| EXINT0 pin input (external interrupt 0)             | 000A               |  |
| Free running counter overflow                       | 000C               |  |
| CPCM0 event input, compare match                    | 0016               |  |
| CPCM1 event input, compare match                    | 0018               |  |
| Timer 0 overflow                                    | 001A               |  |
| EXINT1 pin input (external interrupt 1)             | 001C               |  |
| EXINT2 pin input (external interrupt 2)             | 001E               |  |
| EXINT3 pin input (external interrupt 3)             | 0020               |  |
| Timer 1 overflow                                    | 0022               |  |
| Timer 2 overflow                                    | 0024               |  |
| Timer 3 overflow                                    | 0026               |  |
| EXINT4 pin input (external interrupt 4)             | 002A               |  |
| EXINT5 pin input (external interrupt 5)             | 002C               |  |
| EXINT6 pin input (external interrupt 6)             | 002E               |  |
| EXINT7 pin input (external interrupt 7)             | 0030               |  |
| Timer 4 overflow                                    | 0036               |  |
| SIO1 transmit buffer empty, transmit complete,      | 0029               |  |
| receive complete                                    | 0038               |  |
| Timer 5 overflow                                    | 003A               |  |
| Interrupt by SIO5 transfer completion               | 003C               |  |
| Interrupt by SIO6 transmit buffer empty,            | 003E               |  |
| transmit completion, receive completion             | 003E               |  |
| Interrupt by SIO4 transfer completion               | 0040               |  |
| Timer 6 overflow                                    | 0042               |  |
| One cycle of A/D conversion scan channels complete, | 0044               |  |
| A/D conversion select mode complete                 | 0044               |  |
| Real-time counter output (interval: 0.125 to 1 s)   | 0048               |  |
| PWC0 overflow, match of PWC0 and PWR0               | 006A               |  |
| PWC1 overflow, match of PWC1 and PWR1               | 006C               |  |
| Match of PWC0 and PWR2                              | 006E               |  |
| Match of PWC1 and PWR3                              | 0070               |  |
| Timer 9 overflow                                    | 0072               |  |

#### 17.2 Interrupt Function Registers

Table 17-2 lists a summary of SFRs for interrupt processing

Table 17-2 Summary of SFRs for Interrupt Processing

| Address | Name                                  | Symbol  | Symbol | R/W | 8/16      | Initial   | Reference |
|---------|---------------------------------------|---------|--------|-----|-----------|-----------|-----------|
| [H]     |                                       | (byte)  | (word) |     | Operation | value [H] | page      |
| 0004    | Program status word                   | PSWL    | PSW    | R/W | 8/16      | 00        | 2-18      |
| 0005    | - regram etatae nera                  | PSWH    |        |     |           | 00        |           |
| 005A☆   | External interrupt control register 2 | EXI2CON | _      | R/W | 8         | 0C/4C     | 16-4      |
| 0030 ☆  | Interrupt request register 0          | IRQ0    | _      | R/W | 8         | 00        | 17-12     |
| 0031 ☆  | Interrupt request register 1          | IRQ1    | _      | R/W | 8         | 00        | 17-13     |
| 0032☆   | Interrupt request register 2          | IRQ2    | _      | R/W | 8         | 00        | 17-14     |
| 0033☆   | Interrupt request register 3          | IRQ3    | _      | R/W | 8         | 00        | 17-15     |
| 005C☆   | Interrupt request register 4          | IRQ4    | _      | R/W | 8         | E0        | 17-16     |
| 0034☆   | Interrupt enable register 0           | IE0     | _      | R/W | 8         | 00        | 17-17     |
| 0035 ☆  | Interrupt enable register 1           | IE1     | _      | R/W | 8         | 00        | 17-18     |
| 0036☆   | Interrupt enable register 2           | IE2     | _      | R/W | 8         | 00        | 17-19     |
| 0037☆   | Interrupt enable register 3           | IE3     | _      | R/W | 8         | 00        | 17-20     |
| 005D☆   | Interrupt enable register 4           | IE4     | _      | R/W | 8         | E0        | 17-21     |
| 0038☆   | Interrupt priority control register 0 | IP0     | _      | R/W | 8         | 00        | 17-22     |
| 0039☆   | Interrupt priority control register 1 | IP1     | _      | R/W | 8         | 00        | 17-23     |
| 003A    | Interrupt priority control register 2 | IP2     | _      | R/W | 8         | 00        | 17-24     |
| 003B☆   | Interrupt priority control register 3 | IP3     | _      | R/W | 8         | 00        | 17-25     |
| 003C☆   | Interrupt priority control register 4 | IP4     | _      | R/W | 8         | 00        | 17-26     |
| 003D☆   | Interrupt priority control register 5 | IP5     | _      | R/W | 8         | 00        | 17-27     |
| 003E☆   | Interrupt priority control register 6 | IP6     | _      | R/W | 8         | 00        | 17-28     |
| 003F☆   | Interrupt priority control register 7 | IP7     | _      | R/W | 8         | 00        | 17-29     |
| 005E☆   | Interrupt priority control register 8 | IP8     | _      | R/W | 8         | 00        | 17-30     |
| 005F☆   | Interrupt priority control register 9 | IP9     | _      | R/W | 8         | FC        | 17-31     |

#### [Notes]

- 1. Addresses may not be consecutive in some places.
- 2. A star (戊) in the address column indicates a missing bit.
- 3. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

#### 17

#### 17.3 Description of Interrupt Processing

#### 17.3.1 Non-Maskable Interrupt (NMI)

The non-maskable interrupt (NMI) is an external interrupt that cannot be masked.

When the valid edge specified by bits 4 and 5 (NMIM0, NMIM1) of EXI2CON is detected, the CPU immediately transfers processing to the non-maskable interrupt.

However, the one exception occurs after reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), where the non-maskable interrupt is masked until execution of the first instruction is complete. This function is intended to prevent loss of program control after reset in the case where the non-maskable interrupt occurs before the system stack pointer (SSP) is set with a value (when the SSP is undefined). Therefore, operated as part of the above NMI function, set an appropriate value in SSP with the "first instruction after reset".

[Related information reference guide] NMI settings ... page 16-4

When the non-maskable interrupt (NMI) occurs, a sequence such as listed below is automatically processed by the hardware and the first instruction of the NMI routine is executed. 14 cycles are used to transfer to the NMI routine.

- Save the program counter (PC)
- Save the accumulator (ACC)
- Save the local register base (LRB)
- Save the program status word (PSW)
- · Reset the non-maskable interrupt request flag
- Disable maskable interrupts
- Disable multiple interrupts by the non-maskable interrupt
- Load the program counter with the value that has been written to the NMI routine vector table (0008H, 0009H)

Use a RTI instruction at the end of the NMI routine.

When a RTI instruction is executed, the hardware automatically processes a sequence such as listed below to complete the NMI routine. 12 cycles are used to return from the NMI routine.

- Restore the program status word (PSW)
- Restore the local register base (LRB)
- Restore the accumulator (ACC)
- Restore the program counter (PC)
- Enable maskable interrupts
- Enable multiple interrupts by the non-maskable interrupt

Figure 17-1 shows examples of saving and restoring the PC, ACC, LRB and PSW.

#### [Note]

If the program memory space has been expanded to 1MB, in addition to the above processing, the code segment register (CSR) will be saved and restored. In this case, 17 cycles will be used to transfer to the NMI routine, and 14 cycles to return from the NMI routine.

Interrupt processing example (for a 64KB program memory space)



• Interrupt processing example (for a greater than 64KB program memory space)



SSP: System Stack Pointer

Figure 17-1 Examples of Saving and Restoring the PC, ACC, LRB and PSW

#### 17.3.2 Maskable Interrupts

Maskable interrupts are generated by various interrupt factors such as built-in internal peripheral hardware, external interrupt inputs, etc.

The control of maskable interrupts is performed by the following.

- Interrupt request registers (IRQ0 to IRQ4)
- Interrupt enable registers (IE0 to IE4)
- Master interrupt enable flag (MIE)
- Master interrupt priority flag (MIPF)
- Interrupt priority control registers (IP0 to IP9)

#### (1) Interrupt request registers (IRQ0 to IRQ4)

Interrupt request registers (IRQs) are set to "1" when each interrupt source generates an interrupt signal. If an interrupt is received, the registers are automatically reset to "0" while transferring to the interrupt processing routine. IRQ bits can also be set to "1" or "0" by the program.

#### (2) Interrupt enable registers (IE0 to IE4)

Interrupt enable registers (IEs) individually enable or disable the generation of interrupts. When an IE bit is "0", generation of the corresponding interrupt is disabled. When an IE bit is "1", generation of the corresponding interrupt is enabled.

#### (3) Master interrupt enable flag (MIE)

The master interrupt enable flag (MIE) is a 1-bit flag <u>located in the program status word (PSW).</u> MIE enables or disables generation of all the maskable interrupts.

MIE = "0" All maskable interrupts are disabled (regardless of IE)

MIE = "1" Maskable interrupts are enabled (only those interrupt factors enabled by IE)

[Related information reference guide]

Program status word (PSW) ... Page 2-18

#### (4) Master interrupt priority flag (MIPF)

The master interrupt priority flag (MIPF) is a 1-bit flag <u>located in the external interrupt control</u> <u>register 2 (EXI2CON).</u> MIPF enables or disables priority for all the maskable interrupts. MIPF = "0" Priority control disabled (regardless of IP, interrupts controlled by MIE and IE only)

MIPF = "1" Priority control enabled (3 levels of priority control according to IP setting)

[Related information reference guide]

External interrupt control register 2 (EXI2CON) ... Page 16-4

#### (5) Interrupt priority control registers (IP0 to IP9)

Interrupt priority control registers (IPs) specify the priority of maskable interrupts. The 2-bit specification (P1xxx, P0xxx) for each interrupt indicates 3 levels of priority (where xxx is an abbreviation for each interrupt factor). For further details regarding priority control, refer to Section 17.3.3, "Priority Control of Maskable Interrupts". Priority is specified as shown below.

| P1xxx | P0xxx | Priority |              |  |
|-------|-------|----------|--------------|--|
| 0     | 0     | Level 0  | (low)        |  |
| 0     | 1     | Level 1  | <b>\( \)</b> |  |
| 1     | *     | Level 2  | (high)       |  |

<sup>(\*</sup> indicates either "0" or "1")

Figure 17-2 shows a block diagram of the control for maskable interrupts. IRQ bits are indicated as Qxxx, IE bits as Exxx, and IP bits as P0xxx, P1xxx for each interrupt factor. In some cases, several maskable interrupts correspond to the same interrupt vector. For those interrupts, within each function block there is a flag to enable or disable multiple interrupts and an interrupt request flag to verify (by polling) which interrupt was generated.





The control in the above enclosed area exists in each function block.

Figure 17-2 Maskable Interrupt Control Block Diagram

Table 17-3 lists the vector address and bit symbol for each maskable interrupt. If multiple maskable interrupts are generated simultaneously, the lower vector address (in the order of Table 17-3) is given priority and processed. Similarly, for interrupts that have been enabled, if the priority level is set and priority control enabled (MIPF = "1"), when multiple maskable interrupts with the same priority are generated simultaneously, the lower vector address is given priority and processed.

Table 17-3 Vector Addresses and Bit Symbols for Maskable Interrupts

| Na  | Interrupt factor                                  | Vector      | Interrupt | Interrupt | Priorit | y level |
|-----|---------------------------------------------------|-------------|-----------|-----------|---------|---------|
| No. | Interrupt factor                                  | address [H] | request   | enable    | 1       | 0       |
| 1   | EXINT0 pin input (external interrupt 0)           | 000A        | QINT0     | EINT0     | P1INT0  | P0INT0  |
| 2   | Free running counter overflow                     | 000C        | QFRCOV    | EFRCOV    | P1FRCOV | P0FRCOV |
| 3   | CPCM0 event input, compare match                  | 0016        | QCPCM0    | ECPCM0    | P1CPCM0 | P0CPCM0 |
| 4   | CPCM1 event input, compare match                  | 0018        | QCPCM1    | ECPCM1    | P1CPCM1 | P0CPCM1 |
| 5   | Timer 0 overflow                                  | 001A        | QTM0OV    | ETM0OV    | P1TM0OV | P0TM0OV |
| 6   | EXINT1 pin input (external interrupt 1)           | 001C        | QINT1     | EINT1     | P1INT1  | P0INT1  |
| 7   | EXINT2 pin input (external interrupt 2)           | 001E        | QINT2     | EINT2     | P1INT2  | P0INT2  |
| 8   | EXINT3 pin input (external interrupt 3)           | 0020        | QINT3     | EINT3     | P1INT3  | P0INT3  |
| 9   | Timer 1 overflow                                  | 0022        | QTM1OV    | ETM10V    | P1TM1OV | P0TM1OV |
| 10  | Timer 2 overflow                                  | 0024        | QTM2OV    | ETM2OV    | P1TM2OV | P0TM2OV |
| 11  | Timer 3 overflow                                  | 0026        | QTM3OV    | ETM3OV    | P1TM3OV | P0TM3OV |
| 12  | EXINT4 pin input (external interrupt 4)           | 002A        | QINT4     | EINT4     | P1INT4  | P0INT4  |
| 13  | EXINT5 pin input (external interrupt 5)           | 002C        | QINT5     | EINT5     | P1INT5  | P0INT5  |
| 14  | EXINT6 pin input (external interrupt 6)           | 002E        | QINT6     | EINT6     | P1INT6  | P0INT6  |
| 15  | EXINT7 pin input (external interrupt 7)           | 0030        | QINT7     | EINT7     | P1INT7  | P0INT7  |
| 16  | Timer 4 overflow                                  | 0036        | QTM4OV    | ETM4OV    | P1TM4OV | P0TM4OV |
| 17  | SIO1 transmit buffer empty, transmit              | 0038        | QSIO1     | ESIO1     | P1SIO1  | P0SIO1  |
| 17  | complete, receive complete                        | 0000        |           |           |         |         |
| 18  | Timer 5 overflow                                  | 003A        | QTM5OV    | ETM5OV    | P1TM5OV | P0TM5OV |
| 19  | Interrupt by SIO5 transfer completion             | 003C        | QSIO5     | ESIO5     | P1SIO5  | P0SIO5  |
| 20  | Interrupt by SIO6 transmit buffer empty,          | 003E        | QSIO6     | ESIO6     | P1SIO6  | P0SIO6  |
| 20  | transmit completion, receive completion           | 003L        |           |           |         |         |
| 21  | Interrupt by SIO4 transfer completion             | 0040        | QSIO4     | ESIO4     | P1SIO4  | P0SIO4  |
| 22  | Timer 6 overflow                                  | 0042        | QTM6OV    | ETM6OV    | P1TM6OV | P0TM6OV |
| 23  | One cycle of A/D conversion scan channels         | 0044        | QAD       | EAD       | P1AD    | P0AD    |
| 20  | complete, A/D conversion select mode complete     | 0044        |           |           |         |         |
| 24  | Real-time counter output (interval: 0.125 to 1 s) | 0048        | QRTC      | ERTC      | P1RTC   | P0RTC   |
| 25  | PWC0 overflow, match of PWC0 and PWR0             | 006A        | QPWM0     | EPWM0     | P1PWM0  | P0PWM0  |
| 26  | PWC1 overflow, match of PWC1 and PWR1             | 006C        | QPWM1     | EPWM1     | P1PWM1  | P0PWM1  |
| 27  | Match of PWC0 and PWR2                            | 006E        | QPWM2     | EPWM2     | P1PWM2  | P0PWM2  |
| 28  | Match of PWC1 and PWR3                            | 0070        | QPWM3     | EPWM3     | P1PWM3  | P0PWM3  |
| 29  | Timer 9 overflow                                  | 0072        | QTM9OV    | ETM9OV    | P1TM9OV | P0TM9OV |

When a maskable interrupt occurs, a sequence such as listed below is automatically processed by the hardware and the first instruction of the maskable interrupt routine is executed. 14 cycles are used to transfer to the maskable interrupt routine.

- Save the program counter (PC)
- Save the accumulator (ACC)
- Save the local register base (LRB)
- Save the program status word (PSW)
- Reset the IRQ that initiated the maskable interrupt process
- Reset MIE in PSW (resetting MIE to "0" disables reception of all maskable interrupts)
- Disable reception of interrupts with the same or lower interrupt priority level (if MIPF = 1)
- Load the program counter with the value that has been written to the vector table

Use a RTI instruction at the end of the maskable interrupt routine.

When a RTI instruction is executed, the hardware automatically processes a sequence such as listed below to complete the maskable interrupt routine. 12 cycles are used to return from the maskable interrupt routine.

- Enable reception of interrupts with the same or lower interrupt priority level (if MIPF = 1)
- Restore the program status word (PSW) (set MIE to "1")
- Restore the local register base (LRB)
- Restore the accumulator (ACC)
- Restore the program counter (PC)

Figure 17-1 shows examples of saving and storing the PC, ACC, LRB and PSW.

#### [Note]

If the program memory space has been expanded to 1MB, in addition to the above processing, the code segment register (CSR) will be saved and restored. In this case, 17 cycles will be used to transfer to the maskable interrupt routine, and 14 cycles to return from the maskable interrupt routine.

#### 17.3.3 Priority Control of Maskable Interrupts

The MSM66577 family can set 3 levels of priority for each maskable interrupt factor, resulting in easy to realize control of multiple interrupts. Priority control in actual programs is described below.

#### (1) Basic interrupt control

When a maskable interrupt occurs, since the reception of other maskable interrupts is automatically disabled (MIE = "0"), other interrupts (except for nonmaskable interrupts and reset processing) will not occur within the interrupt processing routine. If another maskable interrupt is generated during execution of the interrupt routine, that interrupt will wait for processing. In such a case, immediately after processing of the first interrupt is completed, processing of the interrupt that has been waiting will begin. (See Figure 17-3.) If several interrupts are awaiting processing, the interrupt vector with the lowest address will be processed first. (See Table 17-3.)

#### (2) Multiple interrupt control

During execution of an interrupt routine, other maskable interrupts may be enabled. This is known as "multiple interrupt control". If multiple interrupt control is required, make a setting so that multiple interrupts will be enabled (MIE = "1") within the maskable interrupt routine when a maskable interrupt occurs.

The following two methods exist for multiple interrupt control.

- (i) Control by IE flags
- (ii) Control by MIPF (Master Interrupt Priority Flag)

#### (i) Control by IE flags

In the interrupt processing routine, only those IE flags that correspond to the multiple interrupt factors to be enabled are set to "1". Multiple interrupts from other factors are disabled by setting their IE flags to "0".

Next, by setting the MIE flag to "1" within the interrupt processing routine, the reception of multiple interrupts for the enabled interrupt factors enabled by setting the IE flags to "1" will begin. (See Figure 17-4.)

If an interrupt occurs for which the corresponding IE flag is "0" while another interrupt is being processed, the interrupt will wait until the interrupt process being executed is completed and the program changes its IE flag to "1".

#### (ii) Control by MIPF (Master Interrupt Priority Flag)

In addition to the control of (i) above, by setting MIPF to "1", the priority of maskable interrupts can be controlled by the hardware. Of the enabled interrupt factors specified with IE = "1", multiple interrupts are enabled only for those interrupt factors whose priority is higher than that of the interrupt currently being processed. (If MIPF = "0", then all interrupt factors with IE specified as "1" will be enabled for multiple interrupts.)

If interrupts are generated having the same or lower priority than that of the interrupt process currently being executed, those interrupts will wait until completion of the interrupt process currently being executed. After completion of the interrupt process, if several interrupts are waiting, they will be executed in order of highest priority. However, if there are several interrupts with the same priority level, the interrupt with the lowest vector address will be processed first. (See Table 17-3.)



Figure 17-3 Fundamental Interrupt Control



**Figure 17-4 Multiple Interrupt Control** 

#### 17.4 IRQ, IE and IP Register Configurations for Each Interrupt

Each interrupt factor has its own interrupt request register (IRQ0 to IRQ4), interrupt enable register (IE0 to IE4) and interrupt priority control register (IP0 to IP9).

These registers are allocated as a group of interrupt processing registers, independent from the group of operation and control registers for each internal peripheral module.

The configurations of each interrupt processing register are presented below, showing which bits of which registers are allocated as the IRQ, IE and IP flags for each interrupt factor. At the end of chapters describing internal peripheral modules, a reference page is listed for the interrupt processing registers of that module.

#### 17.4.1 Interrupt Request Registers (IRQ0 to IRQ4)

#### (1) Interrupt request register 0 (IRQ0)

Interrupt request register 0 (IRQ0) consists of 4 bits. Bits are set to "1" corresponding to external interrupt 0 (bit 0), overflow of free running counter (bit 1), CPCM0 event input / compare match (bit 6), and CPCM1 event input/compare match (bit 7).

IRQ0 can be read or written by the program. However, if writing to bits 2 through 5, always write those bits as "0". If read, a value of "0" will always be obtained for bits 2 through 5.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IRQ0 becomes 00H.

Figure 17-5 shows the configuration of IRQ0.



<sup>&</sup>quot;0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-5 IRQ0 Configuration

#### (2) Interrupt request register 1 (IRQ1)

Interrupt request register 1 (IRQ1) consists of 7 bits. Bits are set to "1" corresponding to overflow of timer 0 (bit 0), external interrupts 1 to 3 (bits 1 to 3) and overflow of timers 1 to 3 (bits 4 to 6).

IRQ1 can be read or written by the program. However, if writing to bit 7, always write the bit as "0". If read, a value of "0" will always be obtained for bit 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IRQ1 becomes 00H.

Figure 17-6 shows the configuration of IRQ1.



Figure 17-6 IRQ1 Configuration

#### (3) Interrupt request register 2 (IRQ2)

Interrupt request register 2 (IRQ2) consists of 6 bits. Bits are set to "1" corresponding to external interrupts 4 to 7 (bits 0 to 3), overflow of timer 4 (bit 6), and SIO1 transmit buffer empty/transmit complete/receive complete (bit 7).

IRQ2 can be read or written by the program. However, if writing to bits 4 and 5, always write those bits as "0". If read, a value of "0" will always be obtained for bits 4 and 5.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IRQ2 becomes 00H.

Figure 17-7 shows the configuration of IRQ2.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-7 IRQ2 Configuration

#### 17

#### (4) Interrupt request register 3 (IRQ3)

Interrupt request register 3 (IRQ3) consists of 7 bits. Bits are set to "1" corresponding to overflow of timer 5 (bit 0), SIO5 and SIO4 transmit-receive completion (bits 1 and 3), overflow of timer 6 (bit 4), A/D conversion scan channel cycle complete/select mode complete (bit 5), and real-time counter output (bit 7).

IRQ3 can be read or written by the program. However, if writing to bit 6, always write the bit as "0". If read, a value of "0" will always be obtained for bit 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IRQ3 becomes 00H.

Figure 17-8 shows the configuration of IRQ3.



<sup>&</sup>quot;0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-8 IRQ3 Configuration

#### (5) Interrupt request register 4 (IRQ4)

Interrupt request register 4 (IRQ4) consists of 5 bits. Bits are set to "1" corresponding to overflow of PWC0/matching of PWC0 and PWR0 (bit 0), overflow of PWC1/matching of PWC1 and PWR1 (bit 1), matching of PWC0 and PWR2 (bit 2), matching of PWC1 and PWR3 (bit 3), and overflow of timer 9 (bit 4).

IRQ4 can be read or written by the program. However, writes to bits 5 through 7 are invalid. If read, a value of "1" will always be obtained for bits 5 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IRQ4 becomes E0H.

Figure 17-9 shows the configuration of IRQ4.



Figure 17-9 IRQ4 Configuration

#### 17.4.2 Interrupt Enable Registers (IE0 to IE4)

#### (1) Interrupt enable register 0 (IE0)

Interrupt enable register 0 (IE0) consists of 4 bits. The generation of interrupts is enabled by setting bits to "1" corresponding to external interrupt 0 (bit 0), overflow of free running counter (bit 1), CPCM0 event input /compare match (bit 6), and CPCM1 event input/compare match (bit 7).

IEO can be read or written by the program. However, if writing to bits 2 through 5, always write those bits as "0". If read, a value of "0" will always be obtained for bits 2 through 5.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IE0 becomes 00H.

Figure 17-10 shows the configuration of IE0.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-10 IE0 Configuration

#### (2) Interrupt enable register 1 (IE1)

Interrupt enable register 1 (IE1) consists of 7 bits. The generation of interrupts is enabled by setting bits to "1" corresponding to overflow of timer 0 (bit 0), external interrupts 1 to 3 (bits 1 to 3), and overflow of timers 1 to 3 (bits 4 to 6).

IE1 can be read or written by the program. However, if writing to bit 7, always write the bit as "0". If read, a value of "0" will always be obtained for bit 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IE1 becomes 00H.

Figure 17-11 shows the configuration of IE1.



If read, a value of "0" will be obtained.

Figure 17-11 IE1 Configuration

#### (3) Interrupt enable register 2 (IE2)

Interrupt enable register 2 (IE2) consists of 6 bits. The generation of interrupts is enabled by setting bits to "1" corresponding to external interrupts 4 to 7 (bits 0 to 3), overflow of timer 4 (bit 6), and SIO1 transmit buffer empty/transmit complete/receive complete (bit 7).

IE2 can be read or written by the program. However, if writing to bits 4 and 5, always write those bits as "0". If read, a value of "0" will always be obtained for bits 4 and 5.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IE2 becomes 00H.

Figure 17-12 shows the configuration of IE2.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-12 IE2 Configuration

#### (4) Interrupt enable register 3 (IE3)

Interrupt enable register 3 (IE3) consists of 7 bits. The generation of interrupts is enabled by setting bits to "1" corresponding to overflow of timer 5 (bit 0), SIO5 and SIO4 transmit-receive completion (bits 1 and 3), SIO6 transmit buffer empty/transmit complete/receive complete (bit 2) overflow of timer 6 (bit 4), A/D conversion scan channel cycle complete/select mode complete (bit 5), and real-time counter output (bit 7).

IE3 can be read or written by the program. However, if writing to bit 6, always write the bit as "0". If read, a value of "0" will always be obtained for bit 6.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IE3 becomes 00H.

Figure 17-13 shows the configuration of IE3.



<sup>&</sup>quot;0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-13 IE3 Configuration

#### (5) Interrupt enable register 4 (IE4)

Interrupt enable register 4 (IE4) consists of 5 bits. The generation of interrupts is enabled by setting bits to "1" corresponding to overflow of PWC0/matching of PWC0 and PWR0 (bit 0), overflow of PWC1/matching of PWC1 and PWR1 (bit 1), matching of PWC0 and PWR2 (bit 2), matching of PWC1 and PWR3 (bit 3), and overflow of timer 9 (bit 4).

IE4 can be read or written by the program. However, writes to bits 5 through 7 are invalid. If read, a value of "1" will always be obtained for bits 5 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IE4 becomes E0H.

Figure 17-14 shows the configuration of IE4.



Figure 17-14 IE4 Configuration

#### 17.4.3 Interrupt Priority Control Registers (IP0 to IP9)

#### (1) Interrupt priority control register 0 (IP0)

Interrupt priority control register 0 (IP0) consists of 4 bits and specifies the interrupt priority for external interrupt 0 (bits 0 and 1) and overflow of the free running counter (bits 2 and 3).

IPO can be read or written by the program. However, if writing to bits 4 through 7, always write those bits as "0". If read, a value of "0" will always be obtained for bits 4 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP0 becomes 00H.

Figure 17-15 shows the configuration of IP0.



Figure 17-15 IPO Configuration

#### (2) Interrupt priority control register 1 (IP1)

Interrupt priority control register 1 (IP1) consists of 4 bits and specifies interrupt priority for CPCM0 event input/compare match (bits 4 and 5) and CPCM1 event input/compare match (bits 6 and 7).

IP1 can be read or written by the program. However, if writing to bits 0 through 3, always write those bits as "0". If read, a value of "0" will always be obtained for bits 0 through 3.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP1 becomes 00H.

Figure 17-16 shows the configuration of IP1.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-16 IP1 Configuration

<sup>&</sup>quot;\*" indicates a "0" or "1".

#### (3) Interrupt priority control register 2 (IP2)

Interrupt priority control register 2 (IP2) consists of 8 bits and specifies interrupt priority for overflow of timer 0 (bits 0 and 1), external interrupts 1 (bits 2 and 3), external interrupt 2 (bits 4 and 5) and external interrupt 3 (bits 6 and 7).

IP2 can be read or written by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP2 becomes 00H.

Figure 17-17 shows the configuration of IP2.



<sup>&</sup>quot;\*" indicates a "0" or "1".

Figure 17-17 IP2 Configuration

#### (4) Interrupt priority control register 3 (IP3)

Interrupt priority control register 3 (IP3) consists of 6 bits and specifies interrupt priority for overflow of timers 1 to 3 (bits 0 to 5).

IP3 can be read or written by the program. However, if writing to bits 6 and 7, always write those bits as "0". If read, a value of "0" will always be obtained for bits 6 and 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP3 becomes 00H.

Figure 17-18 shows the configuration of IP3.



<sup>&</sup>quot;0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-18 IP3 Configuration

<sup>&</sup>quot;\*" indicates a "0" or "1".

#### (5) Interrupt priority control register 4 (IP4)

Interrupt priority control register 4 (IP4) consists of 8 bits and specifies interrupt priority for external interrupt 4 (bits 0 and 1), external interrupt 5 (bits 2 and 3), external interrupt 6 (bits 4 and 5) and external interrupt 7 (bits 6 and 7).

IP4 can be read or written by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP4 becomes 00H.

Figure 17-19 shows the configuration of IP4.



"\*" indicates a "0" or "1".

Figure 17-19 IP4 Configuration

#### (6) Interrupt priority control register 5 (IP5)

Interrupt priority control register 5 (IP5) consists of 4 bits and specifies interrupt priority for overflow of timer 4 (bits 4 and 5) and SIO1 transmit buffer empty/transmit complete/receive complete (bits 6 and 7).

IP5 can be read or written by the program. However, if writing to bits 0 through 3, always write those bits as "0". If read, a value of "0" will always be obtained for bits 0 through 3.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP5 becomes 00H.

Figure 17-20 shows the configuration of IP5.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-20 IP5 Configuration

<sup>&</sup>quot;\*" indicates a "0" or "1."

#### (7) Interrupt priority control register 6 (IP6)

Interrupt priority control register 6 (IP6) consists of 8 bits and specifies interrupt priority for overflow of timer 5 (bits 0 and 1), SIO6 transmit buffer empty/transmit coplete/receive complete (bits 4 and 5) and SIO5 and SIO4 transmit-receive completion (bits 2, 3, 6 and 7).

IP6 can be read or written by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP6 becomes 00H.

Figure 17-21 shows the configuration of IP6.



Figure 17-21 IP6 Configuration

#### (8) Interrupt priority control register 7 (IP7)

Interrupt priority control register 7 (IP7) consists of 6 bits and specifies interrupt priority for overflow of timer 6 (bits 0 and 1), A/D conversion scan channel cycle complete/select mode complete (bits 2 and 3), and real-time counter output (bits 6 and 7).

IP7 can be read or written by the program. However, if writing to bits 4 and 5, always write those bits as "0". If read, a value of "0" will always be obtained for bits 4 and 5.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP7 becomes 00H.

Figure 17-22 shows the configuration of IP7.



"0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-22 IP7 Configuration

<sup>&</sup>quot;\*" indicates a "0" or "1."

#### (9) Interrupt priority control register 8 (IP8)

Interrupt priority control register 8 (IP8) consists of 8 bits and specifies interrupt priority for overflow of PWC0/matching of PWC0 and PWR0 (bits 0 and 1), overflow of PWC1/matching of PWC1 and PWR1 (bits 2 and 3), matching of PWC0 and PWR2 (bits 4 and 5) and matching of PWC1 and PWR3 (bits 6 and 7).

IP8 can be read or written by the program.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP8 becomes 00H.

Figure 17-23 shows the configuration of IP8.



<sup>&</sup>quot;0" indicates that a value of "0" must be written. If read, a value of "0" will be obtained.

Figure 17-23 IP8 Configuration

<sup>&</sup>quot;\*" indicates a "0" or "1".

#### (10) Interrupt priority control register 9 (IP9)

Interrupt priority control register 9 (IP9) consists of 2 bits and specifies interrupt priority for the overflow of timer 9 (bits 0 and 1).

IP9 can be read or written by the program. However, writes to bits 2 through 7 are invalid. If read, a value of "1" will always be obtained for bits 2 through 7.

When reset (RES signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap), IP9 becomes FCH.

Figure 17-24 shows the configuration of IP9.



Figure 17-24 IP9 Configuration

### Chapter 18

## **Bus Port Functions**

#### 18

## 18 Bus Port Functions

#### 18.1 Overview

The MSM66577 family can externally expand program memory (usually ROM) up to a maximum of 1MB and data memory (usually RAM) up to a maximum of 1MB. With the SELMBUS pin setting, a multiplexed bus type (address/data time division) or a separate bus type (independent address/data buses) can be selected for the bus port interface of the MSM66577 family.

Bus ports (A0 to A19, D0 to D7) and control signals (SELMBUS, ALE, PSEN, RD, WR) are used to access the external program memory and external data memory.

When the SELMBUS pin is at a high level, bus ports are configured as the separate bus with 20 address (A0 to A19) lines and 8 data (D0 and D7) lines and assigned as the secondary functions of port 0 (P0), port 1 (P1), port 2 (P2) and port 4 (P4). Unnecessary upper addresses can be reset as normal I/O ports.

PSEN (P3\_1) is used as a strobe signal to read the external program memory. RD (P3\_2) and WR (P3\_3) are used as read and write strobes for external data memory.

When the SELMBUS pin is at a low level, bus ports are configured as the multiplexed bus with 12 address (A8 to A19) lines and 8 address/data combined lines (D0 to D7) and assigned as the secondary functions of port 0 (P0), port 1 (P1), and port 2 (P2). Unnecessary upper addresses can be reset as normal I/O ports.

## 18.2 Port Operation

## 18.2.1 Port Operation When Accessing Program Memory

## Separate bus type (the SELMBUS pin at a high level)

When accessing internal program memory (addresses 0H to 1FFFFH with the EA pin at a high level), P0, P1, P2, P3\_1 and P4 operate as I/O ports.

When accessing external program memory (the  $\overline{EA}$  pin at a low level or addresses 20000H to FFFFH with the  $\overline{EA}$  pin at a high level), P0 operates as the program data input port, P1, P2, and P4 operate as address output ports, and P3 1 operates as the  $\overline{PSEN}$  output port.

If the  $\overline{EA}$  pin is at a low level, P0, P1, P2, P3\_1 and P4 are automatically switched (secondary function control registers and mode registers are set) to bus port and control signal functions (hereafter referred to as bus port functions) when reset ( $\overline{RES}$  signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap). If the  $\overline{EA}$  pin is at a high level, bus port functions are not automatically switched. It is necessary to switch to bus port functions before external program memory is accessed by setting secondary function control registers and mode registers on software.

Of the ports that are automatically set as bus port functions when the  $\overline{EA}$  pin is at a low level, if upper address or other output is unnecessary, then after reset, those ports can be operated as I/O ports by resetting their secondary function control register.

Table 18-1 lists the operation of P0, P1, P2, P3\_1 and P4 in the separate bus type during a program memory access.

Table 18-1 P0, P1, P2, P3\_1 and P4 Operation During Program Memory Access (Separate Bus Type)

| Memory to be     | Address                        | DO aparation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | P1, P2, P4       | D2 1 energtion   |  |  |
|------------------|--------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|--|--|
| accessed         | Address                        | P0 operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | operation        | P3_1 operation   |  |  |
| Internal program | When $\overline{EA} = H$ ,     | 1/0 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                  |                  |  |  |
| Internal program | 0H to 1FFFFH                   | I/O port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                  |                  |  |  |
|                  |                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | After set as     | After set as     |  |  |
|                  | When $\overline{EA} = H$ ,     | secondary secondary                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                  | secondary        |  |  |
| External pregram | 20000H to FFFFFH               | function output,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | function output, | function output, |  |  |
| External program |                                | program data input                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | address output   | PSEN output      |  |  |
|                  | When $\overline{EA} = L$ ,     | Dua anno de la instanta de la decensión de la |                  | PSEN output      |  |  |
|                  | 0H to FFFFFH Program data inpu |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Address output   | PSEN Output      |  |  |

## Multiplexed bus type (the SELMBUS pin at a low level)

When accessing internal program memory (addresses 0H to 1FFFFH with the EA pin at a high level), P0, P1, P2, P3\_1 and P4 operate as I/O ports.

When accessing external program memory (the  $\overline{EA}$  pin at a low level or addresses 20000H to FFFFH with the  $\overline{EA}$  pin at a high level), P0 operates as the address output and program data input port, P1 and P2 operate as addresses output ports, P3\_0 operates as the ALE output port, and P3\_1 operates as the  $\overline{PSEN}$  output port.

If the  $\overline{EA}$  pin is at a low level, P0, P1, P2, P3\_0 and P3\_1 are automatically switched (secondary function control registers and mode registers are set) to bus port and control signal functions (hereafter referred to as bus port functions) when reset ( $\overline{RES}$  signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap). If the  $\overline{EA}$  pin is at a high level, bus port functions are not automatically switched. It is necessary to switch to bus port functions before external program memory is accessed by setting secondary function control registers and mode registers on software.

Of the ports that are automatically set as bus port functions when the  $\overline{EA}$  pin is at a low level, if upper address or other output is unnecessary, then after reset, those ports can be operated as normal I/O ports by resetting their secondary function control register.

Table 18-2 lists the operation of P0, P1, P2, P3\_0 and P3\_1 in the multiplexed bus type during a program memory access.

Table 18-2 P0, P1, P2, P3\_0 and P3\_1 Operation During Program Memory Access (Multiplexed Bus Type)

| Memory to be            | Address                    | DO aparation | P1, P2, P4   | P3_1         | P3_0         |
|-------------------------|----------------------------|--------------|--------------|--------------|--------------|
| accessed                | Address                    | P0 operation | operation    | operation    | operation    |
| Internal program        | When $\overline{EA} = H$ , |              | 1/0          | port         |              |
| Internal program        | 0H to 1FFFFH               |              | 1/0          | port         |              |
|                         |                            | After set as | After set as | After set as | After set as |
|                         |                            | secondary    | secondary    | secondary    | secondary    |
|                         |                            | function     | function,    | function     | function     |
|                         | When $\overline{EA} = H$ , | output,      | address      | output, PSEN | output, ALE  |
| Furtament is no suppose | 20000H to FFFFFH           | address      | output       | output       | output       |
| External program        |                            | output/pro-  |              |              |              |
|                         |                            | gram data    |              |              |              |
|                         |                            | input        |              |              |              |
|                         |                            | Address      | Address      | PSEN output  | ALE output   |
|                         | When $\overline{EA} = L$ , | output/pro-  | output       |              |              |
|                         | 0H to FFFFFH               | gram data    |              |              |              |
|                         |                            | input        |              |              |              |

## 18.2.2 Port Operation When Accessing Data Memory

## Separate bus type (the SELMBUS pin at a high level)

When accessing internal data memory (addresses 0H to 11FFH), P0, P1, P2, P3\_2, P3\_3 and P4 operate as I/O ports.

When accessing external data memory (addresses 1200H to FFFFFH), set ports P0, P1, P2, P3\_2, P3\_3 and P4 to their secondary functions so that P0 operates as a data I/O pin, P1, P2, and P4 operate as address output pins, and P3\_2 and P3\_3 operate as  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  output pins.

If the  $\overline{\text{EA}}$  pin is at a low level, P0, P1, P2 and P4 are automatically set as bus ports (secondary function control registers and mode registers are set) when reset ( $\overline{\text{RES}}$  signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap). Because P3\_2 and P3\_3 are automatically set as input ports instead of  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  output pins, before external data memory is accessed, they must be set as secondary function outputs.

Of the ports that are automatically set as bus port functions when the  $\overline{EA}$  pin is at a low level, if upper address or other output is unnecessary, then after reset, those ports can be operated as I/O ports by resetting their secondary function control register.

Table 18-3 lists the operation of P0, P1, P2, P3\_2, P3\_3 and P4 in the separate bus type during a data memory access.

Table 18-3 P0, P1, P2, P3\_2, P3\_3 and P4 Operation During Data Memory Access (Separate Bus Type)

| Data to be    | Address         | P0 operation        | P1, P2, P4          | P3_2, P3_3       |
|---------------|-----------------|---------------------|---------------------|------------------|
| accessed      | Address         | Po operation        | operation           | operation        |
| Internal data | 0H to 11FFH     |                     | I/O port            |                  |
| External data | 1200H to FFFFFH | After set as        | After set as        | After set as     |
|               |                 | secondary           | secondary           | secondary        |
|               |                 | function output *1, | function output *1, | function output, |
|               |                 | data I/O            | address output      | RD and WR output |

<sup>\*1</sup> If the  $\overline{EA}$  pin is at a low level, P0, P1, P2 and P4 are automatically set as secondary function outputs when reset.

## Multipexed bus type (the SELMBUS pin at a low level)

When accessing internal data memory (addresses 0H to 11FFH), P0, P1, P2, P3\_0, P3\_2 and P3\_3 operate as I/O ports.

When accessing external data memory (addresses 1200H to FFFFFH), set ports P0, P1, P2, P3\_0, P3\_2 and P3\_3 to their secondary functions so that P0 operates as an address output and data I/O pin, P1 and P2 operate as address output pins, P3\_0, P3\_2 and P3\_3 operate as ALE,  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  output pins.

If the  $\overline{EA}$  pin is at a low level, P0, P1 and P2 are automatically set as bus ports (secondary function control registers and mode registers are set) when reset ( $\overline{RES}$  signal input, execution of a BRK instruction, overflow of the watchdog timer, opcode trap). Because P3\_2 and P3\_3 are automatically set as input ports instead of  $\overline{RD}$  and  $\overline{WR}$  output pins, before external data memory is accessed, they must be set as secondary function outputs.

Of the ports that are automatically set as bus port functions when the  $\overline{EA}$  pin is at a low level, if upper address or other output is unnecessary, then after reset, those ports can be operated as I/O ports by resetting their secondary function control register.

Table 18-4 lists the operation of P0, P1, P2, P3\_0, P3\_2 and P3\_3 in the multiplexed bus type during a data memory access.

Table 18-4 P0, P1, P2, P3\_0, P3\_2 and P3\_3 Operation During Data Memory Access (Multiplexed Bus Type)

| Data to be    | Address         | DO operation        | P1, P2              |                                                        |
|---------------|-----------------|---------------------|---------------------|--------------------------------------------------------|
| accessed      | Address         | P0 operation        | operation           | operation                                              |
| Internal data | 0H to 11FFH     |                     | I/O port            |                                                        |
|               |                 | After set as        | After set as        | After set as                                           |
| External data | 1200H to FFFFFH | secondary           | secondary           | secondary                                              |
| External data |                 | function output *1, | function output *1, | function output,                                       |
|               |                 | data I/O            | address output      | ALE, $\overline{\text{RD}}$ and $\overline{\text{WR}}$ |
|               |                 |                     |                     | output                                                 |

<sup>\*1</sup> If the EA pin is at a low level, P0, P1 and P2 are automatically set as secondary function outputs when reset.

19

## 18.3 External Memory Access

## 18.3.1 External Program Memory Access

## Separate bus type (the SELMBUS pin at a high level)

A program memory space of 1MB maximum (00000H to FFFFFH) can be accessed with the 16-bit program counter (PC) and 4-bit code segment register (CSR). When the  $\overline{\text{EA}}$  pin is set to a high level, program addresses from 10000H to FFFFFH access external program memory. When the  $\overline{\text{EA}}$  pin is set to a low level, program addresses from 00000H to FFFFFH access external program memory.

If the  $\overline{EA}$  pin is set to a high level and external program memory is to be used from 10000H to FFFFFH, then P0, P1, P2 and P4 must be set as secondary function outputs. In addition, P3\_1 (PSEN output) must also be set as a secondary function output.

Figure 18-1 shows an example connection of external program memory (ROM) in the separate bus type.



Figure 18-1 External ROM Connection Example (Separate Bus Type)

## Multiplexed bus type (the SELMBUS pin at a low level)

A program memory space of 1MB maximum (00000H to FFFFFH) can be accessed with the 16-bit program counter (PC) and 4-bit code segment register (CSR). When the  $\overline{\text{EA}}$  pin is set to a high level, program addresses from 10000H to FFFFFH access external program memory. When the  $\overline{\text{EA}}$  pin is set to a low level, program addresses from 00000H to FFFFFH access external program memory.

If the  $\overline{EA}$  pin is set to a high level and external program memory is to be used from 10000H to FFFFFH, then P0, P1 and P2 must be set as secondary function outputs. In addition, P3\_0 and P3\_1 ( $\overline{PSEN}$  output) must also be set as a secondary function output.

Figure 18-2 shows an example connection of external program memory (ROM) in the multiplexed bus type.



Figure 18-2 External ROM Connection Example (Multiplexed Bus Type)

40

## 18.3.2 External Data Memory Access

## Separate bus type (the SELMBUS pin at a high level)

A data memory space of 1MB maximum (0000H to FFFFFH) can be accessed with the 16-bit RAM address pointer (RAP) and 4-bit data segment register (DSR). Data addresses from 0000H to 11FFH access internal data memory. Data addresses from 1200H to FFFFFH access external data memory. External data memory is accessed in 8-bit (byte) units.

If external data memory is to be used, P0 must be set as a secondary function output (memory data I/O). Also, corresponding to the memory address, P1, P2 and P4 must be set as secondary function outputs (address outputs). In addition, P3\_2 and P3\_3 must be set as secondary function outputs (WR and RD outputs).

If the  $\overline{EA}$  pin is at a low level, P0, P1, P2 and P4 automatically become secondary function outputs.

If necessary, insert external pull-up resistors at the WR and RD pins.

Figure 18-3 shows an example connection of external data memory (RAM) in the separate bus type.



Figure 18-3 External RAM Connection Example (Separate Bus Type)

## Multiplexed bus type (the SELMBUS pin at a low level)

A data memory space of 1MB maximum (0000H to FFFFFH) can be accessed with the 16-bit RAM address pointer (RAP) and 4-bit data segment register (DSR). Data addresses from 0000H to 11FFH access internal data memory. Data addresses from 1200H to FFFFFH access external data memory. External data memory is accessed in 8-bit (byte) units.

If external data memory is to be used, P0 must be set as a secondary function output (memory data I/O). Also, corresponding to the memory address, P1 and P2 must be set as secondary function outputs (address outputs). In addition, P3\_0, P3\_2 and P3\_3 must be set as secondary function outputs (WR and RD outputs).

If the  $\overline{EA}$  pin is at a low level, P0, P1, P2 and P4 automatically become secondary function outputs.

If necessary, insert external pull-up resistors at the WR and RD pins.

Figure 18-4 shows an example connection of external data memory (RAM) in the multiplexed bus type.



Figure 18-4 External RAM Connection Example (Multiplexed Bus Type)

10

## 18.4 External Memory Access Timing

## 18.4.1 External Program Memory Access Timing

Figures 18-5 and 18-6 show the timing for accessing external program memory in the separate bus type.

Figure 18-7 and 18-8 show the timing for accessing external program memory in the multiplexed bus type.

For external memory with slow access times, a function is available to insert wait cycles (see Section 4.4, "READY Function"). Use this function to match the access time of the external memory to be used. The ROMRDY register specifies the number of wait cycles to insert.

For actual AC characteristics, refer to Chapter 20, "Electrical Characteristics".



Figure 18-5 External Program Memory Access Timing (No Wait Cycles) (Separate Bus Type)



Figure 18-6 External Program Memory Access Timing (2 Wait Cycles) (Separate Bus Type)

Figure 18-7 External Program Memory Access Timing (No Wait Cycles) (Multiplexed Bus Type)



Figure 18-8 External Program Memory Access Timing (2 Wait Cycles)
(Multiplexed Bus Type)

## 18.4.2 External Data Memory Access Timing

Figures 18-9 and 18-10 show the timing for accessing data program memory in the separate bus type.

For external memory with slow access times, a function is available to insert wait cycles (see section 4.4, "Ready Function"). Use this function to match the access time of the external memory to be used. Compared to internal data memory accesses, when accessing external data memory, 2 or 3 wait cycles are automatically inserted for each 1 byte access. The RAMRDY register specifies the number of wait cycles to insert in addition to the 3 to 4 cycles that are automatically inserted.

For actual AC characteristics, refer to Chapter 20, "Electrical Characteristics".



Figure 18-9 External Data Memory Access Timing (Word Access: No Wait Cycles) (Separate Bus Type)



Figure 18-10 External Data Memory Access Timing (Byte Access: 2 Wait Cycles) (Separate Bus Type)



Figure 18-11 External Data Memory Access Timing (Word Access: No Wait Cycles)
(Multiplexed Bus Type)



Figure 18-12 External Data Memory Access Timing (Byte Access: 2 Wait Cycles) (Multiplexed Bus Type)

## 18.5 Notes Regarding Usage of Bus Port Function

## 18.5.1 Dummy Read Strobe Output

The MSM66577 family of microcontrollers utilize the nX-8/500S, Oki's proprietary 16-bit CPU core.

The instruction code of the nX-8/500S uses 8 bits as its basic unit and consists of 1 to 6 bytes. Instructions are classified as NATIVE instructions for commonly performed operations or as COMPOSIT instructions to realize a wide range of addressing. NATIVE instructions consist of 1 to 4 bytes and are used to achieve high coding and processing efficiency.

COMPOSIT instructions consist of a 1 to 3 byte address field (PREFIX) and a 1 to 3 byte operation field (SUFFIX). The PREFIX and SUFFIX are combined to realize a wide range of addressing.

If instructions accompanying a write to external data memory are to be executed, an unnecessary  $\overline{\text{RD}}$  signal (dummy  $\overline{\text{RD}}$ ) will be output before the actual access ( $\overline{\text{WR}}$  signal) if some of those instructions are COMPOSIT instructions, (This is limited to cases where the PREFIX specifies an external data memory area.) For byte and bit accesses, a dummy RD signal is output once. For word accesses, a dummy RD signal is output twice.

Some considerations must be exercised in cases where the above mentioned read strobe affects the internal operation of peripheral devices.

Using the bus port function, the specific example of connecting and accessing the 8251 serial interface LSI chip as a peripheral device will be described.

## [Example]

When the microcomputer writes to the transmit buffer of the 8251, if COMPOSIT instructions are used with the above conditions, output of the dummy read strobe will cause data in the receive buffer to be read. If receive data exists in the receive buffer, the 8251 will determine that the CPU has finished reading data, and the receive ready output signal will be reset.

Some considerations must be exercised in cases where peripheral devices operate differently when read and write operations are performed at the same address.

These types of problems can be avoided by using NATIVE instructions.

For example, a dummy strobe is not output if load and store instructions (L, LB, ST, STB) are used to read from and write to the accumulator (ACC). (If programming in C language, these sections can be written as assembler functions.)

If general-purpose memory (RAM or ROM) is connected to a bus port, the problems described above should not occur. Problems only occur if a connected peripheral device (functional device) is accessed using COMPOSIT instructions as described above and the read strobe affects the internal operation of the peripheral device.

Connect peripheral devices to bus ports based on an understanding of the operation described herein and the function and operation of peripheral devices.

Tables 18-5 and 18-6 list PREFIX and SUFFIX combinations (instructions) that output a dummy RD when an external data memory area is accessed.

In the tables, PREFIX addressing is inserted at the "\*" in the SUFFIX column.

| SUFFIX             |                  | _ | PREFIX  |                  |
|--------------------|------------------|---|---------|------------------|
| Instruction symbol | Instruction code |   | *       | Instruction code |
| SB *               | 08+bit           |   | Rn      | 68+n             |
| RB *               | 00+bit           |   | [X1]    | В0               |
| SBR *              | B8               |   | [DP]    | B2               |
| RBR *              | B9               |   | [DP-]   | B1               |
| TBR *              | CA               |   | [DP+]   | B3               |
| MB *.bit, C        | 18+bit           |   | off     | B5               |
| MBR *.bit, C       | ВВ               |   | dir     | B7               |
| MBR C, *.bit       | BA               |   | N16[X1] | B8               |
| MOVB *,A           | AA               |   | N16[X2] | B9               |
| MOVB *,#N8         | AB               |   | n7[DP]  | 9B               |
| CLRB *             | C7               |   | n7[USP] | 9B               |
| FILLB *            | D7               |   | [X1+A]  | BA               |
|                    |                  |   | [X1+R0] | ВВ               |

Table 18-6 Instructions (Word Manipulations) in Which a Dummy RD Occurs Twice (PREFIX and SUFFIX Combinations)

| SUFFIX             |                  | PREFIX   |                  |
|--------------------|------------------|----------|------------------|
| Instruction symbol | Instruction code | *        | Instruction code |
| MOV *,A            | AA               | ERn      | 64+n             |
| MOV *,#N16         | AB               | <br>[X1] | A0               |
| CLR *              | C7               | [DP]     | A2               |
| FILL *             | D7               | [DP-]    | A1               |
|                    |                  | [DP+]    | A3               |
|                    |                  | off      | A5               |
|                    |                  | dir      | A7               |
|                    |                  | N16[X1]  | A8               |
|                    |                  | N16[X2]  | A9               |
|                    |                  | n7[DP]   | 8B               |
|                    |                  | n7[USP]  | 8B               |
|                    |                  | [X1+A]   | AA               |
|                    |                  | [X1+R0]  | AB               |

## 18.5.2 External Bus Access Timing

The MSM66577 family employs a high-speed separate address and data bus type for external bussing.

If the MSM66577 family runs at high speed, the read and write strobe signals may be in their logically active states before the address outputs are changed and then set up. Care must be taken for AC characteristics when peripheral devices, such as general-purpose SRAMs, whose address outputs have to be set up on the rising edge of the WR signal are connected using the bus port function.

Refer to the AC characteristics (Chapter 20, "Electrical Characteristics") for operating frequencies to be used.

The AC characteristic values are given under the conditions listed below:

- Load capacitor C<sub>I</sub> = 50 pF
- Measurement point for AC timing

```
V_{OL}/V_{OH} = 0.8 \text{ V}/2.0 \text{ V for } V_{DD} = 4.5 \text{ to } 5.5 \text{ V}

V_{OL}/V_{OH} = 0.16V_{DD}/0.44V_{DD} \text{ for } V_{DD} = 2.4 \text{ to } 3.6 \text{ V}
```

- Ambient temperature Ta = −30 to +70°C
- Power supply voltage V<sub>DD</sub> = 2.4 to 3.6 V/4.5 to 5.5 V

In order to set up the address value before the WR signal is made to its logically active state under the above conditions, either of the following operating frequencies should be provided:

```
• f = 11 MHz or less for V_{DD} = 2.4 to 3.6 V
```

• f = 20 MHz or less for  $V_{DD}$  = 4.5 to 5.5 V

The upper limits of operating frequencies will actually be varied according to conditions (load capacitance and supply voltages on the printed circuit boards) of products to which the MSM66577 family is to be applied.

The contents described above should be considered to connect the peripheral devices, such as general-purpose SRAMs.

## Chapter 19

# Flash Memory

## 19. Flash Memory

## 19.1 Overview

The MSM66577 family provides a flash ROM version, which is equipped with an electrically programmable non-volatile memory (flash memory) as the internal program memory. With three types of flash memory programming modes, the flash ROM version can be programmed even after being installed in a system.

There are two types of flash ROM version: the MSM66Q577 operates in the range of 4.5 to 5.5 V and the MSM66Q577LY operates in the range of 3.0 to 3.6 V. Select the device that matches the voltage range to be used.

#### 19.2 Features

Power supply voltage

MSM66Q577 (4.5 to 5.5 V operation) ... Can be programmed with a single 4.5 to

5.5 V power supply

MSM66Q577LY (3.0 to 3.6 V operation) ... Can be programmed with a single 3.0 to

3.6 V power supply

Programming modes

Flash memory has the following three programming modes.

· Parallel mode ... Can be programmed with a PROM writer of MINATO

**ELECTRONICS** make

· Serial mode ... Can be programmed with a flash memory writer

· User mode ... Can be programmed by program execution.

Programming blocks

Flash memory is programmed in blocks of 128-byte units.

Auto-erase function

Since an auto-erase function is provided to automatically erase the block to be written to prior to programming, it is unnecessary to erase flash memory before programming.

Programming Time

Programming time for the flash memory is listed below.

· Programming (128 byte unit) ... Approx. 40 ms (at 4.5 to 5.5 V)

Approx. 50 ms (at 3.0 to 3.6 V)

Write protect function

Flash memory has a built-in power-on write protect function that automatically disables programming for approximately 20 ms after power is turned on.

In addition, there is an acceptor function to prevent incorrect programming in the user mode due to a running of out-of-control program.

#### Security function

Flash memory has a built-in security function that disables reading of contents of memory externally and / or programming externally. The security function is set in the serial mode, but once the security function is set, contents of memory cannot be externally read from or programming cannot be performed externally, in any programming mode.

The security function cannot be set in the parallel mode or in the user mode.

## 19.3 Programming Modes

Flash memory has the following three programming modes. Since an auto-erase function is provided for all the programming modes, it is not necessary to erase the flash memory prior to programming.

Figure 19-1 shows a block diagram of the flash memory programming modes.

## (1) Parallel mode

Programming in this mode is performed with a PROM writer of MINATO ELECTRONICS make. A special program to write to flash memory is unnecessary.

In the parallel mode, connect Oki Electrics' flash memory program conversion adapter (model no. MTP66573) to a ROM writer with model no. 1893 (version 1.20d or later) or 1931 (version 1.20d or later) manufactured by MINATO ELECTRONICS, Inc. and then perform the programming.

#### (2) Serial mode

Programming in this mode is performed with a flash memory writer. A special program to write to flash memory is unnecessary. Flash memory can be programmed by a single microcontroller or after it is mounted on a printed circuit board.

In the serial mode, connect a flash memory writer (model no. PW66K) or a flash microcontroller programmer (model no. AF200) manufactured by YDC Corporation to the two microcontroller pins (P9\_2, P9\_3), the  $\overline{EA}$  pin, and  $V_{DD}$  and GND pins, and then perform the programming. Programming is performed while the microcontroller is in the reset or STOP modes.

## (3) User mode

In this mode, instead of using a programming writer, programming is performed by executing a program that writes to flash memory. Programming can be performed after the device is mounted on the circuit board.

In the user mode, programming is performed by executing a write program already stored (using either the serial mode or parallel mode) in flash memory of the microcontroller.



- \*1: MINATO is MINATO ELECTRONICS, Inc.
- \*2: AF200 is a trademark of YDC Corporation
- \*3: YDC is YDC Corporation

Figure 19-1 Block Diagram of Programming Modes

#### 19.4 Parallel Mode

#### 19.4.1 Overview of the Parallel Mode

Programming in the parallel mode is performed with a PROM writer with model no. 1893 (version 1.20d or later) or 1931 (version 1.20d or later) manufactured by MINATO ELECTRONICS, Inc. The writing and reading of programs is performed by connecting Oki Electric's flash memory program conversion adapter (MTP66573) to a PROM writer. Figure 19-2 shows a connection diagram. Since an auto-erase function is provided, flash memory does not have to be erased prior to programming.

[Note] The security function cannot be set in the parallel mode.

## 19.4.2 PROM Writer Setting

For the details of PROM writer settings, refer to the manual of the PROM writer used.

When writing data, be sure to use the device code "MSM66Q577," which has been registered exclusively for the MSM66Q577, or "MSM66Q577L," which has been registered exclusively for the MSM66Q577L. In addition, never use the Silicon Signature mode, which automatically sets a device code when an LSI is inserted. Refer to the PROM writer manual for details.

## 19.4.3 Flash Memory Programming Conversion Adapter

Use Oki Electric's flash memory program conversion adapter (MTP66573).



Figure 19-2 Parallel Mode Connection Diagram

#### 19.5 Serial Mode

#### 19.5.1 Overview of the Serial Mode

Programming in the serial mode is performed with a flash memory writer. Programs can be written or read by a single microcontroller or after it is mounted on a printed circuit board.

In the serial mode, the writing and reading of programs is performed by connecting the flash memory writer PW66K or YDC Corporation's flash microcontroller programmer AF200 to the two microcontroller pins (P9\_2, P9\_3), the  $\overline{\text{EA}}$  pin, and  $V_{DD}$  and GND pins. Programming and reading are performed while the microcontroller is in the reset or STOP mode. Since an auto-erase function is provided, flash memory does not have to be erased prior to programming.

## 19.5.2 Serial Mode Settings

The serial mode is set automatically by connecting the flash microcontroller programmer to the specific pins and then executing a programming or read operation. When writing or reading is complete, the serial mode setting is released.

#### (1) Pins used in serial mode

Table 19-1 lists the pins used in the serial mode.

The serial mode can only be set while the microcontroller is in reset or STOP mode. Be careful of the high voltage (approx. 9 V) that the flash microcontroller programmer applies to the  $\overline{EA}$  pin to set the serial mode.  $V_{DD}$  is connected to monitor  $V_{DD}$  of the user system.

Table 19-1 List of Pins Used in Serial Mode

| Pin name        | Flash memory function                          |
|-----------------|------------------------------------------------|
| P9_2            | FLACK (serial clock input)                     |
| P9_3            | FLADAT (serial data I/O)                       |
| ĒĀ              | FLAMOD (high voltage input to set serial mode) |
| V <sub>DD</sub> | User system V <sub>DD</sub> monitor            |
| GND             | Ground                                         |

## [Note]

During the serial mode, the voltage higher than the power supply (approx. 9 V) is applied to the  $\overline{EA}$  pin by the flash microcontroller programmer.

19

## (2) Serial mode connection circuit

In the serial mode, the flash memory writer (PW66K) or the flash microcontroller programmer (AF200) must be connected to the P9\_2, P9\_3,  $\overline{\text{EA}}$ ,  $V_{DD}$  and GND pins of the flash ROM version in the user system. In addition, install a switch in the user system to cut off the user system during programming and reading in the serial mode.

Figure 19-3 shows serial mode connection circuit example 1.



Figure 19-3 Serial Mode Connection Circuit Example 1

If not possible to install a switch in the user system, do not use pins P9\_2 and P9\_3 with the user system and connect them only to the flash microcontroller programmer. Also, connect each of the P9\_2, P9\_3 and  $\overline{\text{EA}}$  pins through a resistor of approximately 100 k $\Omega$  to V<sub>DD</sub>.

Figure 19-4 shows serial mode connection circuit example 2.

#### [Note]

The programming and reading in the serial mode are performed while the microcontroller is in the reset or STOP mode. To execute the programming/reading during reset, apply "L" level to the  $\overline{\text{RES}}$  pin. In the case where the flash microcontroller programmer does not apply "L" level to the  $\overline{\text{RES}}$  pin, the "L" level should be applied by the user application system.



Figure 19-4 Serial Mode Connection Circuit Example 2

## (3) Serial mode programming method

Programming in the serial mode is performed with the use of a flash memory writer (PW66K) or a flash microcontroller programmer (AF200).

The procedure for programming with the flash microcontroller programmer is listed below. Refer to the PW66K and AF200 User's Manuals for details of the flash microcontroller programmer.

- 1) Connect the flash microcontroller programmer to the P9\_2, P9\_3,  $\overline{EA}$ , V<sub>DD</sub> and GND pins of the flash ROM version.
- 2) Set the microcontroller to the reset or STOP mode.
- The flash microcontroller will generate a protocol error if other than reset or STOP mode is set
- 3) Perform the programming or read operation with the flash microcontroller programmer.
- · The serial mode is set automatically.
- 4) Verify that operation of the flash microcontroller programmer has been completed correctly.
- · The serial mode is released automatically.
- 5) Release reset or the STOP mode.
- · The microcontroller runs the program that has been written.

## (4) Setting of security function

The security function can be set or reset in the serial mode. For the setting method, refer to the User's Manual for the flash microcontroller programmer.

When the security function is set, the flash memory outputs 0s, for external reading, throughout its entire area and programming are disabled, in all programming modes.

## (5) Notes on use of serial mode

If programming is performed during the STOP mode, while programming is in progress, do not generate an interrupt or a reset via the  $\overline{\text{RES}}$  pin input. If generated, the CPU may run out of control after the serial mode is released. During the STOP mode, execution of BRK instructions, overflow of the watchdog timer, and opcode traps will not generate reset. If an interrupt or reset is generated, reprogram the entire flash memory area.

In addition, when programming in the serial mode is performed during the STOP mode, do not allow external interrupts 6 and 7 to be generated (set EXINT 6 and 7 valid edges of EXI1CON to interrupt input invalid).

#### 19.6 User Mode

#### 19.6.1 Overview of the User Mode

Instead of using a programming writer, programming in the user mode is performed by executing a program on the user's system to write to flash memory. Programming can be performed even after the microcontroller is mounted on a circuit board in the user's system. Since an auto-erase function is provided, flash memory does not have to be erased prior to programming.

The user mode executes a program to write to flash memory. The program is prepared to contain commands to execute the write operation and the I/O method of data to be written. The program must be written (using either the serial mode or parallel mode) to flash memory in advance.

Figure 19-5 shows a block diagram of the user mode.

## [Note]

The security function cannot be set in the user mode.



Figure 19-5 User Mode Block Diagram

## 19.6.2 User Mode Programming Registers

The MSM66577 family has internal special function registers (SRFs) for programming with the user mode. Programming in the user mode is performed by controlling the following registers: the flash memory control register (FLACON), the flash memory address register (FLAADRS) and the flash memory acceptor (FLAACP).

Table 19-2 lists a summary of the SFRs for the user mode.

Table 19-2 Summary of SFRs for User Mode

| Address | Nome                  | Symbol | Symbol  | R/W  | 8/16      | Initial   | Reference |
|---------|-----------------------|--------|---------|------|-----------|-----------|-----------|
| [H]     | Name                  | (byte) | (word)  | H/VV | Operation | value [H] | page      |
| 00F0 ☆  | Flash memory acceptor | FLAACP | _       | W    | 8         | "0"       | 19-11     |
| 00F1 ☆  | Flash memory control  | FLACON | _       | R/W  | 8         | C6        | 19-12     |
| UUFIX   | register              | FLACON |         |      |           |           |           |
| 00F2 ☆  | Flash memory address  | _      | FLAADRS | R/W  | 16        | Undefined | 19-11     |
| 00F3    | register              | _      | FLAADRS | H/VV | 16        | Undelined | 19-11     |

#### Notes:

- 1. A star (☆) in the address column indicates a missing bit.
- 2. For details, refer to Chapter 21, "Special Function Registers (SFRs)".

## 19.6.3 Description of User Mode Registers

## (1) Flash memory address register (FLAADRS)

Bits 3 to 12 (FA7 to FA16) of the FLAADRS register set the flash memory address to be programmed.

Figure 19-6 shows the configuration of FLAADRS.



Figure 19-6 FLAADRS Configuration

## (2) Flash memory acceptor (FLAACP)

FLAACP is an acceptor used when data is to be set in the flash memory control register. FLAACP is set to "1" when the program writes n5H, nAH (n = 0 to F) consecutively. Programming the flash memory resets FLAACP to "0".

Figure 19-7 shows the FLAACP configuration.



Figure 19-7 FLAACP Configuration

## (3) Flash memory control register (FLACON)

FLACON is a 4-bit register that controls programming and operation of the flash memory.

Figure 19-8 shows the FLACON configuration.



Figure 19-8 FLACON Configuration

Writes to bits 0, 3, and 4 of FLACON are valid after consecutively writing n5H, nAH (n = 0 to F) to FLAACP so that the flash memory acceptor is set to "1". FLAACP is reset to "0" after the flash memory is programmed. To reprogram the flash memory, it is necessary to once again set the flash memory acceptor to "1". Also, while the security is being set, it is not able to write to bits 0, 3, and 4 of the FLACON.

## [Description of each bit]

· PRG (bit 0)

If PRG (bit 0) of FLACON is set to "1", after the execution of one instruction, the CPU will enter the hold state and data at internal RAM addresses 300H through 37FH will be transferred to flash memory. Then, a flash memory block will be cleared by the auto-erase function and the write operation performed.

After programming is completed, the hold state is released and this bit is reset to "0". <u>Prior to programming</u>, set the address to be written in FLAADRS and the data to be written in internal RAM addresses 300H to 37FH.

#### Notes:

- If an interrupt occurs during programming of the flash memory, processing of the interrupt is suspended. The interrupt is processed after programming is completed.
- If reset is initiated by input to the RES pin during programming of the flash memory, the reset is processed after programming is normally completed in the flash memory.

Figure 19-9 shows the relationship between internal RAM and flash memory.



Figure 19-9 Relation between Internal RAM and Flash Memory

## · FCLK0, FCLK1 (bits 3,4)

FCLK0 (bit 3) and FCLK1 (bit 4) of the FLACON register are bits that set the clock that transfers data from internal RAM addresses 300H through 37FH to flash memory. At reset, since both FCLK0 and FCLK1 become "0", 1/16CLK will be selected as the transfer clock.

Set FCLK0 and FCKL1 such that the transfer clock frequency is <u>10 MHz or less for the MSM66Q577 (4.5 to 5.5 V programming voltage) and 6.6 MHz or less for the MSM66Q577LY (3.0 to 3.6 V programming voltage).</u>

## · AMPOFF (bit 5)

AMPOFF (bit 5) of FLACON is a bit that is provided to control the sense amplifiers of the flash memory. However, the sense amplifiers constantly have intermittent access to the flash memory regardless of the state of this bit, in which case the flash memory enters the low power mode.

## 19.6.4 User Mode Programming Example

## (1) User mode programming flowchart example

Figure 19-10 shows a flowchart for user mode programming of flash memory. Since an auto-erase function is prepared, flash memory does not have to be erased prior to programming.



Figure 19-10 Programming Flowchart Example

19

## (2) User mode programming program example

Listed below is an example program that programs data to flash memory addresses 5500H through 557FH (128 bytes) and then verifies the data of those 128 bytes.

It is assumed that the data to be programed has already been stored in internal RAM addresses 300H through 37FH.

|     | MOV<br>MOVB                                | FLAADRS,#0550H<br>FLAACP,#05H                                                                                                                                                                    | Set the start address (5500H) for programming.                                                                                                              |
|-----|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | MOVB FLACP,#03H<br>MOVB FLACON,#11H<br>NOP | Set the flash memory acceptor. Set the PRG flag. After execution of one instruction, the hold state is entered and programming begins. When programming is complete, the hold state is released. |                                                                                                                                                             |
|     | MOV<br>MOV<br>SDD                          | DP,#300H<br>ER0,#5500H                                                                                                                                                                           | Set the internal RAM address in DP.<br>Set the flash memory address in ER0.<br>Set the data descriptor.                                                     |
| LOO | P:                                         |                                                                                                                                                                                                  |                                                                                                                                                             |
|     | LC<br>CMP                                  | A, [ER0]<br>A, [DP+]                                                                                                                                                                             | Load flash memory data into the accumulator.<br>Compare accumulator and internal RAM data,<br>then increment the internal RAM address by +2.                |
|     | JC<br>ADDB<br>JBR                          | NE,ERR<br>R0,#02H<br>R0.7,LOOP                                                                                                                                                                   | If they are not equal, jump to the error routine. Increment the flash memory address by +2. If verification of the 128 bytes is not complete, jump to LOOP. |

Note: If programming has been performed by an external program, the programmed data cannot be verified.

Perform error processing.

#### 19.6.5 Notes on Use of User Mode

ERR:

Note the following items when generating a program to be used with the user mode.

- If an interrupt occurs during programming of the flash memory, processing of the interrupt is put on hold. The interrupt is processed after programming is completed.
- If reset is initiated by input to the RES pin during programming of the flash memory, the
  reset is processed. However, the flash memory area that was in the process of being
  programmed will have been incorrectly programmed. If reset is initiated during
  programming, reprogram the flash memory area that was in the process of being
  programmed.
- Do not program to the flash memory area that contains the programming program being executing. (After programming is completed, the CPU program control will run out of control.)
- · Development tools (emulator) cannot evaluate programming or erasing.

#### 19.7 Notes on Program

#### (1) Programming of flash memory immediately after power-on

Programming to flash memory is automatically disabled for approximately 20 ms (for both 4.5 to 5.5 V and 3.0 to 3.6 V devices) after power is turned on. Therefore, if flash memory is to be programmed immediately after power is turned on, wait for the above time by guaranteeing a power-on reset time.

#### (2) Note on STOP mode release

Flash memory requires a standby time of at least  $50 \,\mu s$  when the STOP mode is released. Therefore, set the standby control register (SBYCON) to guarantee the stabilization time for main clock (OSCCLK) oscillation when the STOP is released.

#### (3) Supply voltage sense reset function

If the internal ROM (high level input to the  $\overline{EA}$  pin) of the MSM66Q577LY/MSM66Q577 is operative, the reset function is implemented at a supply voltage of 3 V or less for the MSM66Q577 (the version operating in the range of 4.5 to 5.5 V) and at a supply voltage of 1.5 V or less for the MSM66Q577LY (the version operating in the range of 3.0 to 3.6 V). Programming is automatically disabled for approximately 20 ms after the reset function is implemented. Also, the reset function is not implemented during the STOP mode (only when oscillation of the main clock is terminated).

## Chapter 20

## **Electrical Characteristics**

## 20. Electrical Characteristics

## 20.1 Absolute Maximum Ratings

| Parameter                    | Symbol           | Cond                     | dition           | Rated value              | Unit |
|------------------------------|------------------|--------------------------|------------------|--------------------------|------|
| Digital power supply voltage | $V_{DD}$         |                          | MSM66577/Q577    | -0.3 to +7.0             | V    |
| Digital power supply voltage | <b>V</b> DD      |                          | MSM66577L/Q577LY | -0.3 to +4.6             | V    |
| Input voltage                | VI               | GND = AGND               | _                | $-0.3$ to $V_{DD} + 0.3$ | V    |
| Output voltage               | Vo               | = 0 V<br>Ta = 25°C       | _                | $-0.3$ to $V_{DD} + 0.3$ | V    |
| Analog reference voltage     | $V_{REF}$        | 14 - 25 5                | _                | $-0.3$ to $V_{DD} + 0.3$ | V    |
| Analog input voltage         | $V_{AI}$         |                          | _                | -0.3 to V <sub>REF</sub> | V    |
| Power dissipation            | $P_{D}$          | Ta = 70°C<br>per package | 100-pin TQFP     | 650                      | mW   |
| Storage temperature          | T <sub>STG</sub> | _                        |                  | -50 to +150              | °C   |

## **20.2 Recommended Operating Conditions**

| Parameter                | Symbol           | Cond             | dition                                   | Range                      | Unit        |           |                           |            |
|--------------------------|------------------|------------------|------------------------------------------|----------------------------|-------------|-----------|---------------------------|------------|
|                          |                  | MSM66577         | f <sub>OSC</sub> ≤ 30 MHz                | 4.5 to 5.5                 |             |           |                           |            |
| Digital power supply     | $V_{DD}$         | MSM66577L        | f <sub>OSC</sub> ≤ 14 MHz                | 2.4 to 3.6                 | V           |           |                           |            |
| voltage                  |                  | <b>V</b> DD      | עט י                                     | <b>V</b> DD                | <b>V</b> DD | MSM66Q577 | f <sub>OSC</sub> ≤ 30 MHz | 4.5 to 5.5 |
|                          |                  | MSM66Q577LY      | f <sub>OSC</sub> ≤ 14 MHz                | 3.0 to 3.6                 |             |           |                           |            |
| Analog reference voltage | $V_{REF}$        |                  | _                                        | $V_{DD}$ – 0.3 to $V_{DD}$ | V           |           |                           |            |
| Analog input voltage     | $V_{Al}$         |                  | _                                        | AGND to V <sub>REF</sub>   | V           |           |                           |            |
| Memory hold voltage      | $V_{DDH}$        | MSM66577/Q577    | f <sub>OSC</sub> = 0 Hz                  | 2.0 to 5.5                 | V           |           |                           |            |
| Welliory floid voltage   | V DDH            | MSM66577L/Q577LY | 10SC = 0 HZ                              | 2.0 to 3.6                 | ·           |           |                           |            |
|                          |                  | MSM66577         | $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ | 2 to 30                    |             |           |                           |            |
|                          | f <sub>OSC</sub> | MSM66577L        | $V_{DD} = 2.4 \text{ to } 3.6 \text{ V}$ | 2 to 14                    |             |           |                           |            |
| Operating frequency      | 1080             | MSM66Q577        | $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ | 2 to 30                    | MHz         |           |                           |            |
|                          |                  | MSM66Q577LY      | $V_{DD} = 3.0 \text{ to } 3.6 \text{ V}$ | 2 to 14                    |             |           |                           |            |
|                          | f <sub>XT</sub>  |                  | _                                        | 32.768                     | kHz         |           |                           |            |
| Ambient temperature      | Ta               |                  | _                                        | -30 to +70                 | °C          |           |                           |            |
|                          |                  | МО               | S load                                   | 20                         | _           |           |                           |            |
|                          | N.               |                  | P0, P3, P11                              | 6                          | _           |           |                           |            |
| Fan out                  | N                | TTL load P1, P   | 2, P4, P5, P6, P7,                       | _                          |             |           |                           |            |
|                          |                  | P8, F            | 9, P10, P14, P15                         | 1                          |             |           |                           |            |

#### 20.3 Allowable Output Current Values

MSM66577L/577 (V<sub>DD</sub> = 2.4 to 3.6 V/4.5 to 5.5 V, Ta = -30 to  $+70^{\circ}$ C) MSM66Q577LY/Q577 (V<sub>DD</sub> = 3.0 to 3.6 V/4.5 to 5.5 V, Ta = -30 to  $+70^{\circ}$ C)

| Parameter              | Pin                   | Symbol           | Min. | Тур. | Max. | Unit |
|------------------------|-----------------------|------------------|------|------|------|------|
| "H" output pin (1 pin) | All output pins       | I <sub>OH</sub>  |      | _    | -2   |      |
| "H" output pins        | Sum total of all      | \ \S\ \          | _    |      | -40  |      |
| (sum total)            | output pins           | Σl <sub>OH</sub> |      | _    | -40  |      |
| "L" output pin (1 pin) | P0, P3, P11           | la               |      |      | 10   |      |
| L output piii (1 piii) | Other ports           | l <sub>OL</sub>  |      |      | 5    |      |
|                        | Sum total of          |                  |      |      | 80   |      |
|                        | P0, P3, P11           |                  |      |      |      |      |
|                        | Sum total of          |                  |      |      |      | mA   |
| "I " output ping       | P1, P2, P4            |                  |      |      |      |      |
| "L" output pins        | Sum total of          | 21               |      |      | 50   |      |
| (sum total)            | P5, P6, P9            | $\Sigma I_{OL}$  | _    | _    | 50   |      |
|                        | Sum total of          |                  |      |      |      |      |
|                        | P7, P8, P10, P14, P15 |                  |      |      |      |      |
|                        | Sum total of          |                  |      |      | 1.10 |      |
|                        | all output pins       |                  |      |      | 140  |      |

#### [Note]

Each of the family devices has unique pattern routes for the internal power and ground. Connect the power supply voltage to all  $V_{DD}$  pins and the ground potential to all GND pins. If a device may have one or more  $V_{DD}$  or GND pins to which the power supply voltage or the ground potential is not connected, it cannot be guaranteed for normal operation.

#### 20.4 Internal Flash ROM Programming Conditions

| Parameter           | Symbol   | Condition          | Rating     | Unit   |
|---------------------|----------|--------------------|------------|--------|
| Supply voltage      | $V_{DD}$ | MSM66Q577          | 4.5 to 5.5 | V      |
| Supply voltage      | • ∪∪     | MSM66Q577LY        | 3.0 to 3.6 | V      |
| Ambient temperature | Ta       | During Read        | -30 to +70 | °C     |
| Ambient temperature | Ια       | During Programming | 0 to +50   | °C     |
| Endurance           | CEP      | _                  | 100        | Cycles |
| Blocks size         |          | _                  | 128        | bytes  |

#### 20.5 DC Characteristics

## 20.5.1 DC Characteristics (V<sub>DD</sub> = 4.5 to 5.5 V)

MSM66577/Q577 ( $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ ,  $Ta = -30 \text{ to } +70^{\circ}\text{C}$ )

| Parameter                        | Symbol                           | Condition                 | Min.                  | Тур. | Max.                | Unit     |
|----------------------------------|----------------------------------|---------------------------|-----------------------|------|---------------------|----------|
| "H" input voltage *1             | V <sub>IH</sub>                  |                           | 0.44V <sub>DD</sub>   | _    | $V_{DD} + 0.3$      |          |
| "H" input voltage *2,*3,*4,*5,*6 | VIH                              | _                         | 0.80V <sub>DD</sub>   | _    | $V_{DD} + 0.3$      |          |
| "L" input voltage *1             | V <sub>IL</sub>                  |                           | -0.3                  | _    | 0.16V <sub>DD</sub> |          |
| "L" input voltage *2,*3,*4,*5,*6 | VIL                              | _                         | -0.3                  | _    | 0.20V <sub>DD</sub> |          |
| "H" output voltage *1, *4        |                                  | $I_{O} = -400  \mu A$     | V <sub>DD</sub> – 0.4 |      | _                   |          |
| H output voitage 1, 4            | V <sub>OH</sub>                  | $I_0 = -2.0 \text{ mA}$   | V <sub>DD</sub> – 0.6 | _    | _                   | V        |
| "H" output voltage *2            | VOH                              | I <sub>O</sub> = -200 μA  | V <sub>DD</sub> – 0.4 | _    | _                   | <b>'</b> |
| H output voltage 2               |                                  | $I_{O} = -1.0 \text{ mA}$ | V <sub>DD</sub> – 0.6 | _    | _                   |          |
| "L" output voltage *1, *4        |                                  | $I_0 = 3.2 \text{ mA}$    | 1                     | _    | 0.4                 |          |
| L output voitage 1, 4            | V <sub>OL</sub>                  | $I_0 = 10.0 \text{ mA}$   | _                     | _    | 0.8                 |          |
| "L" output voltage *2            | VOL                              | I <sub>O</sub> = 1.6 mA   | 1                     | _    | 0.4                 |          |
| L output voitage 2               |                                  | $I_{O} = 5.0 \text{ mA}$  | _                     | _    | 0.8                 |          |
| Input leakage current *3         |                                  |                           |                       | _    | 1/–1                |          |
| Input current *5                 | I <sub>IH</sub> /I <sub>IL</sub> | $V_I = V_{DD}/0 V$        |                       | _    | 1/–250              | μΑ       |
| Input current *6                 |                                  |                           | _                     | _    | 15/–15              |          |
| Output leakage current *1,*2,*4  | I <sub>LO</sub>                  | $V_O = V_{DD}/0 V$        | _                     | _    | ±10                 | μΑ       |
| Pull-up resistance               | R <sub>pull</sub>                | $V_I = 0 V$               | 25                    | 50   | 100                 | kΩ       |
| Input capacitance                | CI                               | f <sub>OSC</sub> = 1 MHz, | _                     | 5    | _                   | nE       |
| Output capacitance               | Co                               | Ta = 25°C                 | _                     | 7    | _                   | pF       |
| Analog reference                 | 1                                | During A/D operation      | _                     | _    | 4                   | mA       |
| supply current                   | I <sub>REF</sub>                 | When A/D is stopped       | _                     | _    | 10                  | μΑ       |

<sup>\*1:</sup> Applicable to P0

<sup>\*2:</sup> Applicable to P1, P2, P4, P5, P6, P7, P8, P9, P10, P14, P15

<sup>\*3:</sup> Applicable to P12, SELMBUS, EA, NMI

<sup>\*4:</sup> Applicable to P3, P11

<sup>\*5:</sup> Applicable to RES

<sup>\*6:</sup> Applicable to OSC0

## Supply current $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V})$

MSM66577/Q577 ( $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C}$ )

| Mode             | Symbol           | Cond                          | lition           | Min. | Тур. | Max. | Unit |
|------------------|------------------|-------------------------------|------------------|------|------|------|------|
| ODLI II          |                  | $f_{OSC} = 3$                 | 30 MHz           | _    | 60   | 80   | mA   |
| CPU operation    | I <sub>DD</sub>  | f 00.700 kH=                  | MSM66577         | _    | 80   | 180  | μΑ   |
| mode *1          |                  | $f_{XT} = 32.768 \text{ kHz}$ | MSM66Q577        | _    | 500  | 800  | μA   |
| HALT mode *2     | I <sub>DDH</sub> | $f_{OSC} = 3$                 | 30 MHz           | _    | 40   | 60   | mA   |
|                  |                  | OCC is stanged                | XT is used       | _    | 5    | 110  |      |
| CTOD was also to |                  | OSC is stopped                | XT is not used   | _    | 1    | 100  | μΑ   |
| STOP mode *3     | I <sub>DDS</sub> | OSC is stopped                | , XT is not used |      | 0.0  | 40   | μι   |
|                  |                  | $V_{DD} = 2 V$ ,              | Ta = 25°C        | _    | 0.2  | 10   |      |

#### [Note]

Ports used as inputs are at V<sub>DD</sub> or 0 V. Other ports are unloaded.

- \*1: CPU and all the peripheral functions (timer, PWM, A/D, etc.) are activated.
- \*2: CPU is stopped, and all the peripheral functions (timer, PWM, A/D, etc.) are activated.
- \*3: CPU and all the peripheral functions are deactivated (The clock timer is being activated when the XT is used).

## 20.5.2 DC Characteristics ( $V_{DD} = 2.4 \text{ to } 3.6 \text{ V}$ )

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter                        | Symbol            | Condition                 | Min.                  | Тур. | Max.                  | Unit |
|----------------------------------|-------------------|---------------------------|-----------------------|------|-----------------------|------|
| "H" input voltage *1             | V <sub>IH</sub>   |                           | 0.55V <sub>DD</sub>   | _    | V <sub>DD</sub> + 0.3 |      |
| "H" input voltage *2,*3,*4,*5,*6 | VIH               | _                         | 0.80V <sub>DD</sub>   | _    | V <sub>DD</sub> + 0.3 |      |
| "L" input voltage *1             | V <sub>IL</sub>   |                           | -0.3                  | _    | 0.16V <sub>DD</sub>   |      |
| "L" input voltage *2,*3,*4,*5,*6 | VIL               | _                         | -0.3                  | _    | 0.20V <sub>DD</sub>   |      |
| "H" output voltage *1, *4        |                   | $I_{O} = -400  \mu A$     | V <sub>DD</sub> – 0.4 | _    | _                     |      |
| H output voitage 1, 4            | V <sub>OH</sub>   | $I_0 = -2.0 \text{ mA}$   | $V_{DD} - 0.8$        | _    | _                     | V    |
| "H" output voltage *2            | VOH               | I <sub>O</sub> = -200 μA  | $V_{DD} - 0.4$        | _    | _                     |      |
| H output voitage 2               |                   | $I_{O} = -1.0 \text{ mA}$ | $V_{DD} - 0.8$        | _    | _                     |      |
| L" output voltage *1, *4         |                   | I <sub>O</sub> = 3.2 mA   | _                     | _    | 0.5                   |      |
| L output voitage 1, 4            | V <sub>OL</sub>   | $I_0 = 5.0 \text{ mA}$    | _                     | _    | 0.9                   |      |
| "L" output voltage *2            | VOL               | I <sub>O</sub> = 1.6 mA   | _                     | _    | 0.5                   |      |
| L output voltage 2               |                   | $I_0 = 2.5 \text{ mA}$    | _                     | _    | 0.9                   |      |
| Input leakage current *3,*6      |                   |                           | _                     | _    | 1/–1                  |      |
| Input current *5                 | $I_{IH}/I_{IL}$   | $V_I = V_{DD}/0 V$        | _                     | _    | 1/–250                | μΑ   |
| Input current *6                 |                   |                           | _                     | _    | 15/–15                |      |
| Output leakage current *1,*2,*4  | ILO               | $V_O = V_{DD}/0 V$        | _                     | _    | ±10                   | μΑ   |
| Pull-up resistance               | R <sub>pull</sub> | $V_I = 0 V$               | 40                    | 100  | 200                   | kΩ   |
| Input capacitance                | Cı                | f <sub>OSC</sub> = 1 MHz, | _                     | 5    | _                     | рF   |
| Output capacitance               | Co                | Ta = 25°C                 | _                     | 7    | _                     | РΙ   |
| Analog reference                 | 1                 | During A/D operation      | _                     | _    | 2                     | mA   |
| supply current                   | I <sub>REF</sub>  | When A/D is stopped       | _                     | _    | 5                     | μΑ   |

<sup>\*1:</sup> Applicable to P0

<sup>\*2:</sup> Applicable to P1, P2, P4, P5, P6, P7, P8, P9, P10, P14, P15

<sup>\*3:</sup> Applicable to P12, SELMBUS, EA, NMI

<sup>\*4:</sup> Applicable to P3, P11

<sup>\*5:</sup> Applicable to RES

<sup>\*6:</sup> Applicable to OSC0

#### Supply current $(V_{DD} = 2.4 \text{ to } 3.6 \text{ V})$

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Mode           | Symbol           | Cond                          | lition                    | Min. | Тур. | Max. | Unit |
|----------------|------------------|-------------------------------|---------------------------|------|------|------|------|
|                |                  | $f_{OSC} = 1$                 | 14 MHz                    | _    | 15   | 25   | mA   |
| CPU operation  | IDD              |                               | MSM66577L                 | _    | 50   | 150  | μΑ   |
| mode *1        |                  | $f_{XT} = 32.768 \text{ kHz}$ | MSM66Q577LY               | _    | 300  | 600  | μΑ   |
| HALT mode *2   | I <sub>DDH</sub> | $f_{OSC} = 1$                 | f <sub>OSC</sub> = 14 MHz |      | 10   | 17   | mA   |
|                |                  | OCC is stanced                | XT is used                | _    | 3    | 110  |      |
| CTOD was do *2 | l .              | OSC is stopped                | XT is not used            | _    | 1    | 100  | μΑ   |
| STOP mode *3   | IDDS             | OSC is stopped                | , XT is not used          |      | 0.0  | 10   | μπ   |
|                |                  | $V_{DD} = 2 V$ ,              | Ta = 25°C                 | _    | 0.2  | 10   |      |

#### [Note]

Ports used as inputs are at V<sub>DD</sub> or 0 V. Other ports are unloaded.

- \*1: CPU and all the peripheral functions (timer, PWM, A/D, etc.) are activated.
- \*2: CPU is stopped, and all the peripheral functions (timer, PWM, A/D, etc.) are activated.
- \*3: CPU and all the peripheral functions are deactivated (The clock timer is being activated when the XT is used).

#### 20.6 AC Characteristics

## 20.6.1 AC Characteristics (V<sub>DD</sub> = 4.5 to 5.5 V)

### (1) Separate Bus Type

1. External program memory control

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter                      | Symbol           | Condition                 | Min.      | Max.        | Unit |
|--------------------------------|------------------|---------------------------|-----------|-------------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 30 MHz | 33.3      | _           |      |
| Clock pulse width (HIGH level) | $t_{\phiWH}$     |                           | 13        | _           |      |
| Clock pulse width (LOW level)  | $t_{\phi WL}$    |                           | 13        | _           |      |
| PSEN pulse width               | $t_{PW}$         |                           | 2 to - 15 | _           |      |
| PSEN pulse delay time          | $t_PD$           |                           | _         | 45          |      |
| Address setup time             | t <sub>AS</sub>  | $C_{L} = 50 \text{ pF}$   | tφ – 25   | _           | ns   |
| Address hold time              | t <sub>AH</sub>  |                           | 0         | _           |      |
| Instruction setup time         | t <sub>IS</sub>  |                           | 25        | _           |      |
| Instruction hold time          | t <sub>IH</sub>  |                           | 0         | _           |      |
| Read data access time          | t <sub>ACC</sub> |                           | _         | 3 to - 65*1 |      |



Bus timing during no wait cycle time

<sup>\*1</sup> The read data access time ( $t_{ACC}$ ) is (3 + 2n)  $t_{\phi}$  – 65 when n wait cycles are inserted. For more details, refer to Section 18.4, "External Memory Access Timing".

#### 2. External data memory control

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, Ta = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter                      | Symbol           | Condition                 | Min.      | Max.        | Unit |
|--------------------------------|------------------|---------------------------|-----------|-------------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 30 MHz | 33.3      | _           |      |
| Clock pulse width (HIGH level) | $t_{\phi WH}$    |                           | 13        | _           |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 13        | _           |      |
| RD pulse width                 | t <sub>RW</sub>  |                           | 2 to - 15 | _           |      |
| WR pulse width                 | $t_WW$           |                           | 2 to - 15 | _           |      |
| RD pulse delay time            | $t_{RD}$         |                           | _         | 45          |      |
| WR pulse delay time            | $t_{WD}$         |                           | _         | 45          | ns   |
| Address setup time             | t <sub>AS</sub>  | $C_{L} = 50 \text{ pF}$   | tφ – 25   | _           | 113  |
| Address hold time              | $t_{AH}$         |                           | tφ – 3    | _           |      |
| Read data setup time           | t <sub>RS</sub>  |                           | 25        | _           |      |
| Read data hold time            | t <sub>RH</sub>  |                           | 0         | _           |      |
| Read data access time          | t <sub>ACC</sub> |                           | _         | 3 to - 65*1 |      |
| Write data setup time          | t <sub>WS</sub>  |                           | 2 to - 30 | _           |      |
| Write data hold time           | $t_WH$           |                           | tφ − 3    | _           |      |



\*1 The read data access time  $(t_{ACC})$  is  $(3 + 2n) t_{\phi} - 65$  when n wait cycles are inserted. For more details, refer to Section 18.4, "External Memory Access Timing".

## (2) Multiplexed Bus Type

## 1. External program memory control

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, Ta = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter                      | Symbol           | Condition                 | Min.      | Max.   | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 30 MHz | 33.3      | _      |      |
| Clock pulse width (HIGH level) | $t_{\varphi WH}$ |                           | 13        | _      |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 13        | _      |      |
| ALE pulse width                | $t_{AW}$         |                           | 2 to - 10 | _      |      |
| PSEN pulse width               | $t_{PW}$         |                           | 2 to - 15 | _      |      |
| PSEN pulse delay time          | t <sub>PAD</sub> |                           | t         | _      |      |
| Low address setup time         | t <sub>ALS</sub> | $C_{L} = 50 \text{ pF}$   | 2 to - 15 |        | ns   |
| Low address hold time          | t <sub>ALH</sub> |                           | tφ – 3    | _      |      |
| High address setup time        | t <sub>AHS</sub> |                           | 3 to - 25 | _      |      |
| High address hold time         | t <sub>AHH</sub> |                           | 0         | _      |      |
| Instruction setup time         | t <sub>IS</sub>  |                           | 25        | _      |      |
| Instruction hold time          | t <sub>IH</sub>  |                           | 0         | tφ – 3 |      |



Bus timing during no wait cycle time

## 2. External data memory control

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter                      | Symbol           | Condition                 | Min.      | Max.   | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 30 MHz | 33.3      |        |      |
| Clock pulse width (HIGH level) | $t_{\varphi WH}$ |                           | 13        | _      |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 13        | _      |      |
| ALE pulse width                | $t_{AW}$         |                           | 2 to - 10 | _      |      |
| RD pulse width                 | $t_{RW}$         |                           | 2 to - 15 | _      |      |
| WR pulse width                 | $t_{WW}$         |                           | 2 to - 15 | _      |      |
| RD pulse delay time            | $t_{RAD}$        |                           | t         | _      |      |
| WR pulse delay time            | $t_{WAD}$        |                           | tφ – 3    | _      |      |
| Low address setup time         | t <sub>ALS</sub> | $C_{L} = 50 \text{ pF}$   | 2 to - 15 |        | ns   |
| Low address hold time          | t <sub>ALH</sub> |                           | tφ – 3    |        |      |
| High address setup time        | t <sub>AHS</sub> |                           | 3 to - 25 |        |      |
| High address hold time         | t <sub>AHH</sub> |                           | tφ – 3    |        |      |
| Read data setup time           | t <sub>RS</sub>  |                           | 25        | _      |      |
| Read data hold time            | $t_{RH}$         |                           | 0         | tφ – 3 |      |
| Write data setup time          | t <sub>WS</sub>  |                           | 2 to - 30 | _      |      |
| Write data hold time           | $t_WH$           |                           | tφ − 3    | _      |      |



#### (3) Serial port control

## • Serial ports 1 and 6 (SIO1 and 6)

Master mode (Clock synchronous serial port)

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter               | Symbol             | Condition                 | Min.               | Max. | Unit |  |
|-------------------------|--------------------|---------------------------|--------------------|------|------|--|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 30 MHz | 33.3               | _    |      |  |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 4 t <sub>cyc</sub> | _    |      |  |
| Output data setup time  | t <sub>STMXS</sub> |                           | 2 to - 5           | _    |      |  |
| Output data hold time   | t <sub>STMXH</sub> | $C_L = 50 \text{ pF}$     | 5 tφ – 10          | _    | ns   |  |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 13                 | _    |      |  |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 0                  | _    |      |  |





## Slave mode (Clock synchronous serial port)

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter               | Symbol             | Condition                 | Min.               | Max. | Unit |
|-------------------------|--------------------|---------------------------|--------------------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 30 MHz | 33.3               | _    |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 4 t <sub>cyc</sub> | _    |      |
| Output data setup time  | tstmxs             |                           | 2 to - 15          | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 4 tφ – 10          | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 13                 | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 3                  | _    |      |





## • Serial ports 4 and 5 (SIO4 and 5)

## Master mode (Clock synchronous serial port)

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter               | Symbol             | Condition                 | Min.        | Max. | Unit |
|-------------------------|--------------------|---------------------------|-------------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 30 MHz | 33.3        | _    |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 200         | _    |      |
| Output data setup time  | t <sub>STMXS</sub> |                           | 6 to - 5    | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 4.5 tφ – 10 | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 13          | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 0           | _    |      |





#### Slave mode (Clock synchronous serial port)

 $(V_{DD} = 4.5 \text{ to } 5.5 \text{ V}, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 

| Parameter               | Symbol             | Condition                 | Min.      | Max. | Unit |
|-------------------------|--------------------|---------------------------|-----------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 30 MHz | 33.3      | _    |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 200       | _    |      |
| Output data setup time  | tstmxs             |                           | 3 to - 15 | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 6 tφ – 10 | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 13        | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 3         | _    |      |

Note:  $t\phi = t_{cyc}/2$ 





Measurement points for AC timing (except the serial port)



Measurement points for AC timing (the serial port)



## 20.6.2 AC Characteristics ( $V_{DD} = 2.4 \text{ to } 3.6 \text{ V}$ )

#### (1) Separate Bus Type

1. External program memory control

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter                      | Symbol           | Condition                 | Min.      | Max.         | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 14 MHz | 71.4      | _            |      |
| Clock pulse width (HIGH level) | $t_{\varphi WH}$ |                           | 28        | _            |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 28        | _            |      |
| PSEN pulse width               | $t_{PW}$         |                           | 2 to - 40 | _            |      |
| PSEN pulse delay time          | t <sub>PD</sub>  |                           | _         | 95           |      |
| Address setup time             | $t_{AS}$         | $C_{L} = 50 \text{ pF}$   | tφ – 45   | _            | ns   |
| Address hold time              | t <sub>AH</sub>  |                           | 0         | _            |      |
| Instruction setup time         | $t_IS$           |                           | 75        | _            |      |
| Instruction hold time          | t <sub>IH</sub>  |                           | 0         |              |      |
| Read data access time          | t <sub>ACC</sub> |                           | <u> </u>  | 3 to - 120*1 |      |

Note:  $t\phi = t_{cyc}/2$ 



Bus timing during no wait cycle time

\*1 The read data access time ( $t_{ACC}$ ) is (3 + 2n) t $\phi$  – 120 when n wait cycles are inserted. For more details, refer to Section 18.4, "External Memory Access Timing".

#### 2. External data memory control

MSM66577L (V<sub>DD</sub> = 2.4 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C) MSM66Q577LY (V<sub>DD</sub> = 3.0 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C)

| Parameter                      | Symbol           | Condition                 | Min.      | Max.         | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 14 MHz | 71.4      | _            |      |
| Clock pulse width (HIGH level) | $t_{\phiWH}$     |                           | 28        | _            |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 28        | _            |      |
| RD pulse width                 | $t_{RW}$         |                           | 2 to - 40 | _            |      |
| WR pulse width                 | $t_{WW}$         |                           | 2 to - 40 | _            |      |
| RD pulse delay time            | $t_{RD}$         |                           | _         | 95           |      |
| WR pulse delay time            | t <sub>WD</sub>  |                           | _         | 95           | ns   |
| Address setup time             | $t_{AS}$         | $C_{L} = 50 \text{ pF}$   | to - 45   | _            | 115  |
| Address hold time              | $t_{AH}$         |                           | tφ − 6    | _            |      |
| Read data setup time           | t <sub>RS</sub>  |                           | 75        | _            |      |
| Read data hold time            | $t_{RH}$         |                           | 0         | _            |      |
| Read data access time          | t <sub>ACC</sub> |                           | _         | 3 to - 120*1 |      |
| Write data setup time          | t <sub>WS</sub>  |                           | 2 to - 55 |              |      |
| Write data hold time           | $t_{WH}$         |                           | tφ – 6    | _            |      |



Bus timing during no wait cycle time

<sup>\*1</sup> The read data access time ( $t_{ACC}$ ) is (3 + 2n) t $\phi$  – 120 when n wait cycles are inserted. For more details, refer to Section 18.4, "External Memory Access Timing".

#### (2) Multiplexed Bus Type

#### 1. External program memory control

MSM66577L (V<sub>DD</sub> = 2.4 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C) MSM66Q577LY (V<sub>DD</sub> = 3.0 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C)

| Parameter                      | Symbol           | Condition                 | Min.      | Max.   | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 14 MHz | 71.4      | _      |      |
| Clock pulse width (HIGH level) | $t_{\phi WH}$    |                           | 28        | _      |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 28        | _      |      |
| ALE pulse width                | t <sub>AW</sub>  |                           | 2 to - 15 | _      |      |
| PSEN pulse width               | $t_PW$           |                           | 2 to - 40 | _      |      |
| PSEN pulse delay time          | t <sub>PAD</sub> |                           | to - 6    | _      |      |
| Low address setup time         | t <sub>ALS</sub> | $C_{L} = 50 \text{ pF}$   | 2 to - 25 |        | ns   |
| Low address hold time          | t <sub>ALH</sub> |                           | tφ – 6    | _      |      |
| High address setup time        | t <sub>AHS</sub> |                           | 3 to - 45 | _      |      |
| High address hold time         | t <sub>AHH</sub> |                           | 0         | _      |      |
| Instruction setup time         | t <sub>IS</sub>  |                           | 75        | _      |      |
| Instruction hold time          | t <sub>IH</sub>  |                           | 0         | tφ – 6 |      |



Bus timing during no wait cycle time

#### 2. External data memory control

MSM66577L (V<sub>DD</sub> = 2.4 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C) MSM66Q577LY (V<sub>DD</sub> = 3.0 to 3.6 V, Ta = -30 to  $+70^{\circ}$ C)

| Parameter                      | Symbol           | Condition                 | Min.      | Max.   | Unit |
|--------------------------------|------------------|---------------------------|-----------|--------|------|
| Cycle time                     | t <sub>cyc</sub> | f <sub>OSC</sub> = 14 MHz | 71.4      | _      |      |
| Clock pulse width (HIGH level) | $t_{\phi WH}$    |                           | 28        | _      |      |
| Clock pulse width (LOW level)  | $t_{\phiWL}$     |                           | 28        | _      |      |
| ALE pulse width                | $t_{AW}$         |                           | 2 to - 15 | _      |      |
| RD pulse width                 | $t_{RW}$         |                           | 2 to - 40 | _      |      |
| WR pulse width                 | tww              |                           | 2 to - 40 | _      |      |
| RD pulse delay time            | t <sub>RAD</sub> |                           | to - 6    | _      |      |
| WR pulse delay time            | t <sub>WAD</sub> |                           | tφ – 6    | _      |      |
| Low address setup time         | t <sub>ALS</sub> | $C_{L} = 50 \text{ pF}$   | 2 to - 25 | _      | ns   |
| Low address hold time          | t <sub>ALH</sub> |                           | tφ − 6    |        |      |
| High address setup time        | t <sub>AHS</sub> |                           | 3 to - 45 | _      |      |
| High address hold time         | t <sub>AHH</sub> |                           | tφ − 6    | _      |      |
| Read data setup time           | t <sub>RS</sub>  |                           | 75        | _      |      |
| Read data hold time            | t <sub>RH</sub>  |                           | 0         | tφ – 6 |      |
| Write data setup time          | t <sub>WS</sub>  |                           | 2 to - 55 | _      |      |
| Write data hold time           | $t_{WH}$         |                           | tφ − 6    | _      |      |



#### (3) Serial port control

• Serial ports 1 and 6 (SIO1 and 6)

Master mode (Clock synchronous serial port)

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter               | Symbol             | Condition                 | Min.               | Max. | Unit |
|-------------------------|--------------------|---------------------------|--------------------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 14 MHz | 71.4               | _    |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 4 t <sub>cyc</sub> | _    |      |
| Output data setup time  | t <sub>STMXS</sub> |                           | 2 to - 10          | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 5 tφ – 20          | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 21                 | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 0                  | _    |      |





Slave mode (Clock synchronous serial port)

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter               | Symbol             | Condition                 | Min.               | Max. | Unit |  |
|-------------------------|--------------------|---------------------------|--------------------|------|------|--|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 14 MHz | 71.4               | _    |      |  |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 4 t <sub>cyc</sub> | _    |      |  |
| Output data setup time  | t <sub>STMXS</sub> |                           | 2 to - 30          | _    |      |  |
| Output data hold time   | tstmxh             | $C_{L} = 50 \text{ pF}$   | 4 tφ – 20          | _    | ns   |  |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 21                 | _    |      |  |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 7                  | _    |      |  |





## • Serial ports 4 and 5 (SIO4 and 5)

Master mode (Clock synchronous serial port)

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter               | Symbol             | Condition                 | Min.        | Max. | Unit |
|-------------------------|--------------------|---------------------------|-------------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 14 MHz | 71.4        | -    |      |
| Serial clock cycle time | tsckc              |                           | 400         | _    |      |
| Output data setup time  | t <sub>STMXS</sub> |                           | 5.6 tφ – 10 | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 4.2 tφ − 20 | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 21          | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 0           | _    |      |





Slave mode (Clock synchronous serial port)

MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter               | Symbol             | Condition                 | Min.                    | Max. | Unit |
|-------------------------|--------------------|---------------------------|-------------------------|------|------|
| Cycle time              | t <sub>cyc</sub>   | f <sub>OSC</sub> = 14 MHz | 71.4                    | 1    |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                           | 400                     |      |      |
| Output data setup time  | t <sub>STMXS</sub> |                           | 2.8 t <sub>0</sub> – 30 | _    |      |
| Output data hold time   | t <sub>STMXH</sub> | $C_{L} = 50 \text{ pF}$   | 5.6 tφ − 20             | _    | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                           | 21                      | _    |      |
| Input data hold time    | t <sub>SRMXH</sub> |                           | 7                       | _    |      |

Note:  $t\phi = t_{cyc}/2$ 





Measurement points for AC timing (except the serial port)

Measurement points for AC timing (the serial port)



#### 20.7 A/D Converter Characteristics

### 20.7.1 A/D Converter Characteristics ( $V_{DD} = 4.5 \text{ to } 5.5 \text{ V}$ )

 $(Ta = -30 \text{ to } +70^{\circ}\text{C}, V_{DD} = V_{REF} = 4.5 \text{ V to } 5.5 \text{ V}, AGND = GND = 0 \text{ V})$ 

| Parameter                    | Symbol          | Condition                                 | Min. | Тур. | Max.   | Unit  |
|------------------------------|-----------------|-------------------------------------------|------|------|--------|-------|
| Resolution                   | n               | Refer to measurement                      | _    | 10   | _      | Bit   |
| Linearity error              | EL              | circuit of Fig. 20-1                      | _    | _    | ±3     |       |
| Differential linearity error | E <sub>D</sub>  | Analog input source impedance             | _    | _    | ±2     |       |
| Zero scale error             | Ezs             | $R_1 \le 5 k\Omega$                       | _    | _    | +3     | LOD   |
| Full-scale error             | E <sub>FS</sub> | t <sub>conv</sub> = 8.5 μs                | _    | _    | -3     | LSB   |
| Cross talk                   | E <sub>CT</sub> | Refer to measurement circuit of Fig. 20-2 | _    | _    | ±1     |       |
| Conversion times             |                 | Set according to                          | 0.5  |      | 2000   |       |
| Conversion time              | tCONV           | ADTM set data                             | 8.5  | _    | 3906.3 | μs/ch |

## 20.7.2 A/D Converter Characteristics (V<sub>DD</sub> = 2.4 to 3.6 V)

MSM66577L (Ta = -30 to  $+70^{\circ}$ C,  $V_{DD} = V_{REF} = 2.4$  to 3.6 V, AGND = GND = 0 V) MSM66Q577LY (Ta = -30 to  $+70^{\circ}$ C,  $V_{DD} = V_{REF} = 3.0$  to 3.6 V, AGND = GND = 0 V)

| Parameter                    | Symbol          | Condition                     | Min. | Тур. | Max.   | Unit  |  |
|------------------------------|-----------------|-------------------------------|------|------|--------|-------|--|
| Resolution                   | n               | Refer to measurement          | _    | 10   | _      | Bit   |  |
| Linearity error              | EL              | circuit of Fig. 20-1          | _    | _    | ±4     |       |  |
| Differential linearity error | E <sub>D</sub>  | Analog input source impedance | _    | _    | ±3     |       |  |
| Zero scale error             | Ezs             | $R_l \le 5 k\Omega$           | _    | _    | +4     | LOD   |  |
| Full-scale error             | E <sub>FS</sub> | $t_{conv} = 27.4 \mu s$       | _    | _    | -4     | LSB   |  |
| Cross talls                  | E               | Refer to measurement          |      |      | +2     |       |  |
| Cross talk                   | E <sub>CT</sub> | circuit of Fig. 20-2          | _    |      | ΞZ     |       |  |
| Conversion time              |                 | Set according to              | 07.4 |      | 0000.0 | a/ab  |  |
|                              | tCONV           | ADTM set data                 | 27.4 | _    | 3906.3 | μs/ch |  |



Figure 20-1 Measurement Circuit



Cross talk is the difference between the A/D conversion results when the same analog input is applied to Al0 through Al7 and the A/D conversion results of the circuit to the left.

Figure 20-2 Cross Talk Measurement Circuit

#### **Definition of Terminology**

#### 1. Resolution

Resolution is the value of minimum discernible analog input.

With 10 bits, since  $2^{10} = 1024$ , resolution of (VREF – AGND) ÷ 1024 is possible.

#### 2. Linearity error

Linearity error is the difference between ideal conversion characteristics and actual conversion characteristics of a 10-bit A/D converter (not including quantization error).

Ideal conversion characteristics can be obtained by dividing the voltage between  $V_{\text{REF}}$  and AGND into 1024 equal steps.

#### 3. Differential linearity error

Differential linearity error indicates the smoothness of conversion characteristics. Ideally, the range of analog input voltage that corresponds to 1 converted bit of digital output is 1LSB =  $(V_{REF} - AGND) \div 1024$ . Differential error is the difference between this ideal bit size and bit size of an arbitrary point in the conversion range.

#### 4. Zero scale error

Zero scale error is the difference between ideal conversion characteristics and actual conversion characteristics at the point where the digital output changes from 000H to 001H.

#### 5. Full-scale error

Full-scale error is the difference between ideal conversion characteristics and actual conversion characteristics at the point where the digital output changes from 3FEH to 3FFH.

#### 20.8 D/A Converter Characteristics

MSM66577/MSM66Q577 ( $V_{DD}$  = 2.4 to 3.6 V/4.5 to 5.5 V, Ta = -30 to +70°C) MSM66577L ( $V_{DD}$  = 2.4 to 3.6 V, Ta = -30 to +70°C) MSM66Q577LY ( $V_{DD}$  = 3.0 to 3.6 V, Ta = -30 to +70°C)

| Parameter               | Symbol            | Condition               | Min. | Тур. | Max. | Unit |
|-------------------------|-------------------|-------------------------|------|------|------|------|
| Resolution              | n                 |                         | _    | _    | 8    | Bit  |
| Linearity error         | EL                | _                       | _    | _    | ±1   | 1.00 |
| Absolute precision      | _                 |                         | _    | _    | ±2   | LSB  |
| Conversion time         | t <sub>CONV</sub> | $C_{L} = 50 \text{ pF}$ | _    | 20   | 50   | μs   |
| Analog output impedance | _                 | <del>_</del>            | _    | 10   | 40   | kΩ   |

#### **Definition of Terminology**

#### 1. Resolution

Resolution is the value of minimum discernible analog output.

With 8 bits, since  $2^8 = 256$ , resolution of  $(V_{DD} - GND) \div 256$  is possible.

#### 2. Linearity error

Linearity error is the difference between ideal conversion characteristics and actual conversion characteristics of a 8-bit D/A converter.

Ideal conversion characteristics can be obtained by dividing the voltage between  $V_{DD}$  and GND into 256 equal steps.

#### 3. Absolute precision

Absolute precision is a gross error including a linearity error and the effect of noise.

## Chapter 21

# Special Function Registers (SFRs)

## 21. Special Function Registers (SFRs)

#### 21.1 Overview

The 256-byte area of addresses 0000H to 00FFH in data memory is the special function register (SFR) area.

The SFR area is a register group that includes special function registers such as the following.

Peripheral hardware mode registers

Arithmetic register (ACC)

Control registers (PSW, LRBL, LRBH, SSP)

#### 21.2 List of SFRs

Table 21-1 lists the SFRs. Terms in the table are defined as follows:

Address [H]: Addresses are expressed in hexadecimal format.

• Function: The register is named after the SFR function.

• Byte, Word: Symbol This symbol indicates an I/O function register.

Each symbol indicates whether access is by byte or

word.

A dash indicates that the function cannot be accessed

by that unit.

• Bit Symbol: Symbol This symbol indicates an I/O function register.

In some cases there are two bit symbols, however there

is no difference in function.

Blank The I/O register is also assigned to this bit.

However, since individual access of this bit is either unnecessary or not possible, no bit symbol is needed.

0 If writing to this bit, <u>always write a value of "0".</u>

Even when writing a byte or word that includes this bit,

write this bit as "0".

This bit always reads as "0".

1 If writing to this bit, <u>always write a value of "1".</u>

Even when writing a byte or word that includes this bit,

write this bit as "1".

This bit always reads as "1".

(1) All writes to this bit are ignored.

This bit always reads as "1".

(0) All writes to this bit are ignored.

This bit always reads as "0".

Undefined This indicates a bit that does not support the I/O

function.

Programming should be done on the assumption that

the value of this bit is always undefined.

Operation of this bit when an in-circuit emulator is used may differ from operation when an actual chip (such as

MASK or OTP versions) is used.

R/W: This indicates whether the specified SFR can be read

(R) or written (W).

R/W: Both read and write are possible

R: Read-only W: Write-only

• 8/16: This indicates the unit of bit access for the specified

SFR.

8/16: Both 8-bit and 16-bit access are possible

8: Only 8-bit access is possible
16: Only 16-bit access is possible

Initial value [H]: This indicates the contents of each SFR at reset (RES)

signal input, execution of a BRK instruction, overflow of the watchdog timer, or an opcode trap is generated).

Values are expressed in hexadecimal format.

Reference page: This indicates the page on which the configuration of

each SFR is described.

#### [Note]

Do not perform the following operation on SFRs.

- 1. Write operations on read-only SFRs
- Read operations on write-only SFRs
- 3. 16-bit operations on 8-bit SFRs
- 4. 8-bit operations on 16-bit SFRs
- 5. Operation on addresses that are not allocated as registers
- 6. Operations in the area for emulator use

## Table 21-1 SFR List (1/7)

| Function   Byte   Word   7   6   5   4   3   2   1   0   8   8   6   6   6   5   4   3   2   1   0   8   8   6   6   6   6   6   5   4   3   2   1   0   8   8   6   6   6   6   6   6   6   6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      |                                    |         |       |       |        | =,     |        |         |         |        |        |     |      |           |      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------------------------------------|---------|-------|-------|--------|--------|--------|---------|---------|--------|--------|-----|------|-----------|------|
| Note    |      | Function                           | Byte    | Word  | 7     | 6      | 5      | -      |         | 2       | 1      | 0      | R/W | 8/16 |           |      |
| DOOD   Cocal register base   LRBL   LRBH   LRBH   LRBH   LRBH   LRBH   LRBH   LRBH   LRBH   PSWH   PSWH   PSWH   PSWH   ACCH   | 0000 | System stack pointer               | _       | SSP   | ,     | 0      | J      | 4      | 3       |         |        |        |     | 16   | FF        | , ,  |
| LRBH   LRB   LRB   LRB   LRB   LRB   RBB   RBB |      | ,                                  | _       |       |       |        |        |        |         |         |        |        |     |      |           |      |
| Program status word   PSWH   PSW   PSW   PSW   RAB   F1   BCB1   BCB0   F0   SCB2   SCB1   SCB0   RAC   RAC   RCW   RAC   ACC   AC |      | Local register base                |         | LRB   |       |        |        |        |         |         |        |        |     | 8/16 |           | 2-22 |
| Power   Powe |      |                                    |         |       | MAD   | E1     | DCD1   | BCB0   | EO      | SCB3    | SCB1   | SCBO   |     |      |           |      |
| Accumulator    |      | Program status word                |         | PSW   |       |        |        |        |         |         |        |        |     | 8/16 |           | 2-18 |
| Marcon   M |      | Accumulator                        |         | ۸۵۵   |       |        |        |        |         |         |        |        | R/W | 0/16 | 00        | 2 17 |
| 0009         Data segment register         DSR         DSTSR         0         0         0         0         0         0         2-27           000B         ROM window register         ROMWIN         -         (1)         1         1         1         1         1         1         4         4-2           000C         ROM ready control register         ROMRDY         -         (1)         ARDY11         ARDY10         (1)         ARDY02         ARDY01         ARDY02         ARDY01         ARDY00         8         8         8         8         8         4-4           000D         RAM ready control register         RAMRDY         -         (1)         ARDY11         ARDY10         (1)         ARDY02         ARDY01         ARDY00         8         8         8         FF         4-5           000E         Stop code acceptor         STPACP         -         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         8         8         -6           0011         Memory size acceptor         MEMSCD         -         (1)         (1)         (1)         (1)         (1)         (1)         (1) <td>0007</td> <td>Accumulator</td> <td>ACCH</td> <td>ACC</td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td></td> <td>0/10</td> <td>00</td> <td>2-17</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0007 | Accumulator                        | ACCH    | ACC   |       |        |        |        |         |         |        |        |     | 0/10 | 00        | 2-17 |
| 000B         Data segment register         DSR         0         0         0         0         0         0         0         2-27           000B         ROM window register         ROMWIN         —         1         1         1         1         Inches of the control register         8 Undefined         4-2           000C         ROM ready control register         RAMRDY         —         (1)         ARDY12         ARDY10         ARDY10         ARDY02         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY02         ARDY01         ARDY01         ARDY02         ARDY01         ARDY02         ARDY01         ARDY01         ARDY02         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY01         ARDY02         ARDY01         ARDY01 <t< td=""><td>8000</td><td>Table segment register</td><td>TSR</td><td>ретер</td><td>0</td><td>0</td><td>0</td><td>0</td><td></td><td></td><td></td><td></td><td></td><td>0/16</td><td>00</td><td>2-26</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 8000 | Table segment register             | TSR     | ретер | 0     | 0      | 0      | 0      |         |         |        |        |     | 0/16 | 00        | 2-26 |
| 000C         ROM ready control register         ROMRDY         —         (1)         0         0         0         (1)         IRORDY ORDY1         ORDY0         RAW         8         8B         4-4           000D         RAM ready control register         RAMRDY         —         (1)         ARDY11         ARDY10         (1)         ARDY02         ARDY01         ARDY00         8         FF         4-5           000E         Stop code acceptor         STPACP         —         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         08         3-4           0010         Memory size acceptor         MEMSACP         —         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         08         3-4           0011         Memory size acceptor         MEMSACP         —         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 0009 | Data segment register              | DSR     | DOTOR | 0     | 0      | 0      | 0      |         |         |        |        |     | 0/10 | 00        | 2-27 |
| 000D         RAM ready control register         RAMRDY         —         (1)         ARDY12         ARDY11         ARDY10         (1)         ARDY02         ARDY01         ARDY00         W         8         FF         4-5           000E         Stop code acceptor         STPACP         —         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         "0"         3-3           000F         Standby control register         SBYCON         —         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         "0"         3-3           0010         Memory size acceptor         MEMSCON         —         (1)         (1)         (1)         (1)         (1)         (1)         (1)         LRAM         LRAM         W         8         "0"         2-2           0011         Memory size acceptor         MEMSCON         —         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 000B | ROM window register                | ROMWIN  | _     |       |        | 1      | 1      |         |         |        |        |     | 8    | Undefined | 4-2  |
| 000E         Stop code acceptor         STPACP         -         SBYCON         -         CLK1         CLK0         OST1         OST0         OSCS         FLT         HLT         STP         RW         8         "0"         3-3           000F         Standby control register         MEMSACP         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         -         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 000C | ROM ready control register         | ROMRDY  | _     | (1)   | 0      | 0      | 0      | (1)     | IRORDY  | ORDY1  | ORDY0  |     | 8    | 8B        | 4-4  |
| 000F         Standby control register         SBYCON         —         CLK1         CLK0         OST0         OSCS         FLT         HLT         STP         RW         8         08         3-4           0010         Memory size acceptor         MEMSACP         —         —         —         —         —         W         8         "0"         2-2           0011         Memory size acceptor         MEMSCON         —         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 000D | RAM ready control register         | RAMRDY  | _     | (1)   | ARDY12 | ARDY11 | ARDY10 | (1)     | ARDY02  | ARDY01 | ARDY00 |     | 8    | FF        | 4-5  |
| 0010         Memory size acceptor         MEMSACP         —         Image: control of the control                                                          | 000E | Stop code acceptor                 | STPACP  | _     |       |        |        |        |         |         |        |        | W   | 8    | "0"       | 3-3  |
| 0011         Memory size control register         MEMSCON         —         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)         (1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 000F | Standby control register           | SBYCON  | _     | CLK1  | CLK0   | OST1   | OST0   | oscs    | FLT     | HLT    | STP    | R/W | 8    | 80        | 3-4  |
| 0013         Real-time counter control register         RTCCON         —         (1)         (1)         (1)         (1)         SELRTI1         SELRTI0         RTCIE         RTCCL         8         FO         10-2           0015         Peripheral control register         PRPHCON         —         (1)         WAIT         HOLD         EXTXT         (1)         (1)         CLKO1         CLKO0         8         8C         15-2           0018         Port 0 data register         P0         —         P0_7         P0_6         P0_5         P0_4         P0_3         P0_2         P0_1         P0_0         8         8C         15-2           0019         Port 1 data register         P1         —         P1_7         P1_6         P1_5         P1_4         P1_3         P1_2         P1_1         P1_0         8         00         5-12           001B         Port 2 data register         P2         —         (0)         (0)         (0)         (0)         P2_3         P2_2         P2_1         P2_0         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_2         P4_1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0010 | Memory size acceptor               | MEMSACP | _     |       |        |        |        |         |         |        |        | W   | 8    | "0"       | 2-2  |
| 0015         Peripheral control register         PRPHCON         —         (1)         WAIT         HOLD         EXTXT         (1)         (1)         CLKO1         CLKO0         B         8         8C         15-2           0018         Port 0 data register         P0         —         P0_7         P0_6         P0_5         P0_4         P0_3         P0_2         P0_1         P0_0         8         00         5-12           0019         Port 1 data register         P1         —         P1_7         P1_6         P1_5         P1_4         P1_3         P1_2         P1_1         P1_0         8         00         5-14           001A         Port 2 data register         P2         —         (0)         (0)         (0)         (0)         P2_3         P2_2         P2_1         P2_0         8         00         5-14           001B         Port 3 data register         P3         —         (0)         (0)         (0)         (0)         P3_3         P3_2         P3_1         P3_0         PV         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0011 | Memory size control register       | MEMSCON | _     | (1)   | (1)    | (1)    | (1)    | (1)     | (1)     | LROM   | LRAM   |     | 8    | FC        | 2-1  |
| 0018         Port 0 data register         PO         —         PO_7         PO_6         PO_5         PO_4         PO_3         PO_2         PO_1         PO_0         8         00         5-12           0019         Port 1 data register         P1         —         P1_7         P1_6         P1_5         P1_4         P1_3         P1_2         P1_1         P1_0         8         00         5-14           001A         Port 2 data register         P2         —         (0)         (0)         (0)         (0)         P2_3         P2_2         P2_1         P2_0         8         00         5-16           001B         Port 3 data register         P3         —         (0)         (0)         (0)         (0)         P3_3         P3_2         P3_1         P3_0         R/W         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3         P4_2         P4_1         P4_0         8         00         5-20           001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0) <td>0013</td> <td>Real-time counter control register</td> <td>RTCCON</td> <td>_</td> <td>(1)</td> <td>(1)</td> <td>(1)</td> <td>(1)</td> <td>SELRTI1</td> <td>SELRTI0</td> <td>RTCIE</td> <td>RTCCL</td> <td></td> <td>8</td> <td>F0</td> <td>10-2</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0013 | Real-time counter control register | RTCCON  | _     | (1)   | (1)    | (1)    | (1)    | SELRTI1 | SELRTI0 | RTCIE  | RTCCL  |     | 8    | F0        | 10-2 |
| 0019         Port 1 data register         P1         —         P1_7         P1_6         P1_5         P1_4         P1_3         P1_2         P1_1         P1_0         8         00         5-14           001A         Port 2 data register         P2         —         (0)         (0)         (0)         (0)         P2_3         P2_2         P2_1         P2_0         8         00         5-16           001B         Port 3 data register         P3         —         (0)         (0)         (0)         (0)         P3_3         P3_2         P3_1         P3_0         R/W         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3         P4_2         P4_1         P4_0         8         00         5-20           001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0)         (0)         8         00         5-22           001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1 <td>0015</td> <td>Peripheral control register</td> <td>PRPHCON</td> <td>_</td> <td>(1)</td> <td>WAIT</td> <td>HOLD</td> <td>EXTXT</td> <td>(1)</td> <td>(1)</td> <td>CLKO1</td> <td>CLK00</td> <td></td> <td>8</td> <td>8C</td> <td>15-2</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0015 | Peripheral control register        | PRPHCON | _     | (1)   | WAIT   | HOLD   | EXTXT  | (1)     | (1)     | CLKO1  | CLK00  |     | 8    | 8C        | 15-2 |
| 001A         Port 2 data register         P2         —         (0)         (0)         (0)         (0)         (0)         P2_3         P2_2         P2_1         P2_0         R/W         8         00         5-16           001B         Port 3 data register         P3         —         (0)         (0)         (0)         (0)         P3_3         P3_2         P3_1         P3_0         P/W         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3         P4_2         P4_1         P4_0         8         00         5-20           001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0)         (0)         8         00         5-20           001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1         P6_0         8         00         5-24           001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0018 | Port 0 data register               | P0      | _     | P0_7  | P0_6   | P0_5   | P0_4   | P0_3    | P0_2    | P0_1   | P0_0   |     | 8    | 00        | 5-12 |
| 001B         Port 3 data register         P3         —         (0)         (0)         (0)         (0)         P3_3         P3_2         P3_1         P3_0         R/W         8         00         5-18           001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3         P4_2         P4_1         P4_0         8         00         5-20           001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0)         (0)         8         00         5-22           001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1         P6_0         8         00         5-24           001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)         (0)         (0)         8         00         5-26           0020         Port 0 mode register         P0IO         —         P0IO7         P0IO6         P0IO5         P0IO4         P0IO3         P0IO1         P0IO0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 0019 | Port 1 data register               | P1      | _     | P1_7  | P1_6   | P1_5   | P1_4   | P1_3    | P1_2    | P1_1   | P1_0   |     | 8    | 00        | 5-14 |
| 001C         Port 4 data register         P4         —         P4_7         P4_6         P4_5         P4_4         P4_3         P4_2         P4_1         P4_0         8         00         5-20           001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0)         (0)         8         00         5-22           001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1         P6_0         8         00         5-24           001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)         (0)         (0)         (0)         8         00         5-26           0020         Port 0 mode register         P0IO         —         P0IO7         P0IO6         P0IO5         P0IO4         P0IO3         P0IO1         P0IO0         8         00/FF         5-12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 001A | Port 2 data register               | P2      | _     | (0)   | (0)    | (0)    | (0)    | P2_3    | P2_2    | P2_1   | P2_0   |     | 8    | 00        | 5-16 |
| 001D         Port 5 data register         P5         —         P5_7         P5_6         P5_5         P5_4         (0)         (0)         (0)         (0)         8         00         5-22           001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1         P6_0         8         00         5-24           001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (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>001B</td><td>Port 3 data register</td><td>P3</td><td>_</td><td>(0)</td><td>(0)</td><td>(0)</td><td>(0)</td><td>P3_3</td><td>P3_2</td><td>P3_1</td><td>P3_0</td><td>R/W</td><td>8</td><td>00</td><td>5-18</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 001B | Port 3 data register               | P3      | _     | (0)   | (0)    | (0)    | (0)    | P3_3    | P3_2    | P3_1   | P3_0   | R/W | 8    | 00        | 5-18 |
| 001E         Port 6 data register         P6         —         P6_7         P6_6         P6_5         P6_4         P6_3         P6_2         P6_1         P6_0         8         00         5-24           001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)         (0)         (0)         (0)         8         00         5-26           0020         Port 0 mode register         P0IO         —         P0IO7         P0IO6         P0IO5         P0IO4         P0IO3         P0IO2         P0IO1         P0IO0         8         00/FF         5-12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 001C | Port 4 data register               | P4      | _     | P4_7  | P4_6   | P4_5   | P4_4   | P4_3    | P4_2    | P4_1   | P4_0   |     | 8    | 00        | 5-20 |
| 001F         Port 7 data register         P7         —         P7_7         P7_6         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (0)         (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 | Port 5 data register               | P5      | _     | P5_7  | P5_6   | P5_5   | P5_4   | (0)     | (0)     | (0)    | (0)    |     | 8    | 00        | 5-22 |
| 0020 Port 0 mode register P0IO - P0IO7 P0IO6 P0IO5 P0IO4 P0IO3 P0IO2 P0IO1 P0IO0 8 00/FF 5-12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 001E |                                    | P6      | _     | P6_7  | P6_6   | P6_5   | P6_4   | P6_3    | P6_2    | P6_1   | P6_0   |     | 8    | 00        | 5-24 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 001F | Port 7 data register               | P7      | _     | P7_7  |        | (0)    | (0)    | (0)     | (0)     | (0)    | (0)    |     | 8    | 00        |      |
| 0021   Port 1 mode register   P1IO   -   P1IO7   P1IO6   P1IO5   P1IO4   P1IO3   P1IO2   P1IO1   P1IO0   8   00/FF   5-14                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0020 | Port 0 mode register               | P0IO    | _     | P0I07 | P0I06  | P0IO5  | P0IO4  | P0IO3   | P0IO2   | P0IO1  | P0100  |     | 8    | 00/FF     | 5-12 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0021 | Port 1 mode register               | P1IO    | _     | P1I07 | P1IO6  | P1105  | P1IO4  | P1IO3   | P1IO2   | P1I01  | P1I00  |     | 8    | 00/FF     | 5-14 |

## Table 21-1 SFR List (2/7)

| A              |                                              |       |      |         |         |         |        |            |            |            |            |        |      | 1 22 1 1             | Б (   |
|----------------|----------------------------------------------|-------|------|---------|---------|---------|--------|------------|------------|------------|------------|--------|------|----------------------|-------|
| Address<br>[H] | Function                                     | Byte  | Word | _       |         | _       | •      | ymbol      |            |            |            | R/W    | 8/16 | Initial value<br>[H] | page  |
| 0022           | Dort O made vegister                         | P2IO  |      | (0)     | (0)     | 5       | 4 (0)  | 3<br>P2IO3 | 2<br>P2IO2 | 1<br>P2IO1 | 0<br>P2IO0 |        | 8    | 00/0F                | 5-16  |
|                | Port 2 mode register                         |       | _    | · ' /   |         | (0)     | (0)    |            |            |            |            |        | _    |                      |       |
| 0023           | Port 3 mode register                         | P3IO  | _    | (0)     | (0)     | (0)     | (0)    | P3IO3      | P3IO2      | P3IO1      | P3IO0      |        | 8    | 00/02                | 5-18  |
| 0024           | Port 4 mode register                         | P4IO  | _    | P4I07   | P4I06   | P4IO5   | P4IO4  | P4IO3      | P4IO2      | P4IO1      | P4IO0      |        | 8    | 00/FF                | 5-20  |
| 0025           | Port 5 mode register                         | P5IO  | _    | P5IO7   | P5IO6   | P5IO5   | P5IO4  | (0)        | (0)        | (0)        | (0)        |        | 8    | 00                   | 5-22  |
| 0026           | Port 6 mode register                         | P6IO  | _    | P6IO7   | P6IO6   | P6IO5   | P6IO4  | P6IO3      | P6IO2      | P6IO1      | P6IO0      |        | 8    | 00                   | 5-24  |
| 0027           | Port 7 mode register                         | P7IO  | _    | P7I07   | P7IO6   | (0)     | (0)    | (0)        | (0)        | (0)        | (0)        |        | 8    | 00                   | 5-26  |
| 0028           | Port 0 secondary function control register   | P0SF  | _    | XAD7    | XAD6    | XAD5    | XAD4   | XAD3       | XAD2       | XAD1       | XAD0       |        | 8    | 00/FF                | 5-12  |
| 0020           | Terre o occorridary ramonem control regional |       |      | P0SF7   |         | P0SF5   |        |            |            | P0SF1      | P0SF0      |        |      |                      |       |
| 0029           | Port 1 secondary function control register   | P1SF  | _    | XDM15   |         |         | XDM12  | XDM11      |            | XDM9       | XDM8       |        | 8    | 00/FF                | 5-14  |
| 0023           | Torr T secondary function control register   | 1 101 |      | P1SF7   | P1SF6   | P1SF5   | P1SF4  | P1SF3      | P1SF2      | P1SF1      | P1SF0      |        |      | 00/11                | J 17  |
| 002A           | Port 2 secondary function control register   | P2SF  |      | (0)     | (0)     | (0)     | (0)    | XDM19      | XDM18      | XDM17      | XDM16      |        | 8    | 00/0F                | 5-16  |
| 002A           | Port 2 secondary function control register   | FZSF  | _    | (0)     | (0)     | (0)     | (0)    | P2SF3      | P2SF2      | P2SF1      | P2SF0      |        | 0    | 00/01                | 5-16  |
| 0000           | Dout 2 accordant function control register   | P3SF  |      | (0)     | (0)     | (0)     | (0)    | WR         | RD         | PSEN       | ALE        |        | 8    | 00/03                | 5-18  |
| 002B           | Port 3 secondary function control register   | Poor  | _    | (0)     | (0)     | (0)     | (0)    | P3SF3      | P3SF2      | P3SF1      | P3SF0      |        | 0    | 00/03                | 5-16  |
| 0000           | Det 4                                        | D40F  |      | XDM7    | XDM6    | XDM5    | XDM4   | XDM3       | XDM2       | XDM1       | XDM0       | R/W    |      | 00/55                | F 00  |
| 002C           | Port 4 secondary function control register   | P4SF  | _    | P4SF7   | P4SF6   | P4SF5   | P4SF4  | P4SF3      | P4SF2      | P4SF1      | P4SF0      | IT/ VV | 8    | 00/FF                | 5-20  |
| 0000           | 5 . 5                                        | D-0-  |      | DE055   | PTM0OUT | CPCM1   | СРСМ0  | (0)        | (0)        | (0)        | (0)        |        |      | 00                   | 5.00  |
| 002D           | Port 5 secondary function control register   | P5SF  | _    | P5SF7   | P5SF6   | P5SF5   | P5SF4  | (0)        | (0)        | (0)        | (0)        |        | 8    | 00                   | 5-22  |
|                |                                              |       |      | PTM2OUT |         | PTM1OUT |        |            |            |            |            |        | _    |                      |       |
| 002E           | Port 6 secondary function control register   | P6SF  | _    | P6SF7   | P6SF6   | P6SF5   | P6SF4  | P6SF3      | P6SF2      | P6SF1      | P6SF0      |        | 8    | 00                   | 5-24  |
|                |                                              |       |      | PWM10UT | PWM0OUT | (0)     | (0)    | (0)        | (0)        | (0)        | (0)        |        |      |                      |       |
| 002F           | Port 7 secondary function control register   | P7SF  | _    | P7SF7   | P7SF6   | (0)     | (0)    | (0)        | (0)        | (0)        | (0)        |        | 8    | 00                   | 5-26  |
| 0030           | Interrupt request register 0                 | IRQ0  | _    | QCPCM1  |         | 0       | 0      | 0          | 0          | QFRCOV     | QINT0      |        | 8    | 00                   | 17-12 |
| 0031           | Interrupt request register 1                 | IRQ1  | _    | 0       | QTM3OV  | QTM2OV  | QTM10V | QINT3      | QINT2      | QINT1      | QTM0OV     |        | 8    | 00                   | 17-13 |
| 0032           | Interrupt request register 2                 | IRQ2  | _    |         | QTM4OV  | 0       | 0      | QINT7      | QINT6      | QINT5      | QINT4      |        | 8    | 00                   | 17-14 |
| 0033           | Interrupt request register 3                 | IRQ3  | _    | QRTC    | 0       | QAD     | QTM6OV | -          | QSIO6      |            | QTM5OV     |        | 8    | 00                   | 17-15 |
| 0034           | Interrupt enable register 0                  | IE0   | _    | -       | ECPCM0  |         | 0      | 0          | 0          | EFRCOV     |            |        | 8    | 00                   | 17-17 |
| 0035           | Interrupt enable register 1                  | IE1   | _    |         | ETM3OV  |         | ETM10V |            | EINT2      |            | ETM0OV     |        | 8    | 00                   | 17-18 |
| 0036           | Interrupt enable register 2                  | IE2   | _    | _       | ETM4OV  | 0       | 0      | EINT7      | EINT6      | EINT5      | EINT4      |        | 8    | 00                   | 17-19 |
| 0037           | Interrupt enable register 3                  | IE3   |      | ERTC    | 0       | EAD     | ETM6OV |            | _          | ESIO5      |            |        | 8    | 00                   | 17-20 |
| 0007           | interrupt enable register o                  | ILU   |      |         | U       |         | LIMOOV |            | LOICO      |            | LINGOV     |        | L    | 00                   | 17-20 |

Table 21-1 SFR List (3/7)

| Λ al al μ a a a |                                        |          |        |         |              |        |        |            |              |         |          |       | I    | مريام برامانيم       | Deference |
|-----------------|----------------------------------------|----------|--------|---------|--------------|--------|--------|------------|--------------|---------|----------|-------|------|----------------------|-----------|
| Address<br>[H]  | Function                               | Byte     | Word   | 7       | 6            | 5      | Bit Sy | mbol/<br>3 | 0            | 4       | 0        | R/W   | 8/16 | Initial value<br>[H] | page      |
| 0038            | Interrupt priority control register 0  | IP0      |        | 0       | 6<br>0       | 0      | 0      |            | 2<br>P0FRCOV | P1INT0  |          |       | 8    | 00                   | 17-22     |
| 0039            | Interrupt priority control register 1  | IP1      |        | P1CPCM1 |              |        |        |            | 0            | 0       | 0        |       | 8    | 00                   | 17-23     |
| 003A            | Interrupt priority control register 2  | IP2      |        |         |              |        |        | POINT1     |              | _       | POTMOOV  |       | 8    | 00                   | 17-24     |
| 003B            | Interrupt priority control register 3  | IP3      |        |         |              |        |        | P1TM2OV    |              |         |          |       | 8    | 00                   | 17-25     |
| 003C            | Interrupt priority control register 4  | IP4      |        |         |              |        |        | P1INT5     |              |         |          |       | 8    | 00                   | 17-26     |
| 003D            | Interrupt priority control register 5  | IP5      |        | P1SIO1  |              |        |        | 0          | 0            | 0       | 0        |       | 8    | 00                   | 17-27     |
| 003E            | Interrupt priority control register 6  | IP6      | _      | P1SIO4  |              |        |        | P1SIO5     | P0SIO5       | P1TM5OV | P0TM5OV  |       | 8    | 00                   | 17-28     |
| 003F            | Interrupt priority control register 7  | IP7      |        |         | P0RTC        | 0      | 0      | P1AD       | P0AD         |         | P0TM6OV  |       | 8    | 00                   | 17-29     |
| 0040            |                                        | _        | 500    |         |              |        |        |            |              |         |          |       |      | 00                   |           |
| 0041            | Free running counter                   | _        | FRC    |         |              |        |        |            |              |         |          |       | 16   | 00                   | 9-3       |
| 004A            | 0                                      | _        | ODOMBO |         |              |        |        |            |              |         |          |       | 40   | 00                   | 0.0       |
| 004B            | Capture compare register 0             | _        | CPCMR0 |         |              |        |        |            |              |         |          |       | 16   | 00                   | 9-6       |
| 004C            | Combined as many was stated 1          | _        | CDCMD1 |         |              |        |        |            |              |         |          | D / / | 10   | 00                   | 0.0       |
| 004D            | Capture compare register 1             | _        | CPCMR1 |         |              |        |        |            |              |         |          | R/W   | 16   | 00                   | 9-6       |
| 0050            | Free running counter control register  | FRCON    | _      | (1)     | (1)          | CP1MD  | CP0MD  | FRRUN      | FRCK2        | FRCK1   | FRCK0    |       | 8    | C0                   | 9-4       |
| 0051            | Capture control register               | CAPCON   | _      | (1)     | (1)          | CP1E1  | CP1E0  | CP0E1      | CP0E0        | (0)     | (0)      |       | 8    | C0                   | 9-7       |
| 0055            | Compare control register 0             | CPCMCON0 | _      | (1)     | (1)          | (1)    | (1)    | (1)        | CPCMSBF0     | CPCMBF0 | CPCMOUT0 |       | 8    | FC                   | 9-6       |
| 0056            | Compare control register 1             | CPCMCON1 | _      | (1)     | (1)          | (1)    | (1)    | (1)        | CPCMSBF1     | CPCMBF1 | CPCMOUT1 |       | 8    | FC                   | 9-6       |
| 0058            | External interrupt control register 0  | EXI0CON  | _      | EX3M1   | EX3M0        | EX2M1  | EX2M0  | EX1M1      | EX1M0        | EX0M1   | EX0M0    |       | 8    | 00                   | 16-2      |
| 0059            | External interrupt control register 1  | EXI1CON  | _      | EX7M1   | EX7M0        | EX6M1  | EX6M0  | EX5M1      | EX5M0        | EX4M1   | EX4M0    |       | 8    | 00                   | 16-3      |
| 005A            | External interrupt control register 2  | EXI2CON  | _      | MIPF    | <b>NMIRD</b> | NMIM1  | NMIM0  | (1)        | (1)          | (0)     | (0)      |       | 8    | 0C/4C                | 16-4      |
| 005C            | Interrupt request register 4           | IRQ4     | _      | (1)     | (1)          | (1)    | QTM9OV | QPWM3      | QPWM2        | QPWM1   | QPWM0    |       | 8    | E0                   | 17-16     |
| 005D            | Interrupt enable register 4            | IE4      | _      | (1)     | (1)          | (1)    | ETM9OV | EPWM3      | EPWM2        | EPWM1   | EPWM0    |       | 8    | E0                   | 17-21     |
| 005E            | Interrupt priority control register 8  | IP8      | _      | P1PWM3  | P0PWM3       | P1PWM2 | P0PWM2 | P1PWM1     | P0PWM1       | P1PWM0  | P0PWM0   |       | 8    | 00                   | 17-30     |
| 005F            | Interrupt priority control register 9  | IP9      | _      | (1)     | (1)          | (1)    | (1)    | (1)        | (1)          | P1TM9OV | P0TM9OV  |       | 8    | FC                   | 17-31     |
| 0060            | TBC clock dividing register            | TBCKDVR  | TBCKDV | (1)     | (1)          | (1)    | (1)    |            |              |         |          |       | 8/16 | F0                   | 7-3       |
| 0061            | TBC clock dividing counter             | _        | IBUNDV | (1)     | (1)          | (1)    | (1)    |            |              |         |          | R     | 16   | F0                   | 7-2       |
| 0062            | General-purpose 16-bit timer 0 counter | _        | TM0C   |         |              |        |        |            |              |         |          | R/W   | 16   | Undefined            | 8-4       |
| 0063            | deneral-purpose 10-bit timer o counter | _        | I WIOC |         |              |        |        |            |              |         |          | U/ VV | 10   | Undefined            | 0-4       |

#### Table 21-1 SFR List (4/7)

| Address | Function                                        | Byte    | Word    |        |        |        | Bit S  | ymbol            |        |        |        | DΛM     | 8/16  | Initial value |       |
|---------|-------------------------------------------------|---------|---------|--------|--------|--------|--------|------------------|--------|--------|--------|---------|-------|---------------|-------|
| [H]     | Function                                        | Буге    | vvord   | 7      | 6      | 5      | 4      | 3                | 2      | 1      | 0      | H/VV    | 0/10  | [H]           | page  |
| 0064    | General-purpose 16-bit timer 0 register         | _       | TM0R    |        |        |        |        |                  |        |        |        |         | 16    | Undefined     | 8-4   |
| 0065    | General-purpose 16-bit timer o register         | _       | IIVIUN  |        |        |        |        |                  |        |        |        |         | 10    | Undefined     | 0-4   |
| 0066    | General-purpose 16-bit timer 0 control register | TM0CON  | _       | TM00UT | (1)    | (1)    | (1)    | TM0RUN           | TM0C2  | TM0C1  | TM0C0  |         | 8     | 70            | 8-4   |
| 0068    | General-purpose 8-bit timer 12 counter          | TM1C    | TM12C   |        |        |        |        |                  |        |        |        |         | 8/16  | Undefined     | 8-10  |
| 0069    | General-purpose o-bit timer 12 counter          | TM2C    | 1101120 |        |        |        |        |                  |        |        |        |         | 0/10  | Undefined     | 8-10  |
| 006A    | General-purpose 8-bit timer 12 register         | TM1R    | TM12R   |        |        |        |        |                  |        |        |        |         | 8/16  | Undefined     | 8-10  |
| 006B    | General-purpose o-bit tilller 12 register       | TM2R    | IIVIIZN |        |        |        |        |                  |        |        |        |         | 0/10  | Undefined     | 8-10  |
| 006C    | General-purpose 8-bit timer 1 control register  | TM1CON  | _       | TM10UT | (1)    | (1)    | (1)    | TM1RUN           | TM1C2  | TM1C1  | TM1C0  |         | 8     | 70            | 8-10  |
| 006D    | General-purpose 8-bit timer 2 control register  |         | _       | TM2OUT | (1)    | MODPWM | MOD16  | TM2RUN           | TM2C2  | TM2C1  | TM2C0  |         | 8     | 40            | 8-11  |
| 0070    | General-purpose 8-bit timer 3 counter           | ТМЗС    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-22  |
| 0071    | General-purpose 8-bit timer 3 register          | TM3R    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-22  |
| 0072    | General-purpose 8-bit timer 3 control register  | TM3CON  | _       | TM3OUT | (1)    | (1)    | (1)    | TM3RUN           | TM3C2  | TM3C1  | ТМ3С0  |         | 8     | 70            | 8-22  |
| 0074    | General-purpose 8-bit timer 4 counter           | TM4C    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-28  |
| 0075    | General-purpose 8-bit timer 4 register          | TM4R    | _       |        |        |        |        |                  |        |        |        | R/W     | 8     | Undefined     | 8-28  |
| 0076    | General-purpose 8-bit timer 4 control register  | TM4CON  | _       | TM4OUT | (1)    | (1)    | (1)    | TM4RUN           | TM4C2  | TM4C1  | TM4C0  | FT/ VV  | 8     | 70            | 8-28  |
| 0078    | General-purpose 8-bit timer 5 counter           | TM5C    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-34  |
| 0079    | General-purpose 8-bit timer 5 register          | TM5R    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-34  |
| 007A    | General-purpose 8-bit timer 5 control register  | TM5CON  | _       | TM5OUT | (1)    | (1)    | (1)    | TM5RUN           | TM5C2  | TM5C1  | TM5C0  |         | 8     | 70            | 8-34  |
| 007C    | General-purpose 8-bit timer 6 counter           | TM6C    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-43  |
| 007D    | General-purpose 8-bit timer 6 register          | TM6R    | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 8-43  |
| 007E    | General-purpose 8-bit timer 6 control register  | TM6CON  | _       | MODWDT | WDTLDE | WDTRUN |        | ATMRUN           |        | WDTC1  | WDTC0  |         | 8     | 10            | 8-41  |
| 0084    | SIO1 transmit control register                  | ST1CON  | _       | TR1NIE | TR1MIE | ST1ODD | ST1PEN | ST1STB<br>ST1SLV | (1)    | ST1LN  | ST1MOD |         | 8     | 04            | 12-4  |
| 0085    | SIO1 receive control register                   | SR1CON  | _       | SR1REN | RC1IE  | SR10DD | SR1PEN | SR1SLV           | S1EXC  | SR1LN  | SR1MOD |         | 8     | 00            | 12-6  |
| 0086    | SIO1 transmit-receive buffer register           | S1BUF   | _       |        |        |        |        |                  |        |        |        |         | 8     | Undefined     | 12-10 |
| 0087    | SIO1 status register                            | S1STAT  | _       | (0)    | (0)    | RC1END | TR1END | TR1EMP           | PERR1  | OERR1  | FERR1  |         | 8     | 00            | 12-8  |
| 008C    | SIO4 control register                           | SIO4CON | _       | (1)    | BUSY4  | ICK4   | TEN4   | SIO4SL           | SIO4C2 | SIO4C1 | SIO4C1 |         | 8     | 80            | 12-41 |
| 008D    | FIOF control register                           | FIFOCON | _       | SRES5  | ORE5   | FUL5   | EMP5   | SRES4            | ORE4   | FUL4   | EMP4   |         | 8     | 11            | 12-43 |
| 008E    | SIO4 input FIFO data register                   | SIN4    | _       |        |        |        |        |                  |        |        |        | R       | 8     | Undefined     | 12-45 |
| 008F    | SIO4 output FIFO data register                  | SOUT4   | _       |        |        |        |        |                  |        |        |        | W       | 8     | Undefined     | 12-45 |
| 0090    | PWM register 0                                  | PWR0    | PWR01   |        |        |        |        |                  |        |        |        |         | 8/16  | 00            | 11-4  |
| 0091    | PWM register 1                                  | PWR1    | I ANDOL |        |        |        |        |                  |        |        |        | R/W     | 0/10  | 00            | 11-4  |
| 0092    | PWM register 2                                  | PWR2    | PWR23   |        |        |        |        |                  |        |        |        | עע ירון | 8/16  | 00            | 11-4  |
| 0093    | PWM register 3                                  | PWR3    | WHZ3    |        |        |        |        |                  |        |        |        |         | 0, 10 | 00            | 11-4  |

#### Table 21-1 SFR List (5/7)

| Address |                                         |         |         |        |        |        | Rit Sv | /mbol   |         |         |         |      |      | Initial value | Reference |
|---------|-----------------------------------------|---------|---------|--------|--------|--------|--------|---------|---------|---------|---------|------|------|---------------|-----------|
| [H]     | Function                                | Byte    | Word    | 7      | 6      | 5      | 4      | 3       | 2       | 1       | 0       | R/W  | 8/16 | [H]           | page      |
| 0094    | PWM cycle register 0                    | PWCY0   | DIMON   |        |        |        |        |         |         |         |         |      | 0/40 | 00            | 44.0      |
| 0095    | PWM cycle register 1                    | PWCY1   | PWCY    |        |        |        |        |         |         |         |         |      | 8/16 | 00            | 11-3      |
| 0096    | PWM counter 0                           | PWC0    | PWC     |        |        |        |        |         |         |         |         |      | 8/16 | 00            | 11-3      |
| 0097    | PWM counter 1                           | PWC1    | PWC     |        |        |        |        |         |         |         |         |      | 0/10 | 00            | 11-3      |
| 0098    | PWM control register 0                  | PWCON0  | _       | PWC10V | PWCK11 | PWCK10 | PW1RUN | PWC00V  | PWCK01  | PWCK00  | PW0RUN  | R/W  | 8    | 00            | 11-4      |
| 0099    | PWM control register 1                  | PWCON1  | _       | (1)    | (1)    | (1)    | (1)    | (1)     | (1)     | (1)     | PWHSM   |      | 8    | FE            | 11-6      |
| 009C    | A/D control register 0L                 | ADCON0L | _       | (1)    | SCNC0  | SNEX0  | ADRUN0 | 0       | ADSNM02 | ADSNM01 | ADSNM00 |      | 8    | 80            | 13-3      |
| 009D    | A/D control register 0H                 | ADCON0H | _       | ADTM02 | ADTM01 | ADTM00 | STS0   | 0       | ADSTM02 | ADSTM01 | ADSTM00 |      | 8    | 80            | 13-5      |
| 009E    | A/D interrupt control register 0        | ADINT0  | _       | (1)    | (1)    | (1)    | (1)    | ADSTIE0 | ADSNIE0 | INTST0  | INTSN0  |      | 8    | F0            | 13-7      |
| 00A0    | A/D result register 00                  | _       | ADR00   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00A1    | AD result register ou                   | _       | ADRUU   | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      | 10   | Undefined     | 10-0      |
| 00A2    | A/D result register 01                  | _       | ADR01   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00A3    | A D Tesuit Tegister 01                  | _       | ADITOT  | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      | 10   | Undefined     | 10-0      |
| 00A4    | A/D result register 02                  | _       | ADR02   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00A5    | 7 V D Teadit Teglator 02                | _       | 7101102 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      | 10   | Undefined     | 10 0      |
| 00A6    | A/D result register 03                  | _       | ADR03   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00A7    | 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | _       | 7101100 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         | R    |      | Undefined     | 100       |
| 00A8    | A/D result register 04                  | _       | ADR04   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00A9    | 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 7 | _       | 7121101 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      |      | Undefined     |           |
| 00AA    | A/D result register 05                  |         | ADR05   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00AB    | 742 100011 10910101 00                  | _       | 7121100 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      |      | Undefined     |           |
| 00AC    | A/D result register 06                  | _       | ADR06   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00AD    | 742 100011 10910101 00                  | _       | 7121100 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      |      | Undefined     |           |
| 00AE    | A/D result register 07                  | _       | ADR07   |        |        |        |        |         |         |         |         |      | 16   | Undefined     | 13-8      |
| 00AF    |                                         | _       | 7121101 | (0)    | (0)    | (0)    | (0)    | (0)     | (0)     |         |         |      |      | Undefined     |           |
| 00B8    | Port 8 data register                    | P8      |         | P8_7   | P8_6   | (0)    | P8_4   | P8_3    | P8_2    | P8_1    | P8_0    |      | 8    | 00            | 5-28      |
| 00B9    | Port 9 data register                    | P9      |         | P9_7   | (0)    | (0)    | (0)    | P9_3    | P9_2    | P9_1    | P9_0    | R/W  | 8    | 00            | 5-30      |
| 00BA    | Port 10 data register                   | P10     |         | (0)    | (0)    | P10_5  | P10_4  | P10_3   | (0)     | (0)     | (0)     | , •• | 8    | 00            | 5-32      |
| 00BB    | Port 11 data register                   | P11     | _       | (0)    | (0)    | (0)    | (0)    | P11_3   | P11_2   | P11_1   | P11_0   |      | 8    | 00            | 5-34      |

#### Table 21-1 SFR List (6/7)

| Address |                                                |         |      |                 |         |        | D# C    | was la a l |         |        |         |     |      | Initial value | Doforonco        |
|---------|------------------------------------------------|---------|------|-----------------|---------|--------|---------|------------|---------|--------|---------|-----|------|---------------|------------------|
| [H]     | Function                                       | Byte    | Word | 7               | 6       | 5      | BIT S   | ymbol      | 2       | -1     | 0       | R/W | 8/16 | [H]           | page             |
| 00BC    | Port 12 data register                          | P12     |      | P12_7           | P12_6   | P12_5  | P12_4   | P12_3      |         | P12_1  | P12_0   | R   | 8    | Undefined     | 5-36             |
| 00BE    | Port 14 mode register                          | P14     |      | P14_7           | P14_6   | (0)    | (0)     | (0)        | P14_2   | P14 1  | P14_0   |     | 8    | 00            | 5-37             |
| 00BF    | Port 15 mode register                          | P15     |      | (0)             | (0)     | (0)    | (0)     | P15_3      |         | P15_1  | P15 0   | 1   | 8    | 00            | 5-39             |
| 00C0    | Port 8 mode register                           | P8IO    |      | P8IO7           | P8IO6   | (0)    | P8IO4   | P8IO3      | P8IO2   | P8IO1  | P8IO0   | 1   | 8    | 00            | 5-28             |
| 00C1    | Port 9 mode register                           | P9IO    |      | P9I07           | (0)     | (0)    | (0)     | P9IO3      |         | P9IO1  | P9I00   | 1   | 8    | 00            | 5-30             |
| 00C2    | Port 10 mode register                          | P10IO   | _    | (0)             |         | - ' '  |         | P10IO3     |         | (0)    | (0)     | 1   | 8    | 00            | 5-32             |
| 00C3    | Port 11 mode register                          | P11IO   |      | (0)             | (0)     | (0)    | (0)     |            | . ,     | . ,    | P11IO0  |     | 8    | 00            | 5-34             |
| 00C4    | Port 14 mode register                          | P14IO   | _    | <b>— ` </b> ′ — | P14I06  |        | (0)     | (0)        | P14IO2  | P14IO1 | P14I00  |     | 8    | 00            | 5-37             |
| 00C5    | Port 15 mode register                          | P15IO   | _    | (0)             | (0)     | (0)    | (0)     | P15IO3     | P15IO2  | P15IO1 | P15IO0  |     | 8    | 00            | 5-39             |
| 2000    | 5                                              | D. 40E  |      | AO1             | AO0     |        |         | (0)        | D. 1050 | SIO05  | SIOCK5  |     | _    | -00           | - 0-             |
| 00C6    | Port 14 secondary function control register    | P14SF   | _    | P14SF7          | P14SF6  | (0)    | (0)     | (0)        | P14SF2  | P14SF1 | P14SF0  |     | 8    | 00            | 5-37             |
| 0007    | Dett.                                          | DAFOE   |      | (0)             | (0)     | (0)    | (0)     | TXC6       | RXC6    | TXD6   | D4.5050 |     | 8    | 00            | F 00             |
| 00C7    | Port 15 secondary function control register    | PISSE   | _    | (0)             | (0)     | (0)    | (0)     | P15SF3     | P15SF2  | P15SF1 | P15SF0  |     | 8    | 00            | 5-39             |
| 00C8    | Dort 9 accordant function control register     | P8SF    |      | PWM3OUT         | PWM2OUT | (0)    | PTM4OUT | TXC1       | RXC1    | TXD1   | P8SF0   | R/W | 8    | 00            | 5-28             |
| 0000    | Port 8 secondary function control register     | Poor    | _    | P8SF7           | P8SF6   | (0)    | P8SF4   | P8SF3      | P8SF2   | P8SF1  | P8SFU   |     | ŏ    | 00            | 5-28             |
| 00C9    | Port 9 secondary function control register     | P9SF    |      | HLDACK          | (0)     | (0)    | (0)     | P9SF3      | P9SF2   | P9SF1  | P9SF0   |     | 8    | 00            | 5-30             |
| 0009    | Fort 9 Secondary function control register     | F9SF    | _    | P9SF7           | (0)     | (0)    | (0)     | Faoro      | F93F2   | F9SF1  | F9SFU   |     | 0    | 00            | 5-30             |
| 0000    | Port 10 secondary function control register    | P10SF   |      | (0)             | (0)     | P10SF5 | SIO04   | SIOCK4     | (0)     | (0)    | (0)     |     | 8    | 00            | 5-32             |
| UUCA    | For 10 secondary function control register     | F 103F  | _    | (0)             | (0)     | FTUSFS | P10SF4  | P10SF3     | (0)     | (0)    | (0)     |     | 0    | 00            | 3-32             |
| OOC B   | Port 11 secondary function control register    | P11SF   |      | (0)             | (0)     | (0)    | (0)     | XTOUT      | CLKOUT  | D110E1 | P11SF0  |     | 8    | 00            | 5-34             |
| ООСВ    | Tore it secondary function control register    | 1 1135  |      | (0)             | (0)     | (0)    | (0)     | P11SF3     | P11SF2  | 111351 | 111350  |     | o    | 00            | J-3 <del>4</del> |
| 00CC    | General-purpose 8-bit timer 9 counter          | TM9C    | _    |                 |         |        |         |            |         |        |         |     | 8    | Undefined     | 8-49             |
| 00CD    | General-purpose 8-bit timer 9 register         | TM9R    | _    |                 |         |        |         |            |         |        |         |     | 8    | Undefined     | 8-49             |
| 00CE    | General-purpose 8-bit timer 9 control register | TM9CON  | _    | TM9OUT          | (1)     | (1)    | (1)     | TM9RUN     | TM9C2   | TM9C1  | тм9С0   |     | 8    | 70            | 8-49             |
| 00CF    | FIFO mode register                             | FIFOMOD | _    | (1)             | (1)     | (1)    | (1)     | (1)        | (1)     | FMOD1  | FMOD0   |     | 8    | FC            | 12-54            |

Table 21-1 SFR List (7/7)

| Address<br>[H] | Function                              | Byte    | Word     | 7      | 6      | 5      | Bit S  | ymbol<br>3       | 2      | 1      | 0      | R/W | 8/16 | Initial value<br>[H] | Reference page |
|----------------|---------------------------------------|---------|----------|--------|--------|--------|--------|------------------|--------|--------|--------|-----|------|----------------------|----------------|
| 00D5           | SIO5 control register                 | SIO5CON | _        | (1)    | BUSY5  | ICK5   | TEN5   | SIO5SL           | SIO5C2 | SIO5C1 | SIO5C0 | R/W | 8    | 80                   | 12-52          |
| 00D6           | SIO5 input FIFO data register         | SIN5    |          |        |        |        |        |                  |        |        |        | R   | 8    | Undefined            | 12-54          |
| 00D7           | SIO5 output FIFO data register        | SOUT5   | _        |        |        |        |        |                  |        |        |        | W   | 8    | Undefined            | 12-54          |
| 00DD           | DA control register                   | DACON   | _        | (1)    | (1)    | (1)    | (1)    | (1)              | (1)    | (1)    | DAON   |     | 8    | FE                   | 14-2           |
| 00DE           | DA register 0                         | DAR0    |          |        |        |        |        |                  |        |        |        |     | 8    | 00                   | 14-2           |
| 00DF           | DA register 1                         | DAR1    | _        |        |        |        |        |                  |        |        |        |     | 8    | 00                   | 14-2           |
| 00EA<br>00EB   | Capture compare buffer register 0     |         | CPCMBFR0 |        |        |        |        |                  |        |        |        | R/W | 16   | 00                   | 9-8            |
| 00EC<br>00ED   | Capture compare buffer register 1     |         | CPCMBFR1 |        |        |        |        |                  |        |        |        |     | 16   | 00                   | 9-8            |
| ☆00F0          | Flash memory acceptor                 | FLAACP  | _        |        |        |        |        |                  |        |        |        | W   | 8    | "0"                  | 19-11          |
| ☆00F1          | Flash memory control register         | FLACON  | _        | (1)    | (1)    | AMPOFF | FCLK1  | FCLK0            | (1)    | (1)    | PRG    |     | 8    | C6                   | 19-12          |
| ☆00F2          | Flack mamon, address register         | _       | FLAADRS  | FA11   | FA10   | FA9    | FA8    | FA7              | (1)    | (1)    | (1)    |     | 16   | Undefined            | 19-11          |
| ☆00F3          | Flash memory address register         | _       | FLAADNO  | (1)    | (1)    | (1)    | FA16   | FA15             | FA14   | FA13   | FA12   |     | 10   | Undenned             | 19-11          |
| 00F4           | SIO6 transmit control register        | ST6CON  | _        | TR6NIE | TR6MIE | ST6ODD | ST6PEN | ST6STB<br>ST6SLV | (1)    | ST6LN  | ST6MOD | R/W | 8    | 04                   | 12-16          |
| 00F5           | SIO6 receive control register         | SR6CON  |          | SR6REN | RC6IE  | SR6ODD | SR6PEN | SR6SLV           | S6EXC  | SR6LN  | SR6MOD |     | 8    | 00                   | 12-18          |
| 00F6           | SIO6 transmit-receive buffer register | S6BUF   | _        |        |        |        |        |                  |        |        |        |     | 8    | Undefined            | 12-22          |
| 00F7           | SIO6 status register                  | S6STAT  | _        | (0)    | (0)    | RC6END | TR6END | TR6EMP           | PERR6  | OERR6  | FERR6  |     | 8    | 00                   | 12-20          |

#### [Note]

A star (\$\frac{1}{2}\$) in the address column indicates a SFR existing only in the Flash ROM version.

For details, refer to Chapter 19, "Flash Memory".

### Chapter 22

### Package Dimensions

#### 22. Package Dimensions





Notes for Mounting the Surface Mounting Type Package

The TQFP is a surface mount type package and is very susceptible to heat in reflow mounting and to humidity absorbed in storage. Therefore, before you do reflow mounting, contact Oki's responsible sales person on the product name, package name, pin number, package code and desired mounting conditions (reflow method, temperature and times).

# Note on Programming

#### **Note on Programming**

When the compare output function is used, if a compare match takes place while CPCMR0 or CPCMR1 is being read, the value of the CPCMR0 or CPCMR1 register being read will be changed. However, in the case of ICE, such a change does not occur.

In cases where a compare match takes place while CPCMR0 or CPCMR1 is read, make the free running counter (FRC) stop (FRRUN = 0), then read CPCMR0 or CPCMR1.

# Revision History

### **Revision History**

| Desument        |           | Pa                  | ge                 |                                                             |
|-----------------|-----------|---------------------|--------------------|-------------------------------------------------------------|
| Document<br>No. | Date      | Previous<br>Edition | Current<br>Edition | Description                                                 |
| PEUL66577-01    | Dec. 2000 | _                   | _                  | Preliminary edition 1                                       |
| FEUL66577-01    | Jun. 2002 | Cover               | Cover              | Deleted "Preliminary"                                       |
|                 |           | 1-4                 | 1-4                | Partly changed the contents of Table 1-1.                   |
|                 |           | 1-8                 | 1-8                | Partly changed the contents of Table 1-2.                   |
|                 |           | 3-9                 | 3-9                | Added an explanation of STOP mode to Sec. 3.2.4 (3).        |
|                 |           | 3-10                | 3-10               | Added two items to [Note].                                  |
|                 |           | 6-3                 | 6-3                | Added Table 6-2.                                            |
|                 |           | 6-3                 | 6-3                | Modified Figure 6-4.                                        |
|                 |           | 6-4                 | 6-4                | Modified Figure 6-6.                                        |
|                 |           | 6-5                 | 6-5                | Modified Figure 6-7.                                        |
|                 |           | 9-5                 | 9-5                | Addede [Note] to Sec. 9.5.                                  |
|                 |           | 12-40               | 12-40              | Added an explanation of SIO4 to Sec. 12.7.                  |
|                 |           | 12-51               | 12-51              | Added an explanation of SIO5 to Sec. 12.8.                  |
|                 |           | 17-10               | 17-10              | Partly changed the contents of Sec. 17.3.3 (2).             |
|                 |           | 19-1                | 19-1               | Deleted "Preliminary" from the chapter title.               |
|                 |           | 19-1 to<br>19-9     | 19-1 to<br>19-9    | Partly changed the contents of Sections 19.1 through 19.9.  |
|                 |           | 20-1                | 20-1               | Deleted "Preliminary" from the chapter title.               |
|                 |           | 20-4                | 20-4               | Partly changed the contents of the table of supply current. |
|                 |           | 20-6                | 20-6               | Partly changed the contents of the table of supply current. |
|                 |           | 20-13               | 20-13              | Changed the Min. value of t <sub>SCKC</sub> in the table.   |
|                 |           | 20-14               | 20-14              | Changed the Min. value of t <sub>SCKC</sub> in the table.   |
|                 |           | 20-21               | 20-21              | Changed the Min. value of t <sub>SCKC</sub> in the table.   |
|                 |           | 20-22               | 20-22              | Changed the Min. value of t <sub>SCKC</sub> in the table.   |
|                 |           | _                   | A-1                | Added "Note on Programming".                                |
|                 |           | _                   | R-1                | Added "Revision History".                                   |