### OKI

# MSM66587 Family

### User's Manual

**CMOS 16-bit microcontroller** 

**SECOND EDITION** 

ISSUE DATE: Jan. 2000

FEUL66587-02

<u>NOTICE</u>

- 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.
- 9. MS-DOS is a registered trademark of Microsoft Corporation.

Copyright 2000 Oki Electric Industry Co., Ltd.

### Preface

This user's manual describes the hardware of Oki-original CMOS 16-bit microcontrollers MSM66587 family. In addition to this manual, Oki also provides the following manuals which should be read with regard to the MSM66587 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 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.

| Classification  | Notation                                                                                                                         | Description                                                                                                                                                                                                                                                                                              |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ■ Numeric value | xxH<br>xxb                                                                                                                       | Represents a hexadecimal number<br>Represents a binary number                                                                                                                                                                                                                                            |
| ■ Unit          | Word, W<br>byte, B<br>nibble, N<br>mega-, M<br>kilo-, K<br>kilo-, k<br>mil-, m<br>micro-, µ<br>nano-, n<br>second, s<br>KB<br>MB | 1 word = 16 bits<br>1 byte = 2 nibbles = 8 bits<br>1 nibble = 4 bits<br>10 <sup>6</sup><br>$2^{10} = 1024$<br>$10^3 = 1000$<br>$10^{-3}$<br>$10^{-6}$<br>$10^{-9}$<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;<br>indicates the voltage level of $V_{IH}$ and $V_{OH}$ described in the electrical characteristics.<br>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<br>area that has not been assigned an<br>instruction is fetched, or when an instruction<br>code combination that does not contain an<br>instruction is addressed.                                                                                              |

#### Notation





### Table of Contents

| Chap | ter 1 Overview         | 1-1 |
|------|------------------------|-----|
| 1.1  | Features               | 1-1 |
| 1.2  | Block Diagram          |     |
| 1.3  | Pin Configuration      |     |
| 1.4  | Basic Operation Timing | 1-5 |
|      |                        |     |
| Chap | •                      |     |
| 2.1  | P0_0-P0_7              | 2-1 |
| 2.2  | P1_0-P1_7              | 2-1 |
| 2.3  | P2_0-P2_7              | 2-1 |
| 2.4  | P4_0-P4_7              | 2-2 |
| 2.5  | P5_4, P5_5             | 2-2 |
| 2.6  | P6_0-P6_5              | 2-3 |
| 2.7  | P7_0-P7_7              | 2-4 |
| 2.8  | P8_0-P8_7              |     |
| 2.9  | P9_0-P9_7              | 2-5 |
| 2.10 | P10_0-P10_7            | 2-5 |
| 2.11 | P12_0-P12_7            |     |
| 2.12 | AI0-AI3                |     |
| 2.13 | V <sub>REF</sub>       | 2-6 |
| 2.14 | AGND                   |     |
| 2.15 | OSC0, OSC1             | 2-6 |
| 2.16 | <u>NMI</u>             |     |
| 2.17 | RES                    |     |
| 2.18 | EA                     |     |
| 2.19 | V <sub>DD</sub>        | 2-6 |
| 2.20 | GND                    |     |
| 2.21 | Pin Configurations     |     |
| 2.22 | Unused Pins            | 2-9 |

| Chapter 3 | CPU Architecture                                       | 3-1 |
|-----------|--------------------------------------------------------|-----|
| 3.1 Men   | nory Space                                             | 3-1 |
|           | Memory Space Expansion                                 |     |
|           | Program Memory Space                                   |     |
| (1)       | Accessing Program Memory Space                         | 3-4 |
|           | Vector Table Area                                      |     |
| (3)       | VCAL Table Area                                        | 3-5 |
|           | ACAL Area                                              |     |
| 3.1.3     | Data Memory Space                                      | 3-7 |
| (1)       | Special Function Register (SFR) Area                   | 3-9 |
| (2)       | Expanded Special Function Register (Expanded SFR) Area | 3-9 |
| (3)       | Internal RAM Area                                      | 3-9 |
| (4)       | Fixed Page (FIX) Area                                  | 3-9 |
|           |                                                        |     |

|      | (5)        | Area for Setting Local Registers  | 3-11 |
|------|------------|-----------------------------------|------|
|      |            | External Memory Area              |      |
|      | • • •      | Common Area                       |      |
| 3.   | 1.4        | Accessing Data Memory             |      |
|      | (1)        |                                   |      |
|      | · · ·      | Word Operation                    |      |
| 3.2  |            | isters                            |      |
|      | -          | Arithmetic Register (ACC)         |      |
|      |            |                                   |      |
|      |            | Program Status Word (PSW)         |      |
|      | (2)        |                                   |      |
|      | • • •      | Local Register Base (LRB)         |      |
|      |            | System Stack Pointer (SSP)        |      |
| 3    | 2.3        | Pointing Register (PR)            |      |
|      | 2.4        | Local Registers (R, ER)           |      |
|      | 2.5        | Segment Registers                 |      |
| 0.   |            | Code Segment Register (CSR)       |      |
|      |            | Table Segment Register (TSR)      |      |
|      | . ,        | Data Segment Register (DSR)       |      |
| 3.3  |            | ressing Modes                     |      |
|      | 3.1        | RAM Addressing                    |      |
| 0.   | (1)        |                                   |      |
|      | (2)        |                                   |      |
|      | (2)        |                                   |      |
|      | (4)        |                                   |      |
|      | (5)        |                                   | 3-38 |
| 3    | (3)<br>3.2 | ROM Addressing                    |      |
| 0.   | 3.2<br>(1) |                                   |      |
|      | · · ·      | Table Data Addressing             |      |
|      |            |                                   |      |
|      | (3)        | ROM Window Addressing             |      |
|      | (4)        |                                   | 3-43 |
|      |            |                                   |      |
| Chap | oter 4     | CPU Control Functions             | 4-1  |
| 4.1  | Star       | ndby Function                     | 4-1  |
| 4.   |            | Standby Control Register (SBYCON) |      |
|      |            | Operation in Standby Modes        |      |
|      |            | HALT Mode                         |      |
|      |            | STOP Mode                         |      |
| 4.2  | • • •      | et Function                       |      |
|      | 1.000      |                                   | + 0  |
|      |            |                                   |      |
| Chap | oter 5     | Memory Control Functions          | 5-1  |
| 5.1  | RON        | / Window Function                 | 5-1  |
| 5.2  | REA        | DY Function                       | 5-2  |
| 5.3  | WAI        | T Function                        | 5-4  |
|      |            |                                   |      |

| Chapter 6           | Port Functions                                                         | 6-1  |
|---------------------|------------------------------------------------------------------------|------|
| 6.1 Port            | Hardware Configurations                                                | 6-3  |
| 6.1.1               | Type A (P0_0-P0_7) Configuration                                       |      |
| 6.1.2               | Type B (P1_0-P1_7, P4_0, P9_0-P9_3) Configuration                      |      |
| 6.1.3               | Type C (P2_4, P2_5, P5_4, P5_5, P6_0-P6-5, P7_0-P7_4, P12_2, P12_3)    |      |
|                     | Configuration                                                          | 6-5  |
| 6.1.4               | Type D (P4_1-P4_7, P9_4-P9_7, P10_0-P10_7) Configuration               | 6-6  |
| 6.1.5               | Type E (P2_0-P2_3, P2_6, P2_7, P7_5-P7_7,                              |      |
|                     | P8_0-P8_7, P12_0, P12_1, P12_4-P12_7) Configuration                    | 6-6  |
| 6.2 Port            | Control Registers                                                      | 6-7  |
| 6.2.1               | Port Data Registers (Pn: n = 0-2, 4-10,12)                             | 6-7  |
| 6.2.2               | Port Mode Registers (PnIO: n = 0-2, 4-10,12)                           | 6-7  |
| 6.2.3               | Port Secondary Function Control Registers (PnSF: n = 1, 2, 4-7, 9, 12) | 6-7  |
| 6.2.4               | Port Pull-Up Control Registers (PnPUP: n = 0, 1, 4, 9, 10)             | 6-8  |
| 6.3 Port            | 0 (P0)6                                                                | 6-10 |
| 6.4 Port            | : 1 (P1)6                                                              | 6-11 |
|                     | 2 (P2)6                                                                |      |
|                     | 6 4 (P4)                                                               |      |
|                     | .5 (P5)6                                                               |      |
|                     | 6 (P6)6                                                                |      |
|                     |                                                                        |      |
|                     | 8 (P8)6                                                                |      |
|                     | 9 (P9)                                                                 |      |
|                     | 10 (P10)                                                               |      |
| 6.13 Port           | . 12 (P12)                                                             | 6-25 |
|                     |                                                                        |      |
| Chapter 7           | Clock Generator Circuit                                                | 7-1  |
| •                   |                                                                        |      |
| <b>O</b> h an tau 0 | Time Deve Occurter (TDO)                                               |      |
| Chapter 8           |                                                                        |      |
| 8.1 1/n (           | Counter                                                                | 8-2  |
|                     |                                                                        |      |
| Chapter 9           | 16-Bit RTO/PWM Timer                                                   | 9-1  |
| 9.1 Cou             | nter Configuration                                                     | 9-2  |
|                     | Select Register                                                        |      |
|                     | ister Modules (TMR8, TMR9)                                             |      |
| 9.3.1               | Register Module (TMR8, TMR9) Configuration                             |      |
| (1)                 |                                                                        |      |
| (2)                 | <b>o</b>                                                               |      |
| (3)                 |                                                                        |      |
| 9.3.2               | Register Module (TMR8, TMR9) Operation                                 |      |
| (1)                 |                                                                        |      |
| (2)                 |                                                                        |      |
| (3)                 | PWM Mode Operation                                                     | 9-7  |

| Chap | ter 10 General 8-Bit Timer                                      | 10-1  |
|------|-----------------------------------------------------------------|-------|
| 10.1 | General 8-Bit Timer                                             |       |
|      | (1) General 8-Bit Counter (GTMC)                                |       |
|      | (2) General 8-bit Register (GTMR)                               |       |
|      | (3) General 8-Bit Timer Control Register (GTMCON)               |       |
| Ohan |                                                                 |       |
| -    | ter 11 PWM Function                                             |       |
|      | Clock Divider Circuit                                           |       |
| 11.2 | PWM Configuration                                               |       |
|      | <ul><li>(1) PWM Counter (PWC0)</li></ul>                        |       |
|      | <ul><li>(3) PWM Register (PWR0)</li></ul>                       |       |
|      | (4) PWM Buffer Register (PW0BF)                                 |       |
|      | (5) Comparator Circuit                                          |       |
|      | (6) Output Flip/Flop                                            |       |
|      | (7) PWM Control Register (PWCON0)                               |       |
|      | (8) PWM Run Register (PWRUN)                                    |       |
|      | (9) PWM Interrupt Registers (PWINTQ0, PWINTQ1)                  |       |
|      | (10) PWM Interrupt Enable Registers (PWINTE0, PWINTE1)          |       |
| 11.3 | PWM Operation                                                   | 11-7  |
|      |                                                                 |       |
| -    | ter 12 Baud Rate Generator Functions                            |       |
| 12.1 | SCI1 Timer (S1TM) Configuration                                 |       |
|      | (1) SCI1 Timer Counter                                          |       |
|      | (2) SCI1 Timer Register                                         |       |
| 10.0 | (3) SCI1 Timer Control Register (S1CON)<br>SCI1 Timer Operation |       |
| 12.2 |                                                                 | 12-4  |
| Chap | ter 13 Serial Port Functions                                    |       |
| 13.1 | Serial Port Configuration                                       | 13-1  |
|      | .1.1 SCI1 Transmit/Receive Control Register (SR1CON)            |       |
|      | .1.2 SCI1 Transmit Control Register (ST1CON)                    |       |
| 13   | .1.3 SCI1 Transmit/Receive Buffer Register (S1BUF)              | 13-5  |
|      | .1.4 SCI1 Transmit/Receive Register                             |       |
|      | .1.5 SCI1 Status Register (S1STAT)                              |       |
|      | Serial Port Operation                                           |       |
|      | .2.1 Transmit Operation                                         |       |
| 13   | .2.2 Receive Operation                                          | 13-11 |
| Chan | ter 14 A/D Converter Functions                                  |       |
|      | A/D Converter Configuration                                     |       |
| 14.1 | (1) A/D Control Register High (ADCONH)                          |       |
|      | <ul><li>(2) A/D Interrupt Control Register (ADINTCON)</li></ul> |       |
|      | <ul><li>(3) A/D Result Register (ADCR0)</li></ul>               |       |

| Chap | ter 15   | Peripheral Functions                                    |      |
|------|----------|---------------------------------------------------------|------|
| 15.1 | Clock (  | Dut Function                                            |      |
|      |          |                                                         | 10.1 |
| Chap | ter 16   | External Interrupt Requests                             | 16-1 |
| Chap | ter 17   | Interrupt Request Processing                            |      |
| 17.1 | Non-M    | askable Interrupt (NMI)                                 |      |
| 17.2 |          | ble Interrupts                                          |      |
|      | (1) Ir   | terrupt Request Registers IRQ (IRQ0L, IRQ0H, IRQ1L)     |      |
|      |          | terrupt Enable Registers IE (IE0L, IE0H, IE1L)          |      |
|      | (3) N    | laster Interrupt Enable Flag                            |      |
|      | (4) N    | laster Interrupt Priority Flag                          |      |
|      | (5) Ir   | terrupt Priority Control Registers                      |      |
|      |          | IPX0 (IP00L, IP00H, IP10L)                              |      |
|      |          | IPX1 (IP01L, IP01H)                                     |      |
| 17.3 | Maskal   | ble Interrupt Operation                                 |      |
|      |          |                                                         |      |
| Chap | ter 18   | Bus Port Functions                                      |      |
| 181  | Rus Po   | rt (P0, P1, P9_0-P9_3) Functions                        | 18-1 |
|      |          | 9, P1, P9_0-P9_3 Operation During Program Memory Access |      |
|      |          | , P1, P9_0-P9_3 Operation During Data Memory Access     |      |
|      |          | I Memory Access                                         |      |
|      |          | ternal Program Memory Access                            |      |
|      |          | ternal Program Memory Access Timing                     |      |
|      |          | ternal Data Memory Access                               |      |
|      |          | ternal Data Memory Access Timing                        |      |
|      |          | ,                                                       |      |
| Chap | ter 19   | Flash Memory                                            |      |
| 19.1 | Summa    | ary                                                     |      |
|      |          | )S                                                      |      |
| 19.3 | Reprog   | ramming Modes                                           |      |
| 19.4 | Serial N | Node                                                    |      |
| 19   | .4.1 Se  | rial Mode Summary                                       |      |
| 19   | .4.2 Se  | tting the Serial Mode                                   |      |
|      | (1) Pir  | ns Used for Serial Mode                                 |      |
|      | (2) Se   | rial Mode Connections                                   |      |
|      | (3) Se   | rial Mode Reprogramming Method                          |      |
|      |          | tes Regarding Serial Mode Usage                         |      |
| 19.5 |          | ode                                                     |      |
|      |          | er Mode Summary                                         |      |
| 19   |          | er Mode Reprogramming                                   |      |
|      |          | ish Memory Address Register (FLAADRS)                   |      |
|      |          | Ish Memory Acceptor (FLAACP)                            |      |
|      |          | Ish Memory Control Register (FLACON)                    |      |
|      | (4) Flo  | wchart Examples for User Mode                           |      |

|      | (5) Example Data Verification Programs to Check Erased or Reprogrammed Data | 19-13 |
|------|-----------------------------------------------------------------------------|-------|
|      | (6) Notes on Usage Regarding User Mode                                      | 19-14 |
| 19.6 | Programming Notes                                                           | 19-15 |
|      | (1) Reprogramming Immediately after Power is Supplied to Flash Memory       | 19-15 |
|      | (2) Note when STOP Mode is Canceled                                         | 19-15 |

| Chapter 20 Electrical Characteristics                            | 20-1  |
|------------------------------------------------------------------|-------|
| 20.1 Absolute Maximum Ratings                                    | 20-1  |
| 20.2 Recommended Operating Conditions                            |       |
| 20.3 Allowable Output Current                                    |       |
| 20.4 DC Characteristics                                          |       |
| 20.4.1 DC Characteristics ( $V_{DD} = 5 V \pm 10\%$ )            | 20-3  |
| 20.4.2 DC Characteristics (V <sub>DD</sub> = 2.7 to 5.5 V)       | 20-4  |
| 20.5 AC Characteristics                                          |       |
| 20.5.1 AC Characteristics ( $V_{DD} = 5 V \pm 10\%$ )            |       |
| (1) External Program Memory Control                              |       |
| (2) External Data Memory Control                                 |       |
| (3) Serial Port Control                                          |       |
| 20.5.2 AC Characteristics ( $V_{DD}$ = 2.7 to 5.5 V)             |       |
| (1) External Program Memory Control                              |       |
| (2) External Data Memory Control                                 |       |
| (3) Serial Port Control                                          |       |
| 20.6 A/D Converter Characteristics                               |       |
| 20.6.1 A/D Converter Characteristics ( $V_{DD} = 5 V \pm 10\%$ ) |       |
| 20.6.2 A/D Converter Characteristics ( $V_{DD} = 3 V \pm 10\%$ ) | 20-14 |
| Chapter 21 Special Function Registers (SFRs)                     | 21-1  |
| Chapter 22 Package Dimensions                                    | 22-1  |

| Chapter 1     | Overview                          | 1  |
|---------------|-----------------------------------|----|
| Chapter 2     | Pin Descriptions                  | 2  |
| Chapter 3     | CPU Architecture                  | 3  |
| Chapter 4     | CPU Control Functions             | 4  |
| Chapter 5     | Memory Control Functions          | 5  |
| Chapter 6     | Port Functions                    | 6  |
| Chapter 7     | Clock Generator Circuit           | 7  |
| <br>Chapter 8 | Time-Base Counter (TBC)           | 8  |
| Chapter 9     | 16-Bit RTO/PWM Timer              | 9  |
| Chapter 10    | General 8-Bit Timer               | 10 |
| Chapter 11    | PWM Function                      | 11 |
| Chapter 12    | Baud Rate Generator Functions     | 12 |
| Chapter 13    | Serial Port Functions             | 13 |
| Chapter 14    | A/D Converter Functions           | 14 |
| Chapter 15    | Peripheral Functions              | 15 |
| Chapter 16    | External Interrupt Requests       | 16 |
| Chapter 17    | Interrupt Request Processing      | 17 |
| Chapter 18    | Bus Port Functions                | 18 |
| Chapter 19    | Flash Memory                      | 19 |
| Chapter 20    | Electrical Characteristics        | 20 |
| Chapter 21    | Special Function Registers (SFRs) | 21 |
| Chapter 22    | Package Dimensions                | 22 |

# Chapter 1

Overview

#### 1. Overview

The MSM66587 family of devices are high-performance CMOS 16-bit microcontrollers that integrate a 16-bit CPU (nX-8/500S), ROM, RAM, 8-bit A/D converter, serial port, timers, and PWM. They also allow ROM and RAM to be expanded externally.

The MSM66P587 is of OTP (One-Time PROM) version, the MSM66Q587 is of Flash EEPROM version, and the MSM66X587A is of version with no ROM.

#### 1.1 Features

Powerful instruction set Instruction set superior in orthogonal matrics 8/16-bit arithmetic instructions Multiply/divide instructions Bit manipulation instructions Bit logical operation instructions ROM table reference instructions Abundant addressing modes Register addressing Page addressing Pointer register indirect addressing Stack addressing Immediate addressing Minimum instruction cycle 100 ns at 20 MHz (4.5 V to 5.5 V) 200 ns at 10 MHz (2.7 V to 5.5 V) Program memory (ROM) 64KB (The MSM66X587A includes no internal ROM) Internal: External: 1MB, EA pin active Data memory (RAM) Internal: 2KB External: 1022KB I/O ports Analog input-only port: 4 lines Input/output port: 80 lines Maximum (40 lines with programmable pull-up) Timers Free-run counter: One 16-bit Two 16-bit Realtime output: General autoreload timer: One 8-bit 16-bit PWM Input clock divider: 1 divider 8-bit serial port Synchronous with BRG: 1 port A/D converter 8-bit resolution: 4 channels Interrupts Non-maskable 1 interrupt 9 internal, 4 external (12 vectors) Maskable 3-level priority ROM window function Standby modes HALT mode STOP mode

Package

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

#### MSM66587 Family Products List

| Туре                        | MSM66587A                                    | MSM66X587A   |  |  |
|-----------------------------|----------------------------------------------|--------------|--|--|
| Operating Temperature       | -30°C to +70°C                               |              |  |  |
| Minimum Instruction         | 100 nsec @20 MHz (4.5 to 5                   | .5V)         |  |  |
| Execution Time              | 200 nsec @10 MHz (2.7 to 5                   | .5V)         |  |  |
| Internal ROM Size           | 64KB                                         | Not included |  |  |
| (Maximum External ROM Size) | (1MB)                                        |              |  |  |
| Internal RAM Size           | 2КВ                                          |              |  |  |
| (Maximum External RAM Size) | (1MB)                                        |              |  |  |
| 1/0 Dort                    | 80 input/output lines (ma                    | x)           |  |  |
| I/O Port                    | (includes 40 lines with programma            | ble pull-up) |  |  |
|                             | 16-bit free-run counter × 1                  | lch          |  |  |
|                             | 16-bit real-time-out × 2ch                   |              |  |  |
|                             | (RTO/toggle output RTO mode selectable)      |              |  |  |
|                             | (Configure 2-ch RTO as 1-ch PWM)             |              |  |  |
| Timer                       | 16-bit PWM × 1ch                             |              |  |  |
|                             | 8-bit geneal auto-reload $\times$ 1ch        |              |  |  |
|                             | (Capable of counting external events)        |              |  |  |
|                             | Used as 8-bit auto-reload × 1ch              |              |  |  |
|                             | serial communication and baud-rate generator |              |  |  |
| Serial Port                 | Synchronous × 1ch                            |              |  |  |
| A/D Converter               | 8-bit × 4ch                                  |              |  |  |
| External Interrunt          | Nonmaskable 1ch                              |              |  |  |
| External Interrupt          | Maskable 4ch                                 |              |  |  |
| Other                       | OTP ROM version : MSM66P587 (2.7 to 5.5      | V)           |  |  |
| Other                       | FLASH ROM version : MSM66Q587 (4.5 to 5.5 V) |              |  |  |





\* The MSM66X587A includes no internal ROM

1

#### 1.3 Pin Configuration (Top View)



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

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

#### 1.4 Basic Operation Timing

The MSM66587 family of devices integrate an OKI-original 16-bit CPU Core (nX-8/500S). In the nX-8/500S, each instruction code consists of one byte to six bytes on the basis of 8 bits. There are two types of instruction groups: one is NATIVE instructions and the other is COMPOSIT instruction.

The NATIVE instructions are used frequently and the COMPOSIT instructions are used to implement a wide range of addressing.

The NATIVE instructions consist of one to three bytes to achieve a high code utilization and high instruction execution efficiency.

The COMPOSIT instructions are composed of an address

specification field (PREFIX: 1 to 3 bytes) and operation

specification field (SUFFIX: 1 to 3 bytes).

The combination of PREFIX and SUFFIX can achieve a wide range of addressing.

The basic clock executes one state in a single pulse (CLK). One state is 50 ns (at 20 kHz). Execution of a single instruction takes multiple states (S2, S3,...Sn).

The number of states required for instruction execution differs by instruction. The minimum is 2 states;

The maximum is 48 states (For details refer to the nX-8/500S Core Instruction Manual).

In addition, when program memory is accessed externally, one cycle is inserted automatically for each one-byte read (fetch), and furthermore wait cycles (0 to 3) that are set by the ROM Ready Control Register (ROMRDY), are added. When data memory is accessed externally, three or four cycles (1 cycle=1 state) are inserted automatically for each one byte read or write, and moreover, wait cycles (0 to 7) that are set by the RAM Ready Control Register (RAMRDY) are added. Figures 1-3 and 1-6 show basic timing examples.

#### [Note]

Some COMPOSIT instruction used to write data to external data memory outputs a meaningless RD signal (dummy RD signal) before actual access (PREFIX specifies external data memory). One dummy RD signal is output for byte/bit access and two dummy RD signals are output for word access.

Table 1-1 and 1-2 list instructions with PREFIX and SUFFIX to output dummy RD signals when external data memory is accessed.

In the tables, \* of SUFFIX describes an addressing of PREFIX.

| SUFFIX                 |                  |   | PREFIX  |                  |
|------------------------|------------------|---|---------|------------------|
| Instruction desciption | Instruction code |   | *       | Instruction code |
| SB *                   | 08+bit           |   | Rn      | 68+n             |
| RB *                   | 00+bit           |   | [X1]    | B0               |
| SBR *                  | B8               |   | [DP]    | B2               |
| RBR *                  | B9               |   | [DP-]   | B1               |
| TBR *                  | CA               |   | [DP+]   | B3               |
| MB *.bit, C            | 18+bit           | + | off     | B5               |
| MBR *.bit, C           | BB               |   | 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] | BB               |

#### Table 1-1 Instructions (Byte/Bit Manipulations) In Which a Dummy RD Occurs Once (PREFIX and SUFFIX Combinations)

#### Table 1-2 Instructions (Word Manipulations) In Which a Dummy RD Occurs Twice (PREFIX and SUFFIX Combinations)

SUFFIX

| Instruction desciption | Instruction code |
|------------------------|------------------|
| MOVB *,A               | AA               |
| MOVB *,#N16            | AB               |
| CLR *                  | C7               |
| FILL *                 | D7               |

| PREFIX  |                  |  |
|---------|------------------|--|
| *       | Instruction code |  |
| ERn     | 64+n             |  |
| [X1]    | A0               |  |
| [DP]    | A2               |  |
| [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               |  |



-1  $\overline{}$ 

MSM66587 Family User's Manual

Chapter 1 Overview







1 - 9





## Chapter 2

# **Pin Descriptions**

2

#### 2. Pin Descriptions

This chapter describes each pin.

#### 2.1 P0\_0-P0\_7: Input/Output Pins

Port 0 is 8 input/output pins. Input or output can be specified for each bit with the Port 0 Mode Register (P0IO). Pull-up resistors can be specified for each bit with the Port 0 Pull-Up Register (P0PUP).

These pins also function as time-multiplexed address outputs and data input/output pins (AD0-AD7) when accessing memory that has been expanded externally (program or data memory).

After reset (by RES signal input, BRK instruction execution, or op code trap), P0 will be high-impedance inputs.

#### 2.2 P1\_0-P1\_7: Input/Output Pins

Port 1 is 8 input/output pins. Input or output can be specified for each bit with the Port 1 Mode Register (P1IO). Pull-up resistors can be specified for each bit with the Port 1 Pull-Up Register (P1PUP).

P1\_0-P1\_7 also have a secondary function as input/output pins for internal operation. Their secondary function can be set for each bit with the Port 1 Secondary Function Control Register (P1SF). The input/output settings by P1IO will be ignored for pins that have been set to the secondary function by P1SF.

< Secondary function of each pin >

A8-A15 (P1\_0-P1\_7)

These pins function as output pins for address A8-A15 when accessing program memory or data memory that has been expanded externally. When the  $\overline{EA}$  pin is low, A8-A15 will be output regardless of P1SF settings.

After reset (by RES signal input, BRK instruction execution, or op code trap), P1 will be high-impedance inputs.

#### 2.3 P2\_0-P2\_7: Input/Output Pins

Port 2 is 8 input/output pins. Input or output can be specified for each bit with the Port 2 Mode Register (P2IO).

P2\_4 and P2\_5 also have a secondary function as input/output pins for internal operation. Their secondary function can be set for each bit with the Port 2 Secondary Function Control Register (P2SF). The input/output settings of P2IO will be ignored for pins that have been set to the secondary function by P2SF.

< Secondary function of each pin >

RTO8 (P2\_4), RTO9 (P2\_5)

These pins output a previously set level when the value of Timer Registers 8 and 9 matches a selected counter value.

After reset (by RES signal input, BRK instruction execution, or op code trap), P2 will be high-impedance inputs.

#### 2.4 P4\_0-P4\_7: Input/Output Pins

Port 4 is 8 input/output pins. Input or output can be specified for each bit with the Port 4 Mode Register (P4IO). Pull-up resistors can be specified for each bit with the Port 4 Pull-Up Register (P4PUP).

P4\_0 also has a secondary function as an input pin for internal operation. Its secondary function can be set for the bit with the Port 4 Secondary Function Control Register (P4SF). The input/output settings by P4IO will be ignored for pins that have been set to the secondary function by P4SF.

< Secondary function of each pin >

ETMCK (P4\_0)

This is the external clock input pin for the counter of a general 8-bit timer.

After reset (by RES signal input, BRK instruction execution, or op code trap), P4 will be high-impedance inputs.

#### 2.5 P5\_4, P5\_5: Input/Output Pins

Port 5 is 2 input/output pins. Input or output can be specified for each bit with the Port 5 Mode Register (P5IO).

P5\_4 and P5\_5 also have a secondary function as output pins for internal operation. Their secondary function can be set for each bit with the Port 5 Secondary Function Control Register (P5SF). The input/output settings of P5IO will be ignored for pins that have been set to the secondary function by P5SF.

2

< Secondary function of each pin >

**PSEN** (P5\_4)

This pin outputs the strobe signal for read operations when external program memory is accessed. Operation will automatically switch to the secondary function when the  $\overline{EA}$  pin is low. This pin will be pulled up when both the  $\overline{EA}$  pin and  $\overline{RES}$  pin are low.

ALE (P5\_5)

This pin outputs the strobe for externally latching the lower 8 address bits output from P0 when external memory is accessed. Operation will automatically switch to the secondary function when the  $\overline{EA}$  pin is low. This pin will be pulled up when both the  $\overline{EA}$  pin and  $\overline{RES}$  pin are low.

After reset (by RES signal input, BRK instruction execution, or op code trap), P5 will be high-impedance inputs.

#### 2.6 P6\_0-P6\_5

Port 6 is 6 input/output pins. Input or output can be specified for each bit with the Port 6 Mode Register (P6IO).

P6\_0-P6\_5 also have a secondary function as input/output pins for internal operation. Their secondary function can be set for each bit with the Port 6 Secondary Function Control Register (P6SF). The input/output settings of P6IO will be ignored for pins that have been set to the secondary function by P6SF.

< Secondary function of each pin >

INT0 (P6\_0), INT1 (P6\_1)

These pins input external interrupts 0 and 1.

RXD1 (P6\_2)

This pin inputs receive data to the Serial Port 1 receive circuit.

TXD1 (P6\_3)

This pin outputs transmit data to the Serial Port 1 transmit circuit.

RXC1 (P6\_4)

This pin outputs the shift clock when the Serial Port 1 receive circuit is in master mode. It inputs the shift clock when the receive circuit is in slave mode.

TXC1 (P6\_5)

This pin outputs the shift clock when the Serial Port 1 transmit circuit is in master mode. It inputs the shift clock when the transmit circuit is in slave mode.

After reset (by RES signal input, BRK instruction execution, or op code trap), P6 will be high-impedance inputs.

#### 2.7 P7\_0-P7\_7: Input/Output Pins

Port 7 is 8 input/output pins. Input or output can be specified for each bit with the Port 7 Mode Register (P7IO).

P7\_0-P7\_4 also have a secondary function as input/output pins for internal operation. Their secondary function can be set for each bit with the Port 7 Secondary Function Control Register (P7SF). The input/output settings of P7IO will be ignored for pins that have been set to the secondary function by P7SF.

< Secondary function of each pin >

WR (P7\_0)

This pin outputs the strobe signal for write operations when external data memory is accessed.

#### RD (P7\_1)

This pin outputs the strobe signal for read operations when external data memory is accessed.

WAIT (P7\_2)

This pin inputs a wait to the internal CPU when external data memory with a slow access time is accessed. CPU is driven to "WAIT" state during WAIT pin high.

#### CLKOUT (P7\_3)

This pin outputs the clock pulses set by the Peripheral Control Register (PRPHF).

PWM0 (P7\_4)

This pin outputs PWM0.

After reset (by RES signal input, BRK instruction execution, or op code trap), P7 will be high-impedance inputs.

When P7\_0 and P7\_1 are used as their secondary functions (WR, RD), they need to be connected externally to pull-up resistors.

#### 2.8 P8\_0-P8\_7: Input/Output Pins

Port 8 is 8 input/output pins. Input or output can be specified for each bit with the Port 8 Mode Register (P8IO).

After reset (by RES signal input, BRK instruction execution, or op code trap), P8 will be high-impedance inputs.

2

#### 2.9 P9\_0-P9\_7: Input/Output Pins

Port 9 is 8 input/output pins. Input or output can be specified for each bit with the Port 9 Mode Register (P9IO). Pull-up resistors can be specified for each bit with the Port 9 Pull-Up Register (P9PUP).

P9\_0-P9\_3 also have a secondary function as output pins for internal operation. Their secondary function can be set for each bit with the Port 9 Secondary Function Control Register (P9SF). The input/output settings of P9IO will be ignored for pins that have been set to the secondary function by P9SF.

< Secondary function of each pin >

A16-A19 (P9\_0-P9\_3)

These pins function as output pins for address A16-A19 when accessing program memory or data memory that has been expanded externally. Note that program memory address A16-A19 will be output even when accessing data memory that has been expanded externally. When the  $\overline{EA}$  pin is low and program memory that has been expanded externally is accessed, A16-A19 will be output regardless of P9SF settings.

After reset (by RES signal input, BRK instruction execution, or op code trap), P9 will be high-impedance inputs.

2.10 P10\_0-P10\_7: Input/Output Pins

Port 10 is 8 input/output pins. Input or output can be specified for each bit with the Port 10 Mode Register (P10IO). Pull-up resistors can be specified for each bit with the Port 10 Pull-Up Register (P10PUP).

After reset (by RES signal input, BRK instruction execution, or op code trap), P10 will be high-impedance inputs.

#### 2.11 P12\_0-P12\_7: Input/Output Pins

Port 12 is 8 input/output pins. Input or output can be specified for each bit with the Port 12 Mode Register (P12IO).

P12\_2 and P12\_3 also have a secondary function as input pins for internal operation. Their secondary function can be set for each bit with the Port 12 Secondary Function Control Register (P12SF). The input/output settings of P12IO will be ignored for pins that have been set to the secondary function by P12SF.

< Secondary function of each pin >

INT2 (P12\_2), INT3 (P12\_3)

These pins input external interrupts 2 and 3.

After reset (by RES signal input, BRK instruction execution, or op code trap), P12 will be highimpedance inputs.

#### 2.12 AlO-Al3: Input Pins

These are analog input pins for the A/D converter.

2.13 V<sub>REF</sub>: Input Pin

This is the reference voltage pin for the A/D converter.

2.14 AGND: Input Pin

This is the ground input pin for the A/D converter.

2.15 OSC0, OSC1: Input Pin, Output Pin

These pins connect to a crystal oscillator, ceramic oscillator, or capacitors for base clock oscillation. When the base clock is to be supplied externally, it should be input on the OSC0 pin with the OSC1 pin left open.

2.16 NMI: Input Pin

This input pin requests a non-maskable interrupt.

2.17 RES: Input Pin

This is an active-low reset input pin.

2.18 EA: Input Pin

When this pin is high, program addresses 0H-FFFFH will access internal program memory and program addresses 10000H-FFFFFH will access external program memory. <u>To access external program memory</u>, P1, P5, and P9 must be set with their secondary function control registers.

When this pin is low, all program addresses will access external program memory.

2.19 V<sub>DD</sub>: Input Pins

These are voltage pins. All V<sub>DD</sub> pins (9, 17, 37, 67, 93) should be connected to the supply voltage.

2.20 GND: Input Pins

These are ground pins. All GND pins (16, 40, 68, 94) should be connected to ground.

#### 2.21 Pin Configurations

Table 2-1 and Figure 2-1 show a simplified configuration for each pin.

| Pin Name   | Type Number | Pin Name    | Type Number |
|------------|-------------|-------------|-------------|
| P0_0-P0_7  | 7           | P9_0-P9_7   | 6           |
| P1_0-P1_7  | 6           | P10_0-P10_7 | 6           |
| P2_0-P2_7  | 5           | P12_0-P12_7 | 5           |
| P4_0-P4_7  | 6           | AI0-AI3     | 3           |
| P5_4, P5_5 | 4           | NMI         | 1           |
| P6_0-P6_5  | 5           | RES         | 2           |
| P7_0-P7_7  | 5           | ĒĀ          | 1           |
| P8_0-P8_7  | 5           |             |             |

#### Table 2-1 Pin Configurations





#### 2.22 Unused Pins

Table 2-2 shows how to connect unused pins.

#### Table 2-2 Unused Pins

| Pin              | Connection when unused                 |
|------------------|----------------------------------------|
| P0_0-P0_7        |                                        |
| P1_0-P1_7        | When set as programmable pull-up: open |
| P4_0-P4_7        | When set as input: high or low level   |
| P9_0-P9_7        |                                        |
| P10_0-P10_7      | When set as output: open               |
| P2_0-P2_7        |                                        |
| P5_4, P5_5       |                                        |
| P6_0-P6_5        | When set as input: high or low level   |
| P7_0-P7_7        | When set as output: open               |
| P8_0-P8_7        |                                        |
| P12_0-P12_7      |                                        |
| AI0-AI3          | V <sub>REF</sub> or AGND               |
| V <sub>REF</sub> | V <sub>DD</sub>                        |
| AGND             | GND                                    |
| NMI              | High or Low level                      |
| ĒĀ               | High level                             |

2

## **Chapter 3**

3

# **CPU** Architecture

### 3. CPU Architecture

#### 3.1 Memory Space

Two independent memory spaces, a program memory space and data memory space are provided. After reset both program memory space and data memory space can be accessed up to 64KB. By changing the Memory Size Control Register (allocated as an SFR), program memory space and data memory space can be expanded to a maximum of 1MB.

#### 3.1.1 Memory Space Expansion

The Memory Size Control Register (MEMSCON) is allocated in the expanded SFR area to specify the size of the memory spaces. By setting bit 1 (LROM) to "1", program memory space will be expanded to 1MB. By setting bit 0 (LRAM) to "1", data memory space will be expanded to 1MB.



"—" indecates bits that do not exist. When read, "1" is read.

Just before writing the LROM and LRAM bits of MEMSCON, you must write in sequence 5H followed by 0AH to the upper (for LROM) and lower (for LRAM) four bits of the Memory Size Acceptor Register (MEMSACP).



When the LROM and LRAM bits are written (set), the actual change in memory space will be after execution of the instruction after the instruction that wrote the LROM and LRAM bits. Here is a program example showing memory space expansion to each individual model.

• COMPACT model (pragram memory space 64KB, data memory space 1MB)

| MOVB | MEMSACP, #05H |
|------|---------------|
| MOVB | MEMSACP, #0AH |
| MOVB | MEMSCON, #01H |

- MEDIUM model (program memory space 1MB, data memory space 64KB) MOVB MEMSACP, #50H
  - MOVB MEMSACP, #30H MOVB MEMSACP, #0A0H MOVB MEMSCON, #02H
- LARGE model (program memory space 1MB, data memory space 1MB)
  - MOVB MEMSACP, #55H MOVB MEMSACP, #0AAH
  - MOVB MEMSCON, #03H

After reset (RES signal input, BRK instruction execution, or OPTRP trap). <u>MEMSCON can be written one time only</u>. Therefore, once the memory space model has been set, it can be changed to other models only after a reset (RES signal input, BRK instruction, or OPTRP trap).

3.1.2 Program Memory Space

Up to 1MB (1,048,576 bytes) of program memory can be accessed as segments 0-15, with one segment equal to 64KB (65,536 bytes). However, to access above 64KB (segments 1-15), the LROM bit of MEMSCON (Memory Size Control Register) allocated as an SFR must be set to 1.

The segment is specified by the Code Segment Register (CSR). The address within a segment is specified by the Program Counter (PC). However, the segment when executing ROM table reference instructions (LCA obj, etc.) and ROM window functions is specified by the Table Segment Register (TSR).

The 64KB in segment 0 are the internal ROM area, and the 64KB in segments 1-15 are the external ROM area.

The following are allocated in segment 0.

Vector table area (82 bytes) VCAL table area (32 bytes)

The following are allocated in each segment.

ACAL area (2048 bytes)

Figure 3-1 shows a memory map of program memory space.



Figure 3-1 Program Memory Space Memory Map

(1) Accessing Program Memory Space

Program memory space is accessed using the Program Counter (PC) and Code Segment Register (CSR). However, when ROM table reference instructions (LC A, obj, etc.) and ROM window functions (refer to Section 5.1) are executed, program memory space will be accessed using the Table Segment Register (TSR) and a register specified by the instruction.

For program memory space, access of the internal ROM area and external memory area is switched automatically by the state of the EA pin (input: pin 36). When the EA pin is input high, program memory addresses 0000H-FFFFH will access the internal memory area, and 10000H-FFFFFH will access the external memory area. <u>To access the external memory area</u>, Port 1, 5, and 9 must be set by their secondary function control registers.

When the  $\overline{EA}$  pin is input low, program addresses across the entire memory space will be accessed in the external memory area.

When program memory space is accessed in the external memory area, Port 0 (I/O pins 51-58: AD0-AD7 outputs and data inputs), Port 1 (output pins 59-66: A8-A15 outputs), and Port 9 (output pins 69-72: A16-A19 outputs) operate as a bus port synchronized to the P5\_5/ALE pin (output pin 50). The P5\_4/PSEN pin (output pin 49) will also be active.

The internal program area that can be fetched is 0000H-FFFDH. Be sure that the last address of instruction codes does not exceed FFFDH. The last address of table data is FFFFH.

(2) Vector Table Area

In program memory space segment 0, the 74 bytes at 0000H-0049H and the 8 bytes at 006AH-0071H form a vector table area (16 types) that stores branch addresses for each type of interrupt request and for reset by RES pin input (input pin 34), by break instruction, or by op code trap (OPTRP).

When a reset or interrupt occurs, the corresponding 2-byte branch address stored in the vector table is loaded into the PC (even address is low data, odd address is high data), and simultaneously 0 is loaded into the CSR. Program execution then starts from the loaded address in segment 0. If, for example, a reset or interrupt occurs during execution of an instruction in segment 1, then execution will branch to an address in segment 0.

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

Table 3-1 shows the vector table for reset and interrupt requests.

#### [Example] Program start address after RES pin input from 0200H

Program Address 0000H 0001H Data Code 00H 02H

Program start address low data Program start address high data

#### Table 3-1 Vector Table

| Program Address | Vector Source                            |
|-----------------|------------------------------------------|
| Address [H]     |                                          |
| 0000            | RES pin input reset                      |
| 0002            | BRK instruction execution reset          |
| 0006            | OPTRP (op code trap) reset               |
| 0008            | NMI pin input interrupt                  |
| 000A            | External interrupt pin INTO interrupt    |
| 000E            | TM1 overflow interrupt                   |
| 0020            | RT08 event generation interrupt          |
| 0022            | RT09 event generation interrupt          |
| 0028            | Serial port 1 transmit/receive interrupt |
| 002A            | S1TM overflow interrupt                  |
| 002C            | GTMC overflow interrupt                  |
| 0030            | A/D conversion completion interrupt      |
| 0032            | PWC0 underflow/matching interrupt        |
| 0038            | External interrupt pin INT1 interrupt    |
| 006E            | External interrupt pin INT2 interrupt    |
| 0070            | External interrupt pin INT3 interrupt    |

#### (3) VCAL Table Area

In program memory space segment 0, the 32 bytes at 004AH-0069H form the VCAL table area that stores branch addresses (VCAL: 16 types) for one-byte call instructions.

When a VCAL instruction is executed, the next address after the VCAL instruction is saved on the system stack, the System Stack Pointer (SSP) is decremented by two, the corresponding 2-byte branch address stored in the VCAL table is loaded into the PC (even address is low data, odd address is high data), and program execution then starts from the loaded address.

However, when program memory space has been expanded to 1MB, the value of CSR is saved at the same time the value of PC is saved, so SSP will be decremented by four. Also, at the same time the branch address is loaded into the PC, a 0 will be loaded into CSR. If, for example, a VCAL instruction in segment 1 is executed, then execution will branch to an address in segment 0.

When program memory space is 64KB with the LROM bit in MEMSCON set to 0, return from subroutines called by a VCAL instruction with an RT instruction. When program memory space is 1 MB with the LROM bit in MEMSCON set to 1, return from subroutines called by a VCAL instruction with an FRT instruction.

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

Table 3-2 shows VCAL vector addresses.

[Example] Program start address after VCAL 4AH from 0400H

| <u>Program Address</u> | Data Code |                                 |
|------------------------|-----------|---------------------------------|
| 004AH                  | 00H       | Program start address low data  |
| 004BH                  | 04H       | Program start address high data |

| VCAL Table 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         |

#### Table 3-2 VCAL Vector Table Addresses

#### (4) ACAL Area

In each segment of program memory space, the 2KB at 1000H-17FFH is the area for direct subroutine calls with the 2-byte call instruction (ACAL).

When an ACAL instruction is executed, the next address after the ACAL instruction is saved on the system stack, the System Stack Pointer (SSP) is decremented by two, the 11-bit data including in the ACAL instruction code is loaded into the PC, and program execution then starts from the loaded address. The CSR value is not modified.

3

#### 3.1.3 Data Memory Space

Up to 1MB (1,048,576 bytes) of data memory can be accessed.

The following areas are allocated to data memory space: special function register area (SFR: 256 bytes), expanded SFR area (256 bytes), fixed page area (FIX: 256 bytes), internal RAM area (2,048 bytes), local register setting area (2,048 bytes), and external memory area (1,046,016 bytes).

In addition, the pointing register area (PR: 64 bytes) and special bit addressing area (sbafix: 64 bytes) are allocated to the fixed page area. The ROM window setting area (1000H-FFFFH in every segment) is allocated to the external memory area.

To enable exchange of data between multiple data segments, there is a common area that starts in data memory from address 0H. The SFR area, expanded SFR area, and fixed page area always reside in the common area.

Figure 3-2 shows the memory map of data memory space.



Note: The range of the external memory area in segments 1 to 15 depends on that of the common area to be set.

Figure 3-2 Data Memory Space Memory Map

(1) Special Function Register (SFR) Area

In data memory space, the 256 bytes at 0000H-00FFH are allocated to a register group with special functions, like counters, control registers, and mode registers for internal peripheral hardware.

(2) Expanded Special Function Register (Expanded SFR) Area

In data memory space, the 256 bytes at 0100H-01FFH are allocated to a register group with special functions, just like the SFR area. However, note that the expanded SFR area is restricted in that it cannot use SFR addressing.

(3) Internal RAM Area

In data memory space, the 2KB (2,048 bytes) at 0200H-09FFH are allocated to internal RAM.

(4) Fixed Page (FIX) Area

In data memory space, the 256 bytes at 0200H-02FFH are allocated as a pointing register (PR) area and special bit address (sbafix) area.

The pointing register area is allocated to 0200H-023FH. It provides eight sets of the following four registers.

- Index Registers (X1, X2)
- Data Pointer (DP)
- User Stack Pointer (USP)

All of the pointing registers are 16-bit registers, with the even address as low data and the subsequent odd address as high data.

The special bit address area is allocated to 02C0H-02FF. This area enables efficient byte counts with SB, RB, JBR, and JBS instructions.

Figure 3-3 shows a map of the fixed page area.

3



Figure 3-3 Fixed Page Area Map

(5) Area for Setting Local Registers

In data memory space, the 2KB at 0200H-09FFH can be set for local registers. Local registers are set in 8-byte blocks with the lower 8 bits of LRB (LRBL). Figure 3-4 shows the map of the area for setting local registers.



Figure 3-4 Map of Area for Setting Local Registers

(6) External Memory Area

In data memory space, the 1022KB (1,046,016 bytes) at 0A00H-FFFFFH are an external memory area. This area is accessed by the following signals; port 0 (address output AD0-AD7, data input /output), port 1 (address output A8-A15), port 9 (address output A16-A19), P5\_5/ ALE (port 5 P5\_5 secondary function), P7\_0/WR (write strobe output function), and P7\_1/RD (read strobe output function). The ROM window function can also be set in this area with the ROM Window Setting Register. For a specified area in data memory space (1000H and above) the ROM window function makes instruction accesses (read operations) not on data in data memory space, but instead on the data in program memory space at the same address.

In the ROM window function, set the register for enabling it (ROMWIN) and access (read operations) addresses in external data memory.

#### (7) Common Area

Data memory space has a common area for exchanging data between segments. The area common to all segments is in the low end of data memory starting at offset address 0H of each segment. The range of the common area is determined by the values of the BCB bits in the PSW.

| BC | СВ | Common Area Pango |
|----|----|-------------------|
| 1  | 0  | Common Area Range |
| 0  | 0  | 0H-03FFH          |
| 0  | 1  | OH-1FFFH          |
| 1  | 0  | 0H-3FFFH          |
| 1  | 1  | 0H-7FFFH          |

#### 3.1.4 Accessing Data Memory

This section shows memory accesses in data memory space with byte and word operations performed by instructions.

#### (1) Byte Operation

For byte operations, 8-bit data at the address obtained by the instruction is accessed.

[Example] For LB A, [DP] assume that the value of DP is 0335H.



#### (2) Word Operation

For word operations, 8 bit-data at the address obtained by the instruction but with its least significant bit set to "0" (even address) is accessed as the low 8-bit data and 8bit-data at the obtained address but with its LSB set to "1" (odd address) is accessed as the high 8-bit data.

[Example] For L A, [DP] assume that the value of DP is 0334H (or 0335H).



#### 3.2 Registers

Registers are classified by their function: accumulator registers, control registers, pointing registers, special function registers, local registers, and segment registers. Figure 3-5 shows the configuration of the registers.



Pointing Registers

Local Registers

R1

R3

R5

R7

7

| 15 |     | 0 |
|----|-----|---|
|    | X1  |   |
|    | X2  |   |
|    | DP  |   |
|    | USP |   |

07

R0

R2

R4

R6

| Control Registers<br>15 | 0 |
|-------------------------|---|
| PSW                     |   |
| PC                      |   |
| LRB                     |   |
| SSP                     |   |
|                         |   |





Special Function Registers (SFR)

| 7 0 | 7 0 |
|-----|-----|
| 1   | 0   |
| 3   | 2   |
|     |     |
| 253 | 252 |
| 255 | 254 |

### Figure 3-5 Register Configuration

### 3.2.1 Arithmetic Register (ACC)

The accumulator (ACC) is a 16-bit register for all types of calculations. The arithmetic operation, shifting, and so on are performed with as follows.

• Word type: all 16 bits (bits 15-0) are performed

0

(ER0)

(ER1)

(ER2)

(ER3)

- Byte type: lower 8 bits (bits 7-0) are performed
- Nibble type: lower 4 bits (bits 3-0) are performed

When the accumulator specifies the object bit of a bit operation instruction (SBR, RBR, etc.) the upper 5 bits of the lower byte (bits 7-3) specify the address offset and the lower 3 bits (bits 2-0) specify the bit position.

ACC is allocated as an SFR. Its value after reset (by RES signal input, BRK instruction execution, op code trap) will be 0000H.

3 - 14

#### 3.2.2 Control Registers

This is a group of registers with specific functions to control program status, program sequence, local registers, stacks, etc. There are four 16-bit control registers.

(1) Program Status Word (PSW)

The PSW is a 16-bit register configured as follows.

- Flag for instruction execution (DD)
- Flags set (1) or reset (0) by instruction execution results (CY, ZF, HC, S, OV)
- Flag to specify the pointing register set (SCB0-2)
- Flag to enable (1) or disable (0) all maskable interrupts (MIE)
- Flag to enable (1) or disable (0) priority of all maskable interrupts (MIP)
- Flag to set the segment 0 common area (BCB0, 1)
- Flags available for user use (F0, 1)
- Flag provided for future expansion of CPU core functions, but which is available for user use with the MSM66587 family (MAB)

PSW is divided into 8-bit registers, PSWH (bits 15-8) and PSWL (bits 7-0), so it can be operated on with 8-bit instruction operations in addition to 16-bit operations.





The high byte of PSW (PSWH) contains the following.

- Flag for instruction execution (DD)
- Flags set (1) or reset (0) by instruction execution results (CY, ZF, HC, S, OV)

<u>Please note that when the following instructions are executed, the actual operation of the PSW</u> or PSWH flags may differ from expected.

- Instructions that load contents of PSW or PSWH into ACC. (Value corresponding to ZF in ACC will be undefined.)
- ② Bit operation instructions on ZF.
   (ZF will change based on its value immediately prior to execution of the bit operation instruction.)
- ③ Instructions that perform increment, decrement, arithmetic calculation, logical calculation, or comparison on PSW or PSWH (Value of PSW or PSWH after instruction execution will be undefined.)

When an interrupt occurs, the PSW will be saved automatically during the interrupt process. It will be restored automatically by execution of an RTI instruction.

PSW is allocated as an SFR. Its value after reset (by RES signal input, BRK instruction execution, op code trap) will be 0000H.

Below is an explanation of each bit in PSW.

Bit 15: Carry Flag (CY)

The Carry Flag will be set (1) if the result of an arithmetic calculation or comparison instruction generates any of the following. Otherwise it will be reset (0).

- Carry is generated from bit 7 for byte calculations.
- Borrow is generated to bit 7 for byte calculations.
- Carry is generated from bit 15 for word calculations.
- Borrow is generated to bit 15 for word calculations.

The Carry Flag can be directly set and reset by instructions and data can also be sent and received to the bits specified by the register. The state of the Carry Flag can also be tested by conditional branch instructions.

Bit 14: Zero Flag (ZF)

The Zero Flag will be set (1) when the following occurs. Otherwise it will be reset (0).

- Result value of an arithmetic calculation instruction is 0.
- Execution of a load instruction to ACC loads a value of 0.
- Object bit of a bit operation instruction is 0.

The state of the Zero Flag can also be tested by conditional branch instructions.

Bit 13: Half-Carry Flag (HC)

The Half-Carry Flag will be set ("1") when the result of executing an arithmetic calculation or comparison instruction (byte and word calculations are the same) carrys or borrows from bit 3. Otherwise it will be reset (0).

Bit 12: Data Descriptor (DD)

The Data Descriptor flag indicates the attribute of data stored in ACC.

- When DD is 1, all 16 bits of ACC data are considered valid.
- When DD is 0, the lower 8 bits of ACC data are considered valid.

When calculation and data transfer instructions with ACC are executed, DD is referred and execution proceeds as follows.

- When DD is 1, calculation and transfer will be executed with words.
- When DD is 0, calculation and transfer will be executed with bytes.

DD can be set ("1") or reset ("0") when a data transfer instruction to ACC is executed and when flag-specific set or reset instructions are executed.

- DD will be set ("1") when a word load instruction to ACC is executed or the SDD instruction is executed.
- DD will be reset ("0") when a byte load instruction to ACC is executed or the RDD instruction is executed.

When DD is modified by execution of a load instruction to ACC or a flag-specific set or reset instruction, the following instruction will refer and execute the modified DD if that instruction is reference DD.

DD is a part of PSW, so it can be overwritten by instructions other than the ones described above. In this case, the following instruction will refer the value of DD before it is modified if that instruction is reference DD. For this use, insert a NOP instruction after the instruction that directly modifies DD.

Bit 11: Sign Flag (S)

The Sign Flag will be set if the MSB of the execution result of an arithmetic or logical operation instruction is "1", and will be reset if MSB = "0".

Bit 10: Master Interrupt Priority Flag (MIP)

The Master Interrupt Priority Flag controls the priority function for maskable interrupts. If "1", the priority function is enabled. If "0", the priority function is disabled.

Bit 9: Overflow Flag (OV)

The Overflow Flag will be set ("1") if the execution result of an arithmetic operation instruction exceeds the range that can be expressed as 2's complement (-128 to +127 for byte arithmetic, -32768 to +32767 for word arithmetic). Otherwise it will be reset ("0").

Bit 8: Master Interrupt Enable Flag (MIE)

The Master Interrupt Enable Flag controls whether all maskable interrupts are enabled ("1") or disabled ("0").

This flag will be reset ("0") after the PSW is saved on the system stack during a maskable interrupt transfer cycle. It will be restored when an RTI instruction is executed. When MIE is set ("1"), all maskable interrupts are enabled to occur from the instruction following the one that set MIE. When MIE is reset ("0"), all maskable interrupts are disabled to occur from the instruction following the one that set MIE.

Bit 7: Multiply-Accumulate Bank Flag (MAB)

This flag can be used as a user flag.

Bit 6: User Flag 1 (F1) Bit 3: User Flag 0 (F0)

The User Flags can be set ("1") and reset ("0") by instructions.

Bit 5: Bank Common Base 1 (BCB1) Bit 4: Bank Common Base 0 (BCB0)

The Bank Common Base specifies the last address of the common area between segments in data memory space. The relationship of BCB value and the common area is as follows.

| BC | CB | Common Area Range |  |  |  |
|----|----|-------------------|--|--|--|
| 1  | 0  | Common Area hange |  |  |  |
| 0  | 0  | 0H-03FFH          |  |  |  |
| 0  | 1  | 0H-1FFFH          |  |  |  |
| 1  | 0  | 0H-3FFFH          |  |  |  |
| 1  | 1  | 0H-7FFFH          |  |  |  |

(2) Program Counter (PC)

The Program Counter is a 16-bit counter that stores the program address within a segment to execute next. It is generally incremented by the number of bytes in each instruction executed. When branch and conditional jump instructions are executed, the PC will be loaded with immediate data or the contents of a register. Even if the PC overflows when incremented, the value of CSR will not change.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap) or when an interrupt occurs, the PC will be loaded with a value from the vector table area.

(3) Local Register Base (LRB)

The Local Register Base is a 16-bit register. Its low-order 8 bits (LRBL) specify 2KB (0200H-09FFH) of data memory space (for local register addressing) in units of 8 bytes. Its high-order 8 bits (LRBH) specify 64KB of data memory space (for current page addressing) in units of 256 bytes. The 64 bytes at XXC0H-XXFFH in the current page are an area that can be accessed using the sba.bit of SB, RB, JBR, and JBS instructions.

LRBL (02H) and LRBH (03) are both allocated in the SFR area. After reset (by RES signal input, BRK instruction execution, or op code trap), their contents are undefined.





• LRBL's 8 bits specify 2KB (0200H-09FFH) of data memory space (the X values are included in the instruction code) in units of 8 bytes.



• LRBH's 8 bits specify 64KB of data memory space in units of 256 bytes.



- Bit 2: System Control Base 2 (SCB2)
- Bit 1: System Control Base 1 (SCB1)
- Bit 0: System Control Base 0 (SCB0)

The System Control Base specifies the Pointing Register (PR) set allocated in the fixed page area.

|   | SCB | SCB Pointing Register Set |                        |  |
|---|-----|---------------------------|------------------------|--|
| 2 | 1   | 0                         | Folliting Register Set |  |
| 0 | 0   | 0                         | PR0 (0200H-0207H)      |  |
| 0 | 0   | 1                         | PR1 (0208H-020FH)      |  |
| 0 | 1   | 0                         | PR2 (0210H-0217H)      |  |
| 0 | 1   | 1                         | PR3 (0218H-021FH)      |  |
| 1 | 0   | 0                         | PR4 (0220H-0227H)      |  |
| 1 | 0   | 1                         | PR5 (0228H-022FH)      |  |
| 1 | 1   | 0                         | PR6 (0230H-0237H)      |  |
| 1 | 1   | 1                         | PR7 (0238H-023FH)      |  |

(4) System Stack Pointer (SSP)

The System Stack Pointer is a 16-bit register that points to the address of the stack for saving and restoring PC and register values when interrupts are processed and call, push, return, and pop instructions are executed. SSP is automatically incremented or decremented by instruction execution.

Saving and restoring to the stack address pointed to by SSP is performed with words, so the least significant bit (LSB) of SSP is "0".

The SFR area and expanded SFR area cannot be used as the stack.

The SSP (00H) is allocated in the SFR. After reset (by RES signal input, BRK instruction execution, or op code trap), its value will be FFFFH.

#### 3.2.3 Pointing Register (PR)

There are eight PR sets. Each set consists of four 16-bit registers.

- Index Register 1 (X1)
- Index Register 2 (X2)
- Data Pointer (DP)
- User Stack Pointer (USP)

PR sets are allocated to 0200H-023FH in the internal RAM area. One of the eight sets will be selected by the SCB0-2 bits in PSWL.

If the PR functions are not used, then area for PR sets can be used as normal internal RAM.

X1, X2, DP, and USP have their even address in the low-order 8 bits and odd address in the low-order 8 bits.



#### 3.2.4 Local Registers (R, ER)

R is an 8-bit register, and ER is a 16-bit register. Local Registers R and ER specify 2KB of Data Memory Space from 0200H to 09FFH in 8-byte units by low 8-bit LRBL. The one of the 8 bytes can be accessed by specifying 3-bit data embedded in a local register operation instruction (for ER, two of the 8 bytes can be accessed by specifying 2-bit data embedded in a local register operation).



#### 3.2.5 Segment Registers

The segments registers are three 8-bit registers: Code Segment Register (CSR), Table Segment Register (TSR), and Data Segment Register (DSR). They select segments in program memory space.

However, only segments 0-15 exist in program memory space, so only bits 3-0 are valid. Bits 7-4 are always 0.

(1) Code Segment Register (CSR)



CSR specifies the segment in program memory space which contains the program code currently being executed. CSR is an independent 8-bit register; it is not allocated as an SFR. CSR may be written by FJ, FCAL, VCAL, FRT, and RTI instructions, as well as interrupts. There is no other way to write to CSR. <u>Be sure that the destination address of an FJ or FCAL instruction is within segment 0-15.</u>

Offset addresses 0-0FFFFH are assigned within each segment. Address calculations that determine an addressing object are performed on 16-bit offset addresses, with any overflows and underflows ignored. Similarly, if the PC overflows, CSR will not change. Therefore, unless CSR is written using one of the above methods, program execution will not proceed beyond code segment boundaries. After reset the value of CSR is 00H.

When program memory space has been expanded to 1MB and an interrupt occurs, the current CSR and PC values will both be saved automatically on the stack. The saved values will be restored by execution of an RTI instruction. (Refer to Section 3.1.1, "Memory Space Expansion.")

(2) Table Segment Register (TSR)



TSR specifies the segment in program memory space which contains table data. TSR is an 8-bit register allocated in SFR space. However, TSR is rewritable, only when MEMSCON bit 1 (LROM) is set to ("1"). TSR can be written by instructions that have SFR addressing. Data in the table segment can be accessed using ROM reference instructions (LC, LCB, CMPC, CMPCB). By using the ROM window function, RAM addressing can be used for the table segment.

Bits 3-0 of TSR are valid. When read, bits 7-4 will be "0". Always write 0 to bits 7-4.

Offset addresses 0-0FFFFH are assigned within each segment. Address calculations that determine an addressing object are performed on 16-bit offset addresses, with any overflows and underflows ignored. Therefore, TSR will not be changed by these operations. After reset the value of TSR is 00H.

(3) Data Segment Register (DSR)

|             | 7   | 6   | 5   | 4   | 3 | 2 | 1 | 0 |  |
|-------------|-----|-----|-----|-----|---|---|---|---|--|
| DSR         | "0" | "0" | "0" | "0" |   |   |   |   |  |
| Reset state | 0   | 0   | 0   | 0   | 0 | 0 | 0 | 0 |  |

DSR specifies the segment in data memory space which contains data currently being used. DSR is an 8-bit register allocated in SFR space. DSR can be written by instructions that have SFR addressing. However, DSR is rewritable, only when MEMSCON bit 0 (LRAM) is set to ("1").

Bits 3-0 of DSR are valid. When read, bits 7-4 will be "0". Always write "0" to bits 7-4.

#### 3.3 Addressing Modes

There are two independent memory spaces: data memory space and program memory space. Addressing modes are classified into two categories corresponding to each memory space.

Data memory space consists of memory that can be read and written (RAM), so it is also called RAM space. Addressing for this space is called RAM addressing.

Program memory space consists of read-only memory (ROM), so it is also called ROM space. Addressing for this space is called ROM addressing.

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

There is also a special addressing called ROM window addressing. It allows table data to be accessed in ROM space using RAM addressing. This is a mode for reading data in the table segment through a data segment window opened by program specification.

#### 3.3.1 RAM Addressing

RAM addressing modes specify addressing of program variables in RAM space. Addressing modes provided are register addressing, page addressing, direct data addressing, pointing register indirect addressing, and special bit area addressing.

#### (1) Register Addressing

- A. Accumulator Addressing
- B. Control Register Addressing
- C. Pointing Register Addressing
- D. Local Register Addressing
- A. Accumulator Addressing

A PSW, LRB, SSP X1, X2, DP, USP ERn, Rn

3

Word instructions access the accumulator contents (A). Byte instructions access the low byte of the accumulator (AL).

#### [Word]

| L<br>ST             | <u>A,</u> #1234H<br><u>A</u> , VAR   |
|---------------------|--------------------------------------|
| [Byte]<br>LB<br>STB | <u>A,</u> #12H<br><u>A</u> , VAR     |
| [Bit]<br>MB<br>JBS  | C, <u>A</u> .3<br><u>A</u> .3, LABEL |

B. Control Register Addressing

Register contents are 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]

| FILL                   | <u>SSP</u>          |
|------------------------|---------------------|
| MOV                    | <u>LRB</u> , #401H  |
| CLR                    | <u>PSW</u>          |
| [Byte]<br>CLRB<br>INCB | <u>PSWH</u><br>PSWL |

[Bit]

MB <u>C</u>, BITVAR

C. Pointing Register Addressing

Pointing register contents are accessed. Pointing registers are provided with eight sets of registers (PR0-PR7: every 8-byte in memory 200H-23FH), but the set addressed in this mode is specified by the System Control Base (SCB) field in PSW.

X1: Index Register 1 X2: Index Register 2 DP: Data Pointer USP: **User Stack Pointer** X1L: Index Register 1 Low byte X2L: Index Register 2 Low byte DPL: Data Pointer Low byte DP\*: Data Pointer Low byte USPL: User Stack Pointer Low byte

\* Used only for "JRNZ DP, radr" instruction provided for nX-8/100-400 compatibility.

| [Word]<br>L<br>ST<br>MOV<br>CLR | A, <u>X1</u><br>A, <u>X2</u><br><u>DP</u> , #2000H<br><u>USP</u> |
|---------------------------------|------------------------------------------------------------------|
| [Byte]<br>DJNZ                  | X1L, LOOP                                                        |

|      | <u>MIE</u> , 2001 |
|------|-------------------|
| DJNZ | <u>X2L,</u> LOOP  |
| DJNZ | <u>DPL,</u> LOOP  |
| DJNZ | <u>USPL,</u> LOOP |
| JRNZ | DP, LOOP          |

D. Local Register Addressing

Local register contents are accessed. Local registers are 256 8-byte sets of registers (in memory 200H-9FFH), but the set addressed in this mode is specified by the Local Register Base (LCB) low byte.

ER0-ER3:Expanded Local Registers R0-R7: Local Registers [Word] L A, <u>ER0</u> MOV ER2, ER1 CLR ER3 [Byte] LB A, <u>R0</u> ADDB <u>R1,</u> A R2, #12H CMPB INCB R3 ROR R4 MOVB <u>R5, R6</u> [Bit] SB R0.0 RB R1.7 JBRS R7.3, LABEL

(2) Page Addressing

A. SFR Page Addressing B. FIXED Page Addressing

C. Current Page Addressing

sfr Dadr fix Dadr off Dadr

#### A. SFR Page Addressing

SFR page addressing specifies an offset in the SFR page (data memory 0-0FFH) with one byte of instruction code. Word, byte, or bit data can be accessed at the specified address.

The operand is coded with the "sfr" addressing specifier. The "sfr" can be omitted, but then SFR page addressing will only be used when the assembler recognizes that an address is in the SFR page.

An address symbol is provided for every SFR. Normally these symbols are used for SFR accesses.



If an odd address is specified, then the word data starting at the next lower even address will be accessed (see "word boundary"). However, there are exceptions depending on the SFR.



#### B. FIXED Page Addressing

FIXED page addressing specifies an offset in the FIXED page (data memory 200H-2FFH) with one byte of instruction code. Word, byte, or bit data can be accessed at the specified address.

The operand is coded with the "fix" addressing specifier. The "fix" can be omitted, but then fixed page addressing will only be used when the assembler recognizes that an address is in the FIXED page.



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



#### C. Current Page Addressing

Current page addressing specifies an offset in the current page (one of 256 pages in data memory specified by LRBH) with one byte of instruction code. Word, byte, or bit data can be accessed at the specified address.

02FFH

.....

The operand is coded with the "off" addressing specifier. The "off" can be replaced by "¥", but this will have a slightly different meaning when bit data in the SBA area is accessed (see "sbaoff Badr").



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



#### (3) Direct Data Addressing

Direct page addressing specifies an address in the current physical segment of data memory(address 0-0FFFFH: 64KB) with two bytes of instruction code. Word, byte, or bit data can be accessed at the specified address.

**xxFFH** 

**+≻** I 1.1

111111

Current page

The operand is coded with the "dir" addressing specifier. The "dir" can be omitted, but then if an address in the SFR page or FIXED page is specified then the assembler may interpret it as SFR page addressing or FIXED page addressing.



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



#### (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

DP/X1 indirect addressing specifies an address in the current physical segment (address 0-0FFFFH: 64KB) by the contents of a pointing register. Word, byte, or bit data can be accessed at the specified address.

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

[Word]



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



B. DP Indirect Addressing With Post-Increment

DP indirect addressing with post-increment specifies an address in the current physical segment (address 0-0FFFH: 64KB) by the contents of a pointing register. Word, byte, or bit data can be accessed at the specified address.

After access, the pointing register contents will be incremented. The increment will be 2 for word instructions and 1 for byte and bit instructions.

This mode is primarily used to access consecutive array elements.

[DP+]: DP indirect addressing with post-increment

[Word]



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



3 - 33

C. DP Indirect Addressing With Post-Decrement

DP indirect addressing with post-decrement specifies an address in the current physical segment of data memory(address 0-0FFFFH: 64KB) by the contents of a pointing register. Word, byte, or bit data can be accessed at the specified address.

After access, the pointing register contents will be decremented. The decrement will be 2 for word instructions and 1 for byte and bit instructions.

This mode is primarily used to access consecutive array elements.

[DP-]: DP indirect addressing with post-decrement

[Word]



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



D. DP/USP Indirect Addressing With 7-Bit Displacement

DP/USP indirect addressing with 7-bit displacement specifies an address in the current physical segment (address 0-0FFFFH: 64KB) using the contents of a pointing register as a base and adding a 7-bit displacement with sign embedded in instruction code (bits 6-0). The range –64 to +63 bytes around the pointing register value can be accessed. Word, byte, or bit data can be accessed at the specified address.

*numeric\_expression*[DP] : DP indirect addressing with 7-bit displacement *numeric\_expression*[USP] : USP indirect addressing with 7-bit displacement

The *numeric\_expression* is a value in the range -64 to +63. DP and USP can be used as the pointing register.

[Word]



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



E. X1/X2 Indirect Addressing With 16-Bit Base

X1/X2 indirect addressing with 16-bit base specifies a 2-byte (D16) base embedded in instruction code and adds it to the contents of an index register (X1 or X2) to obtain an address in the current physical segment (address 0-0FFFH: 64KB). Word (16-bit) calculations are used to generate the address, with overflows ignored. Therefore the generated address will be 0-0FFFFH. Word, byte, or bit data can be accessed at the specified address.

address\_expression[X1]: X1 indirect addressing with 16-bit base address\_expression[X2]: X2 indirect addressing with 16-bit base

The *address\_expression* is a value in the range 0-0FFFFH. However, the assembler allows a value in the range of -8000H to +0FFFFH. That is, D16 can also be thought of as a displacement instead of a base address.





If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]



[Bit]



F. X1 Indirect Addressing With 8-Bit Register Displacement

X1 indirect addressing with 8-bit register displacement specifies an address in the current physical segment (address 0-0FFFFH: 64KB) using the contents of a pointing register as a base and the contents of the Accumulator low byte (AL) or Local Register 0 (R0). Word (16-bit) calculations are used to generate the address. The 8-bit displacement obtained from the register will be extended without sign, and overflow will be ignored so the generated address will be 0-0FFFFH. Word, byte, or bit data can be accessed at the specified address.

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

[Word]



If an odd address is specified, then the word data starting at the next lower even address will be accessed.

[Byte]





3

- (5) Special Bit Area Addressing
  - A. FIXED page SBA area addressing
  - B. Current page SBA area addressing

A. FIXED page SBA area addressing

FIXED page SBA area addressing specifies a bit address in the FIXED page's 512-bit SBA area (2C0H.0-2FFH.7). Only bit data can be accessed at the specified address.

The instructions that can use this addressing are SB, RB, JBS, and JBR.

[Bit]

| SBsbafix 2C0H.0RBsbafix 1600HJBSsbafix VAR,LABELJBRsbafix 2EFH.7                         |                                                                              |
|------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|
| SB <u>2C0H.0</u><br>RB <u>1600H</u><br>JBS <u>VAR</u> ,LABEL<br>JBR <u>2EFH.3</u> ,LABEL | RAM         02C0H         02xxH         IIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIIII |

sbafix Badr sbaoff Badr

3

B. Current page SBA area addressing

Current page SBA area addressing specifies a bit address in the current page's 512-bit SBA area (xxC0H.0-xxFFH.7). Only bit data can be accessed at the specified address.

The instructions that can use this addressing are SB, RB, JBS, and JBR.

[Bit]

- SB sbaoff 4C0H.0
- RB sbaoff 2E80H
- JBS sbaoff VAR, LABEL
- JBR sbaoff OFFFFH.3,LABEL



### 3.3.2 ROM Addressing

ROM addressing specifies addressing of program variables in ROM space. The modes provided are immediate addressing, table data addressing, and program code addressing.

(1) Immediate Addressing

Immediate addressing specifies access of immediate data embedded in instruction code. For words, two bytes (N16) in instruction code will be accessed. For bytes, one byte (N8) in instruction code will be accessed.

Word values are expressions in the range 0-0FFFFH. Byte values are expressions in the range 0-0FFH. However, the assembler permits values in the range covered by both signed and unsigned expressions. For words that range is from -8000H to +0FFFFH, and for bytes it is from -80H to +0FFFH.

[Word]

| L   | A, <u>#1234H</u>            |
|-----|-----------------------------|
| MOV | X1, <u>#WORD_ARRAY_BASE</u> |
|     |                             |

[Byte] LB A, <u>#12H</u> MOV X1, <u>#BYTE ARRAY BASE</u>

(2) Table Data Addressing

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

| A. Direct Table Addressing                  | Tadr    |
|---------------------------------------------|---------|
| B. RAM Indirect Table Addressing            | [**]    |
| C. RAM Indirect Addressing With 16-Bit Base | T16[**] |

A. Direct Table Addressing

Direct table addressing specifies an address (0-0FFFFH: 64KB) in the table segment specified by TSR with two bytes of instruction code. Word or byte data can be accessed at the specified address.

This addressing can be used with the four instructions LC, LCB, CMPC, and CMPCB.

| [Word]<br>LC<br>CMPC   | A, <u>VAR</u><br>A, <u>VAR</u> |
|------------------------|--------------------------------|
| [Byte]<br>LCB<br>CMPCB | A, <u>VAR</u><br>A, <u>VAR</u> |

B. RAM Indirect Table Addressing

RAM indirect table addressing uses the word data specified by RAM addressing as a pointer to the table segment specified by TSR. Table memory can be accessed by using a register or data memory as a pointer into the table memory.

This addressing can be used with the four instructions LC, LCB, CMPC, and CMPCB.

[Word] LC A, [A] CMPC A, [1234[X1]] [Byte] LCB A, [ER0] CMPCB A, [VAR]

C. RAM Indirect Addressing With 16-Bit Base

RAM indirect addressing with 16-bit base specifies two bytes (D16) in instruction code as a base and adds it to the contents of word data specified by RAM addressing to obtain an address (0-0FFFFH: 64KB) in the table segment specified by TSR. Word (16-bit) calculations are used to generate the address, with overflows ignored. Therefore the generated address will be 0-0FFFFH. Word or byte data can be accessed at the specified address.

This mode can be used with operands of LC, LCB, CMPC, and CMPCB instructions.

[Word] LC A, <u>2000H [A]</u> CMPC A, <u>2000H [1234[X1]]</u>

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

### (3) Program Code Addressing

Program code addressing specifies access of the current program code in ROM space. These modes are used as operands of branch instructions.

| A. Near Code Addressing         | Cadr   |
|---------------------------------|--------|
| B. Far Code Addressing          | Fadr   |
| C. Relative Code Addressing     | radr   |
| D. ACAL Code Addressing         | Cadr[] |
| E. VCAL Code Addressing         | Vadr   |
| F. RAM Indirect Code Addressing | [**]   |

A. Near Code Addressing

Near code addressing specifies an address (0-0FFFFH: 64KB) in the current code segment with two bytes of instruction code. This addressing can be used with J and CAL instructions.

[Usage Example] J <u>3000H</u> CAL <u>LABEL</u>

B. Far Code Addressing

Far code addressing specifies an address (0:0-F:0FFFH: 1MB) in program memory space with three bytes of instruction code. This addressing can be used with FJ and FCAL instructions.

[Usage Example] FJ <u>1:3000H</u> FCAL <u>FARLABEL</u>

C. Relative Code Addressing

Relative code addressing takes the current program counter (PC) value as a base and adds it to an 8-bit or sign-extended 7-bit value in instruction code to obtain an address (0-0FFFH: 64KB) in the current code segment. Word (16-bit) calculations are used to generate the address, with overflows ignored. Therefore the generated address will be 0-0FFFFH. This addressing can be used with SJ and conditional branch instructions.

[Usage Example]SJLABELDJNZR0, LABELJCLT, LABEL

D. ACAL Code Addressing

ACAL code addressing specifies an address in the ACAL area (1000H-17FFH: 2KB) in the current code segment with 11 bits of instruction code. This addressing can be used only with ACAL instructions.

[Usage Example] ACAL <u>1000H</u> ACAL <u>ACALLABEL</u>

E. VCAL Code Addressing

VCAL code addressing specifies an entry (word data) in the vector table for VCAL instructions with 4 bits of instruction code. The vector table is located at even addresses in the range 004AH-0069H. This addressing can be used only with VCAL instructions.

[Usage Example]VCAL4AHVCAL0:4AHVCALVECTOR

F. RAM Indirect Code Addressing

RAM indirect code addressing uses word data specified by RAM addressing as a pointer to the code segment. It allows indirect jumps and calls using a register or data memory as a pointer to code memory. This addressing can be used with J and CAL instructions.

[Usage Example] J [A] CAL [1234[X1]]

(4) ROM Window Addressing

ROM window addressing accesses table data in ROM space using RAM addressing. This mode reads data in the table segment specified by TSR using data segment window opened by the program.

Data memory addressing is permitted in the ROM window area, but results are not guaranteed if an instruction that writes to the ROM window is executed.

## Chapter 4

4

## **CPU Control Functions**

4

### 4. CPU Control Functions

There are two CPU control functions.

- Standby function
- Reset function

### 4.1 Standby Function

There are two operating modes of the standby function.

- HALT mode: clock supplied to the CPU is stopped by software
- STOP mode: oscillation clock supply is stopped by software

The modes are set by the following hardware.

- Stop Code Acceptor (STPACP: for STOP mode)
- Standby Control Register (SBYCON: for HALT and STOP modes)

Table 4-1 shows the standby modes and the states of the output pins in each.

|                             | Standby Mode                    | HALT Mode                                            | STOP                                                                   | Mode (note 1)                                                            |
|-----------------------------|---------------------------------|------------------------------------------------------|------------------------------------------------------------------------|--------------------------------------------------------------------------|
| Set condition               |                                 | • SBYCON bit 1<br>(HLT) set.                         | • SBYCON bit 0 (STP)<br>set when bit 2 (FLT)<br>is in set state ("1"). | • SBYCON bit 0 (STP) set<br>when bit 2 (FLT) is in<br>reset state ("0"). |
|                             | Release condition               | <ul> <li>Interrupt</li> <li>RES pin input</li> </ul> | Interrupt (note 6) <del>RES</del> pin input                            |                                                                          |
|                             | PO                              | Unchanged                                            | (note 4)<br>High impedance                                             | (note 2)                                                                 |
| SS                          | P1, P4, P9, P10 Unchanged       |                                                      | or<br>Pull-up                                                          | Unchanged                                                                |
| Output Pin States           | P2, P6, P7_2-P7_7, P8, P12      | Unchanged                                            | High impedance                                                         | Unchanged                                                                |
| Pin                         | P5_4, P5_5 (primary function)   | Unchanged                                            | High impedance                                                         | Unchanged                                                                |
| Itput                       | P5_4 (secondary function)       | High level                                           | High impedance                                                         | High level                                                               |
| ō                           | P5_5 (secondary function)       | Low level                                            | High impedance                                                         | Low level                                                                |
|                             | P7_0, P7_1 (primary function)   | Unchanged                                            | High impedance                                                         | Unchanged                                                                |
|                             | P7_0, P7_1 (secondary function) | High level (pull-up)                                 | High level (pull-up) (note 5)                                          | High level (pull-up)                                                     |
| uo                          | TBC                             | Operating                                            | Stopped                                                                |                                                                          |
| erati                       | 16-bit RTO/PWM timer            | Operating                                            | Stopped                                                                |                                                                          |
| n Op                        | GTMC                            | Operating                                            | Operating if external clock selected (note 3)                          |                                                                          |
| Internal Function Operation | S1TM Operating                  |                                                      | Stopped                                                                |                                                                          |
| I Fur                       | SCI1                            | Operating                                            | Stopped                                                                |                                                                          |
| erna                        | ADC                             | Operating                                            | Stopped                                                                |                                                                          |
| Int                         | PWM                             | Operating                                            | Stopped                                                                |                                                                          |

### Table 4-1 Standby Modes

Notes: 1. The set condition for STOP mode is that the Stop Code Acceptor (STPACP) already be set ("1").

2. P0 will be high impedance in external ROM mode, or unchanged in internal ROM mode.

3. Edge specification is disabled, so the falling edge will be assumed.

4. Pins specified to pull-up will be kept in pull-up state regardless of the mode.

5. ICE output is high impedance, so it differs from the device operation(MASK version, OTP version, etc.).

6. The edge specification for external interrupts (INT0-INT3) is disabled and the "L" level is enabled.

### 4.1.1 Standby Control Register (SBYCON)

SBYCON is a 5-bit register that controls standby functions. Also, the Stop Code Acceptor (STPACP) is an acceptor used to set STOP mode.

Figure 4-1 shows the configuration of SBYCON.

|             | 7 | 6 | 5    | 4    | 3 | 2   | 1   | 0   | address : 000F[H] |
|-------------|---|---|------|------|---|-----|-----|-----|-------------------|
| SBYCON      | — |   | OST1 | OST0 |   | FLT | HLT | STP | R/W access : R/W  |
| Reset state | 1 | 1 | 0    | 0    | 1 | 0   | 0   | 0   |                   |

- indicates a non-existent bit. These will read as "1".

### Figure 4-1 SBYCON Configuration

• STP (bit 0)

Writing n5H and nAH (n = 0-F) consecutively to STPACP will set ("1") the stop code acceptor. Setting ("1") the STP bit of SBYCON at that point will set the device in STOP mode. STP will be reset (0) when an interrupt or reset from  $\overline{\text{RES}}$  pin input occurs, releasing STOP mode. For details refer to Section 4.1.2 (2), "STOP Mode." STPACP will be reset ("0") at the same time STOP mode is entered.

• HLT (bit 1)

Setting ("1") the HLT (bit 1) of SBYCON will set the device in HALT mode. HLT will be reset ("0") when an interrupt or reset from  $\overline{\text{RES}}$  pin input occurs, releasing halt mode. For details refer to Section 4.1.2 (1), "HALT Mode."

• FLT (bit 2)

If STOP mode is entered when the FLT bit of SBYCON is set ("1"), then ports, control signals, and all other output pins will enter a high impedance state. (However, some output pins may change their states by programmable pull-up settings/ secondary function setting. Refer to Table 4-1 Standby Modes.)

At this time, the internal circuits of the high-impedance pins will activate a circuit that prevents internal stray current even if the pins are left open. However, for the purpose of STOP mode release condition, the stray current prevention circuit will not operate for pins like external interrupts (INT0-INT3) and the event timer clock input pin (ETMCK). These pins need to be fixed to a high or low level when the FLT bit of SBYCON is set ("1") to enter STOP mode.

When the above pins are used as their primary function (I/O ports), the stray current prevention circuit will operate, so they have no need to be fixed at a logic level.

If STOP mode is entered when the FLT bit of SBYCON is reset ("0"), then ports, control signals, and other output pins will maintain their state at that time.

Pins in input mode should be fixed to a high or low level regardless of the FLT bit content.

• OST0 (bit 4), OST1 (bit 5)

The OST0 and OST1 bits of SBYCON set the time after STOP mode is released by an interrupt and the oscillation clock starts oscillating until the clock is supplied to the CPU.

| OST1 | OST0 | Selected Clock Cycles |
|------|------|-----------------------|
| 0    | 0    | 32768                 |
| 0    | 1    | 16384                 |
| 1    | 0    | 8192                  |
| 1    | 1    | Setting prohibited    |

Note: Do not set OST1, 0 to "1" simultaneously.

### 4.1.2 Operation in Standby Modes

(1) HALT Mode

When HLT (bit 1) of SBYCON is set ("1"), the device will enter HALT mode. In HALT mode the oscillation clock operates, so TBC, timers, the serial ports, etc. will operate as well. However, the clock supplied to the CPU will stop, so instructions will not be executed. Execution will stop at the start of the instruction following the one that set ("1") HLT.

HALT mode will be released when either an interrupt or reset by RES input occurs.

When a non-maskable interrupt occurs in HALT mode, HALT mode will be released unconditionally and the CPU will execute the non-maskable interrupt process.

When a maskable interrupt occurs in HALT mode, HALT mode will be released when both its Interrupt Request Flag (IRQ bit) and Interrupt Enable Flag (IE) are set ("1").

If the Master Interrupt Enable Flag (MIE of the PSW) has been set ("1"), then after HALT mode is released the CPU will execute the maskable interrupt process for the interrupt. If it has been reset ("0"), then the CPU will start execution at the instruction after the instruction that set HALT mode (set the HLT bit of SBYCON).

If interrupt priority has been set (MIP = 1) and HALT mode is entered from within a high-priority interrupt routine, then HALT mode can be released by interrupt requests of lower priority but the lower priority interrupt process will not be executed even though MIE is 1. Instead the CPU will start execution at the instruction after the instruction that set HALT mode.

When HALT mode is released by RES pin input, the CPU will perform reset processing.

(2) STOP Mode

The device will enter STOP mode when n5H followed by nAH (n = 0-FH) are written to STPACP to set (1) the Stop Code Acceptor, and then STP (bit 0) of SBYCON is set (1). The Stop Code Acceptor will be reset (0) at the same time stop mode is entered.

STOP mode stops the oscillation clock, so TBC, timers, the serial port, etc. will also stop. However, the general 8-bit timer (GTMC) will operate if an external clock has been selected. The valid edge specification for the external clock will be disabled, so it will operate on the falling edge.

The clock supply to the CPU will also stop, so instructions will not be executed. Execution will stop at the instruction after the instruction that set ("1") STP (bit 0) in SBYCON.

STOP mode will be released when either an interrupt or reset by RES input occurs. The edge specification for external interrupts (INT0-INT3) is disabled and the "L" level is enabled.

When a non-maskable interrupt occurs in STOP mode, STOP mode will be released unconditionally and the CPU will execute the non-maskable interrupt process.

When a maskable interrupt occurs in STOP mode, STOP mode will be released when both its Interrupt Request Flag (IRQ bit) and Interrupt Enable Flag (IE) are set ("1").

If the Master Interrupt Enable Flag (MIE of the PSW) has been set ("1"), then after STOP mode is released the CPU will execute the maskable interrupt process for the interrupt. If it has been reset ("0"), then the CPU will start execution at the instruction after the instruction that set STOP mode (set the STP bit of SBYCON).

If STOP mode is set during an NMI routine and then released by an interrupt, execution after release will start at the instruction after the instruction that set STOP mode. Also, if interrupt priority has been set (MIP = 1) and STOP mode is entered from within a high-priority interrupt routine, then STOP mode can be released by interrupt requests of lower priority but the lower priority interrupt process will not be executed even though MIE is 1. Instead the CPU will start execution at the instruction after the instruction that set STOP mode.

Figure 4-2 shows STOP mode timing.

When STOP mode is released by RES pin input, the CPU will perform its reset processing. When releasing by RES pin input, apply a low level on the RES pin until the oscillation clock is stable.



\* The oscillation stabilization time is the time until the oscillation clock begins oscillating, and the time set by OST0 and OST1 as a number of clock cycles.

### Figure 4-2 STOP Mode Timing Diagram (Release By Interrupt)

### 4.2 Reset Function

There are three ways to reset the device.

- Input a low level on the RES pin
- Execute a BRK (break) instruction
- Generate an OPTRP (op code trap)

These three methods are identical in all ways except that the location of the vector address loaded into the Program Counter during reset processing will be different.

Reset processing initializes calculation registers, control registers, and mode registers. It also loads the contents of the location indicated by the vector address into the Program Counter.

See Chapter 21, "Special Function Registers (SFRs)," for the initial states of registers. See Table 3-1, "Vector Table," for the vector address corresponding to each reset type.

When resetting by RES pin input, apply a low level on the RES pin until the oscillation clock is stable.

Reset processing has priority over all other processing (interrupt processes and instruction execution). It will abort all processes, and will not preserve register or RAM contents.

Figure 4-3 shows an example of the reset pin connection. Table 4-2 shows the reset state of output pins.

4



SW and R are for manual reset.

#### Figure 4-3 Reset Pin Connection Example

#### Table 4-2 Reset State of Output Pins

| Name  | PO             | P1             | P2, P4, P6-P10, P12 | P5_4, P5_5<br>EA pin at high level |
|-------|----------------|----------------|---------------------|------------------------------------|
| State | High impedance | High impedance | High impedance      | High impedance                     |

Note: If the EA pin is low and external program memory is selected, then P0, P1, P5\_4, P5\_5, and P9\_0-P9\_3 will automatically take their secondary functions and enter an operating state.

### Chapter 5

# Memory Control Functions

5

### 5. Memory Control Functions

There are two independent memory spaces, program memory space and data memory space. Several functions are provided to make using these spaces easier. One is the ROM window function, which allows the many instructions provided for data memory space to be used for program memory space.

Another is the ready function, which inserts wait cycles in external memory timing under software control so access times match the external memory being used in either memory space.

One more is the wait function, which can insert wait cycles under the control of an external device.

### 5.1 ROM Window Function

The ROM window function reads the contents of program memory specified by the ROM Window Control Register (ROMWIN) in the SFR area through a data memory space window at the same address.

In other words, when the ROM window function is enabled and an instruction that accesses (reads) data memory space is executed, the data in data memory space will not be accessed (read), <u>but</u> instead the data at the same address in program memory space in the segment specified by the <u>TSR will be accessed (read)</u>.

For each access (read), the number of instruction execution cycles will increase by three cycles for byte instructions and by six cycles for word instructions.

Results are not guaranteed if an instruction that performs a write operation is executed while the ROM window function is enabled. The number of cycles will not increase, though.

ROMWIN is an 8-bit register, the lower 4 bits specifying the ROM window start address, and the upper 4 bits specifying the ROM window end address. Both specify the most significant hexadecimal digit of the four digits needed to fully address 64KB of program memory space. However, if the lower 4 bits are all zeroes, then the ROM window function will not operate.

If internal RAM is located in the data memory area specified as the ROM window, then the data memory internal RAM will take precedence. (This does not apply to the MSM66587 family.)

External data memory cannot be allocated to the data memory area specified as the ROM window. Figure 5-1 shows the configuration of ROMWIN.



### Figure 5-1 ROMWIN Configuration

After reset (by RES signal input, BRK instruction execution, or op code trap), ROMWIN will be 00H, disabling the ROM window function.

ROMWIN may be written only one time after reset. Second and later writes will be ignored. Therefore after the ROM window function has been set once, it can be changed only after another reset. ROMWIN can be read any number of times.

Note: The device hardware does not compare the start address X and end address Y written to ROMWIN, so your program should ensure that  $X \le Y$ .

### 5.2 READY Function

The READY function allows memory and general ICs with slow access speeds to be connected externally by specifying that wait cycles are to be inserted in external memory accesses (RAM: 0-7 cycles, ROM: 0-3 cycles). The number of wait cycles is specified by the RAM Ready Control Register (RAMRDY) and ROM Ready Control Register (ROMRDY).

RAMRDY specifies the wait cycles when data memory space has been expanded externally. The wait cycles can be set, equally for all segments, in two areas of the offset addresses 0H-7FFFH (0A00H-7FFFH for segment 0) and 8000H-FFFFH.

ROMRDY specifies the wait cycles when program memory space is used with external ROM mode.

RAMRDY and ROMRDY can be read and written by the program. However, RAMRDY bit 7 and bit 3 will not be affected by write operations. These bits will always read as "1".

The lower 2 bits of ROMRDY are valid for write operations, but the upper 6 bits will not be affected. The lower 2 bits will read correctly, but the upper 6 bits will always read as "1".

5

Figure 5-2 shows the configuration of RAMRDY, and Figure 5-3 shows that of ROMRDY.

After reset (by RES signal input, BRK instruction execution, or op code trap), RAMRDY and ROMRDY will both be FFH, inserting 7 wait cycles when external data memory is accessed and 3 cycles when external program memory is accessed.

- Notes: 1. Compared to internal program memory accesses, external program memory accesses have one cycle inserted automatically for each byte accessed. The ROMRDY register specifies the number of cycles inserted in addition to one cycle inserted automatically.
  - Compared to internal data memory accesses, external data memory accesses <u>have 3</u> or 4 cycles inserted automatically for each byte accessed. The RAMRDY register <u>specifies the number of cycles inserted in addition</u> to 3 or 4 cycles inserted automatically.



It will read as "1".

1 cycle consists of 1 CLK.





1 cycle consists of 1 CLK.

### Figure 5-3 ROMRDY Configuration

### 5.3 WAIT Function

In addition to the READY function, which inserts wait cycles under CPU control, there is also a WAIT function, which can insert wait cycles under control of an external device.

More specifically, pin P7\_2 (must be set to secondary function) is sampled on the falling edges of the internal clock, as shown in Figure 5-4. If its level is high, then wait cycles will be inserted into the  $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  strobes.

As shown in the sample timing of Figure 5-4, the wait cycles are released when pin P7\_2 has been sampled at a low level twice and 1 tow.

When the WAIT function is used together with the READY function, the longer wait time will be effective (this only applies to data memory space accesses).



Figure 5-4 Sample Timing When WAIT Function is Used

### **Chapter 6**

## Port Functions

### 6. Port Functions

The MSM66587 family provides nine 8-bit, one 2-bit, and one 6-bit input/output port. Each bit of an input/output port can be specified individually.

Pins are high-impedance when inputs, and push-pull when outputs. Each port not only has port functions, but also is assigned a function for internal operation (secondary function). The bits of some ports can also be programmed individually for internal pull-up.

Table 6-1 lists the port functions.

| Port    | Pin          | Туре | No. | Pull-up   | Secondary Function                               |
|---------|--------------|------|-----|-----------|--------------------------------------------------|
| Port 0  | P0_0-P0_7    | Α    | 8   | Available | External memory access: AD0-AD7 (I/O)            |
| Port 1  | P1_0-P1_7    | В    | 8   | Available | External memory access: A8-A15 (0)               |
| Port 2  | P2_0-P2_3    | E    | 4   | None      | None                                             |
|         | P2_4, P2_5   | С    | 2   | None      | Flexible RTO output: RT08, RT09 (0)              |
|         | P2_6, P2_7   | E    | 2   | None      | None                                             |
| Port 4  | P4_0         | В    | 1   | Available | Event timer external clock: ETMCK (I)            |
|         | P4_1-P4_7    | D    | 7   | Available | None                                             |
| Port 5  | P5_4         | С    | 1   | None      | External memory access: PSEN (0)                 |
|         | P5_5         | C    | 1   | None      | External memory access: ALE (0)                  |
| Port 6  | P6_0, P6_1   | С    | 2   | None      | External interrupt signal inputs: INTO, INT1 (I) |
|         | P6_2         | С    | 1   | None      | Serial Port 1 data input: RXD1 (I)               |
|         | P6_3         | С    | 1   | None      | Serial Port 1 data output: TXD1 (0)              |
|         | P6_4         | C    | 1   | None      | Shift clock for serial receive: RXC1 (I/O)       |
|         | P6_5         | C    | 1   | None      | Shift clock for serial transmit: TXC1 (I/O)      |
| Port 7  | P7_0         | C    | 1   | None      | External memory access: WR (0)                   |
|         | P7_1         | С    | 1   | None      | External memory access: RD (0)                   |
|         | P7_2         | C    | 1   | None      | Wait signal input pin: WAIT (I)                  |
|         | P7_3         | С    | 1   | None      | Clock output: CLKOUT (0)                         |
|         | P7_4         | С    | 1   | None      | PWM output: PWM0 (0)                             |
|         | P7_5-P7_7    | E    | 3   | None      | None                                             |
| Port 8  | P8_0-P8_7    | E    | 8   | None      | None                                             |
| Port 9  | P9_0-P9_3    | В    | 4   | Available | External memory access: A16-A19 (0)              |
|         | P9_4-P9_7    | D    | 4   | Available | None                                             |
| Port 10 | P10_0-P10_7  | D    | 8   | Available | None                                             |
| Port 12 | P12_0, P12_1 | E    | 2   | None      | None                                             |
|         | P12_2, P12_3 | С    | 2   | None      | External interrupt signal inputs: INT2, INT3 (I) |
|         | P12_4-P12_7  | E    | 4   | None      | None                                             |

| Table 6-1 | Port | Functions |
|-----------|------|-----------|
|-----------|------|-----------|

Type A: The secondary function of these ports is to be an address/data bus. During external memory accesses, the ports automatically switch to the secondary function. They have programmable pull-ups.

- Type B: These ports have a secondary function which is switched on by the state of each port's secondary function control register. They have programmable pull-ups.
- Type C: These ports have a secondary function which is switched on by the state of each port's secondary function control register.
- Type D: These ports do not have a secondary function. They have programmable pull-ups.
- Type E: These ports do not have a secondary function.

6.1 Port Hardware Configurations

The functions of the ports (P0, P1, P2, P4, P5, P6, P7, P8, P9, P10, P12) are classified into five types.

6.1.1 Type A (P0\_0-P0\_7) Configuration

Type A ports automatically take their secondary function during external memory accesses. They function as low address output pins and data i/o pins. They also have programmable pull-ups.

Figure 6-1 shows the Type A configuration.



Figure 6-1 Type A Configuration

### 6.1.2 Type B (P1\_0-P1\_7, P4\_0, P9\_0-P9\_3) Configuration

Type B ports take their secondary function as high address outputs during external data memory accesses if specified by the secondary function select register (PmSFn). They also have programmable pull-ups.

However, P1 and P9\_0-P9\_3 will switch to their secondary function as high address outputs automatically when the  $\overline{EA}$  pin goes low.

Figure 6-2 shows the Type B configuration.



Figure 6-2 Type B Configuration

6.1.3 Type C (P2\_4, P2\_5, P5\_4, P5\_5, P6\_0-P6-5, P7\_0-P7\_4, P12\_2, P12\_3) Configuration

Type C ports take their secondary function as output or input pins if specified by the secondary function select register (PmSFn).

However, P5\_4 and P5\_5 will switch to their secondary function automatically when the  $\overline{EA}$  pin goes low. P5\_4 outputs a strobe signal for read operations (PSEN pin). P5\_5 outputs a strobe signal for externally latching the lower 8 address bits from P0 (ALE pin). P5\_5 also functions as the ALE pin when external data memory is accessed.

Figure 6-3 shows the Type C configuration.



Figure 6-3 Type C Configuration

### 6.1.4 Type D (P4\_1-P4\_7, P9\_4-P9\_7, P10\_0-P10\_7) Configuration

Type D ports do not have a secondary function. They have programmable pull-ups.

Figure 6-4 shows the Type D configuration.



Figure 6-4 Type D Configuration

6.1.5 Type E (P2\_0-P2\_3, P2\_6, P2\_7, P7\_5-P7\_7, P8\_0-P8\_7, P12\_0, P12\_1, P12\_4-P12\_7) Configuration

Type E ports do not have a secondary function. They function as I/O pins.

Figure 6-5 shows the Type E configuration.





# 6.2 Port Control Registers

There are four types of port control registers.

- Port Data Registers (Pn: n = 0-2, 4-10, 12)
- Port Mode Registers (PnIO: n = 0-2, 4-10, 12)
- Port Secondary Control Registers (PnSF: n = 1, 2, 4-7, 9, 12)
- Port Pull-Up Control Registers (PnPUP: n = 0, 1, 4, 9, 10)

These registers are allocated as SFRs. Table 6-2 lists the port control registers.

# 6.2.1 Port Data Registers (Pn: n = 0-2, 4-10, 12)

Port Data Registers (Pn: n = 0-2, 4-10, 12) are 8-bit registers that store port output data. However, Port 5 has a 2-bit register, and Port 6 has a 6-bit register.

Pn are allocated as SFRs. After reset (by RES signal input, BRK instruction execution, op code trap) the contents of P0-P2, P4, P7-P10, and P12 will be 00H, the contents of P5, and P6 will be undefind.

When a read instruction is executed for a port, it will read the pin state ("0" or "1") if it has been specified as an input port, or it will read the contents of Pn ("0" or "1") if it has been specified as an output port. When a write instruction is executed for a port, data will be written to Pn regardless of the input/output specification.

6.2.2 Port Mode Registers (PnIO: n = 0-2, 4-10, 12)

Port Mode Registers (PnIO: n = 0-2, 4-10, 12) are 8-bit registers that specify whether ports are input or output. However, Port 5 has a 2-bit register, and Port 6 has a 6-bit register.

PnIO are allocated as SFRs. After reset (by RES signal input, BRK instruction execution, op code trap) the contents of P0IO-P2IO, P4IO, P7IO-P10IO, and P12IO will be 00H, and the contents of P5IO, and P6IO will be undefind.

When a PnIO bit is 0, the port will enter input mode. When 1, the port will enter output mode. However, if the Port Secondary Function Control Register (PnSF: n = 0-2, 4-7, 9, 12) explained next has been set to 1 to select secondary function, then the PnIO specification will be disabled.

# 6.2.3 Port Secondary Function Control Registers (PnSF: n = 1, 2, 4-7, 9, 12)

Port Secondary Function Control Registers (PnSF: n = 1, 2, 4-7, 9, 12) are 8-bit registers that specify whether ports operate as their primary or secondary function. However, Port 2 has a 2-bit register, Port 5 has a 2-bit register, Port 6 has a 6-bit register, Port 7 has a 5-bit register, Port 9 has a 4-bit register, and Port 12 has a 2-bit register.

PnSF are allocated as SFRs. After reset (by RES signal input, BRK instruction execution, op code trap) the contents of P1SF, P4SF, P6SF, P7SF, P9SF, and P12SF will be 00H, the contents of P2SF will be 80H, and the contents of P5SF will be CFH. This selects the primary function for all ports.

When a PnSF bit is "0", the port's primary function will be selected. When "1", the port's secondary function will be selected. For Port 0 the primary/secondary function select is performed automatically by hardware, so it has not Port Secondary Function Control Register.

# 6.2.4 Port Pull-Up Control Registers (PnPUP: n = 0, 1, 4, 9, 10)

Port Pull-Up Control Registers (PnPUP: n = 0, 1, 4, 9, 10) are 8-bit registers that specify whether port pull-up resistors are enabled or disabled.

PnPUP are allocated as SFRs. After reset (by RES signal input, BRK instruction execution, op code trap) the contents of PnPUP registers will be 00H, disabling the pull-up resistors of all ports.

When a PnPUP bit is 0, the pull-up resistor is disabled. When 1, the pull-up resistor is enabled.

| Address | Name                                        | Symbol (Byte) | Symbol (Word) | R/W | Reset    |
|---------|---------------------------------------------|---------------|---------------|-----|----------|
| [H]     |                                             |               |               |     | State    |
| 0010    | Port 0 Data Register                        | PO            |               |     | 00       |
| 0011    | Port 1 Data Register                        | P1            | —             |     | 00       |
| 0012    | Port 2 Data Register                        | P2            |               |     | 00       |
| 0014    | Port 4 Data Register                        | P4            | —             |     | 00       |
| 0015☆   | Port 5 Data Register                        | P5            |               |     | undefind |
| 0016☆   | Port 6 Data Register                        | P6            | —             |     | undefind |
| 0017    | Port 7 Data Register                        | P7            | —             |     | 00       |
| 0018    | Port 0 Mode Register                        | P010          | —             |     | 00       |
| 0019    | Port 1 Mode Register                        | P1I0          | —             |     | 00       |
| 001A    | Port 2 Mode Register                        | P2I0          | —             |     | 00       |
| 001C    | Port 4 Mode Register                        | P4I0          | _             |     | 00       |
| 001D☆   | Port 5 Mode Register                        | P5I0          |               |     | undefind |
| 001E☆   | Port 6 Mode Register                        | P6I0          |               |     | undefind |
| 001F    | Port 7 Mode Register                        | P7I0          | —             |     | 00       |
| 0020    | Port 8 Data Register                        | P8            | —             |     | 00       |
| 0021    | Port 9 Data Register                        | P9            | _             | R/W | 00       |
| 0022    | Port 10 Data Register                       | P10           |               |     | 00       |
| 0028    | Port 8 Mode Register                        | P8I0          | —             |     | 00       |
| 0029    | Port 9 Mode Register                        | P9I0          | —             |     | 00       |
| 002A    | Port 10 Mode Register                       | P10I0         |               |     | 00       |
| 0031    | Port 1 Secondary Function Control Register  | P1SF          |               |     | 00       |
| 0032☆   | Port 2 Secondary Function Control Register  | P2SF          | —             |     | 80       |
| 0034☆   | Port 4 Secondary Function Control Register  | P4SF          | —             |     | 00       |
| 0035☆   | Port 5 Secondary Function Control Register  | P5SF          |               |     | CF       |
| 0036☆   | Port 6 Secondary Function Control Register  | P6SF          | —             |     | 00       |
| 0037☆   | Port 7 Secondary Function Control Register  | P7SF          | —             |     | 00       |
| 0039☆   | Port 9 Secondary Function Control Register  | P9SF          | —             |     | 00       |
| 0120    | Port 12 Data Register                       | P12           |               |     | 00       |
| 0122    | Port 12 Mode Register                       | P12I0         |               |     | 00       |
| 0124☆   | Port 12 Secondary Function Control Register | P12SF         | —             |     | 00       |
| 0130    | Port 0 Pull-Up Control Register             | POPUP         | —             |     | 00       |
| 0131    | Port 1 Pull-Up Control Register             | P1PUP         | _             |     | 00       |
| 0134    | Port 4 Pull-Up Control Register             | P4PUP         | _             |     | 00       |
| 0139    | Port 9 Pull-Up Control Register             | P9PUP         |               |     | 00       |
| 013A    | Port 10 Pull-Up Control Register            | P10PUP        | —             |     | 00       |

# Table 6-2 Port Contorol SFR List

Notes: 1. Addresses do not run consecutively.

<sup>2.</sup> Addresses in the address column marked by stars indicate that the register has bits missing.

# 6.3 Port 0 (P0)

P0 (P0\_0-P0\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 0 Mode Register (P0IO). Pull-up resistors can be individually enabled and disabled for each bit by the Port 0 Pull-Up Control Register (P0PUP).

When external memory is accessed, P0 automatically operates as its secondary function of address/data bus (low address output pins and data i/o pins) instead of as a port.

Figure 6-6 shows the configuration of the Port 0 Data Register (P0), Port 0 Mode Register (P0IO), and Port 0 Pull-Up Control Register (P0PUP).



When P0 has been specified as an input by P0IO (P0IOn = 0) and a read instruction is executed on it, the pin state will be read. When P0 has been specified as an output by P0IO (P0IOn = 1) and a read instruction is executed on it, the contents of the Port 0 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P0, the read will be of the pin state or Port 0 Data Register contents as specified by P0IO, while the write will be to the Port 0 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P0 will be a high-impedance input port (P0IO = 00H), and the contents of P0 will be 00H.

# 6.4 Port 1 (P1)

P1 (P1\_0-P1\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 1 Mode Register (P1IO). Pull-up resistors can be individually enabled and disabled for each bit by the Port 1 Pull-Up Control Register (P1PUP).

In addition to its port function, P1 has been assigned a secondary function (external memory highaddress output). The Port 1 Secondary Control Register (P1SF) selects whether the port function or secondary function will be enabled. However, when the EA pin is low, P1 will operate as the address bus (high address output pins) to external program memory and external data memory, regardless of the P1SF settings.

Figure 6-7 shows the configuration of the Port 1 Data Register (P1), Port 1 Mode Register (P1IO), Port 1 Secondary Function Control Register (P1SF), and Port 1 Pull-Up Control Register (P1PUP).



Figure 6-7 Configuration of P1, P1IO, P1SF, P1PUP

When P1 has been specified as an input by P1IO (P1IOn = 0) and a read instruction is executed on it, the pin state will be read. When P1 has been specified as an output by P1IO (P1IOn = 1) and a read instruction is executed on it, the contents of the Port 1 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P1, the read will be of the pin state or Port 1 Data Register contents as specified by P1IO, while the write will be to the Port 1 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P1 will be a high-impedance input port (P1IO,P1SF = 00H), and the contents of P1 will be 00H.

# 6.5 Port 2 (P2)

P2 (P2\_0-P2\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 2 Mode Register (P2IO).

In addition to its port function, P2 has been assigned a secondary function (realtime output pins). The Port 2 Secondary Control Register (P2SF) selects whether the port function or secondary function will be enabled.

Figure 6-8 shows the configuration of the Port 2 Data Register (P2), Port 2 Mode Register (P2IO), and Port 2 Secondary Function Control Register (P2SF).



— indicates a bit that is not provided. It will be read as "1". Always write "0" to the bits shown as 0. They will always read as "0".

# Figure 6-8 Configuration of P2, P2IO, P2SF

When a read instruction is executed on P2, the value read will depend on the contents of P2IO and P2SF, as shown in Table 6-3. When calculation, increment, and other read-modify-write instructions are executed on P2, the read will be of the pin state or Port 2 Data Register contents as specified by P2IO, while the write will be to the Port 2 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P2 will be a high-impedance input port (P2IO = 00H, P2SF = 80H), and the contents of P2 will be 00H.

|            | P2IO | P2SF | Read Data    |
|------------|------|------|--------------|
| P2_0-P2_3, | 0    | —    | Pin          |
| P2_6, P2_7 | 1    | _    | Output latch |
|            | 0    | 0    | Pin          |
| P2_4, P2_5 | 1    | 0    | Output latch |
|            | *    | 1    | Output data  |

#### Table 6-3 Port 2 Reads

— indicates bits that are not provided.

\* indicates 1 or 0.

# 6.6 Port 4 (P4)

P4 (P4\_0-P4\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 4 Mode Register (P4IO). Pull-up resistors can be individually enabled and disabled for each bit by the Port 4 Pull-Up Control Register (P4PUP).

In addition to its port function, P4 has been assigned a secondary function (external clock input for general 8-bit timer). The Port 4 Secondary Control Register (P4SF) selects whether the port function or secondary function will be enabled.

Figure 6-9 shows the configuration of the Port 4 Data Register (P4), Port 4 Mode Register (P4IO), Port 4 Secondary Function Control Register (P4SF), and Port 4 Pull-Up Control Register (P4PUP).



Always write "0" to the bits shown as "0". They will always read as "0".

Figure 6-9 Configuration of P4, P4IO, P4SF, P4PUP

When a read instruction is executed on P4, the value read will depend on the contents of P4IO and P4SF, as shown in Table 6-4. When calculation, increment, and other read-modify-write instructions are executed on P4, the read will be of the pin state or Port 4 Data Register contents as specified by P4IO, while the write will be to the Port 4 Data Register.

After reset (by RES signal input, BRK instruction execution, or op code trap), P4 will be a high-impedance input port (P4IO, P4SF = 00H), and the contents of P4 will be 00H.

|           | P4IO | P4SF | Read Data    |  |
|-----------|------|------|--------------|--|
|           | 0    | 0    | Pin          |  |
| P4_0      | 1    | 0    | Output latch |  |
|           | *    | 1    | Pin          |  |
| P4_1-P4_7 | 0    |      | Pin          |  |
| 14_174_/  | 1    | _    | Output latch |  |

#### Table 6-4 Port 4 Reads

- indicates bits that are not provided.

\* indicates 1 or 0.

# 6.7 Port 5 (P5)

P5 (P5\_4, P5\_5) is a 2-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 5 Mode Register (P5IO).

In addition to its port function, P5 has been assigned a secondary function (ALE and  $\overline{\text{PSEN}}$  output pins). The Port 5 Secondary Control Register (P5SF) selects whether the port function or secondary function will be enabled. However, when the  $\overline{\text{EA}}$  pin is low, P5\_5 and P5\_4 will be configured as ALE and  $\overline{\text{PSEN}}$  pins regardless of P5SF settings.

Figure 6-10 shows the configuration of the Port 5 Data Register (P5), Port 5 Mode Register (P5IO), and Port 5 Secondary Function Control Register (P5SF).



# Figure 6-10 Configuration of P5, P5IO, P5SF

When P5 has been specified as an input by P5IO (P5IOn = "0") and a read instruction is executed on it, the pin state will be read. When P5 has been specified as an output by P5IO (P5IOn = "1") and a read instruction is executed on it, the contents of the Port 5 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P5, the read will be of the pin state or Port 5 Data Register contents as specified by P5IO, while the write will be to the Port 5 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P5 will be a high-impedance input port (P5IO = undefined, P5SF = CFH), and the contents of P5 will be undefined.

# 6.8 Port 6 (P6)

P6 (P6\_0-P6\_5) is a 6-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 6 Mode Register (P6IO).

In addition to its port function, P6 has been assigned a secondary function (external interrupt pins, etc.). The Port 6 Secondary Control Register (P6SF) selects whether the port function or secondary function will be enabled.

Figure 6-11 shows the configuration of the Port 6 Data Register (P6), Port 6 Mode Register (P6IO), and Port 6 Secondary Function Control Register (P6SF).



They will always read as "0".

Figure 6-11 Configuration of P6, P6IO, P6SF

When a read instruction is executed on P6, the value read will depend on the contents of P6IO and P6SF, as shown in Table 6-5. When calculation, increment, and other read-modify-write instructions are executed on P6, the read will be of the pin state or Port 6 Data Register contents as specified by P6IO, while the write will be to the Port 6 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P6 will be a high-impedance input port (P6IO = undefined, P6SF = 00H), and the contents of P6 will be undefined.

|            | P6IO | P6SF | Read Data                                                                 |
|------------|------|------|---------------------------------------------------------------------------|
|            | 0    | 0    | Pin                                                                       |
| P6_0-P6_2  | 1    | 0    | Output latch                                                              |
|            | *    | 1    | Pin                                                                       |
|            | 0    | 0    | Pin                                                                       |
| P6_3       | 1    | 0    | Output latch                                                              |
|            | *    | 1    | Output data                                                               |
|            | 0    | 0    | Pin                                                                       |
| P6_4, P6_5 | 1    | 0    | Output latch                                                              |
|            | *    | 1    | Clock when shift clock is an output;<br>pin when shift clock is an input. |

#### Table 6-5 Port 6 Reads

\* indicates 1 or 0.

# 6.9 Port 7 (P7)

P7 (P7\_0-P7\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 7 Mode Register (P7IO).

In addition to its port function, P7 has been assigned a secondary function (external memory strobe signal output pin, etc.). The Port 7 Secondary Control Register (P7SF) selects whether the port function or secondary function will be enabled.

Figure 6-12 shows the configuration of the Port 7 Data Register (P7), Port 7 Mode Register (P7IO), and Port 7 Secondary Function Control Register (P7SF).



They will always read as "0".

Figure 6-12 Configuration of P7, P7IO, P7SF

When a read instruction is executed on P7, the value read will depend on the contents of P7IO and P7SF, as shown in Table 6-6. When calculation, increment, and other read-modify-write instructions are executed on P7, the read will be of the pin state or Port 7 Data Register contents as specified by P7IO, while the write will be to the Port 7 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P7 will be a high-impedance input port (P7IO, P7SF = 00H), and the contents of P7 will be 00H.

|            | P7IO | P7SF | Read Data    |
|------------|------|------|--------------|
| P7_0, P7_1 | 0    | 0    | Pin          |
| F/_0, F/_1 | 1    | 0    | Output latch |
|            | 0    | 0    | Pin          |
| P7_2       | 1    | 0    | Output latch |
|            | *    | 1    | Pin          |
|            | 0    | 0    | Pin          |
| P7_4       | 1    | 0    | Output latch |
|            | *    | 1    | Output data  |

#### Table 6-6 Port 7 Reads

\* indicates 1 or 0.

# 6.10 Port 8 (P8)

P8 (P8\_0-P8\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 8 Mode Register (P8IO).

Figure 6-13 shows the configuration of the Port 8 Data Register (P8) and Port 8 Mode Register (P8IO).



# Figure 6-13 Configuration of P8, P8IO

When P8 has been specified as an input by P8IO (P8IOn = 0) and a read instruction is executed on it, the pin state will be read. When P8 has been specified as an output by P8IO (P8IOn = 1) and a read instruction is executed on it, the contents of the Port 8 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P8, the read will be of the pin state or Port 8 Data Register contents as specified by P8IO, while the write will be to the Port 8 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P8 will be a high-impedance input port (P8IO = 00H), and the contents of P8 will be 00H.

# 6.11 Port 9 (P9)

P9 (P9\_0-P9\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 9 Mode Register (P9IO). Pull-up resistors can be individually enabled and disabled for each bit by the Port 9 Pull-Up Control Register (P9PUP).

In addition to its port function, P9 has been assigned a secondary function (external program memory address output). The Port 9 Secondary Control Register (P9SF) selects whether the port function or secondary function will be enabled. However, when the  $\overline{EA}$  pin is low, P9 will operate as the program memory address bus (address output pins), regardless of the P9SF settings.

Figure 6-14 shows the configuration of the Port 9 Data Register (P9), Port 9 Mode Register (P9IO), Port 9 Secondary Function Control Register (P9SF), and Port 9 Pull-Up Control Register (P9PUP).



Always write "0" to the bits shown They will always read as "0".

Figure 6-14 Configuration of P9, P9IO, P9SF, P9PUP

When P9 has been specified as an input by P9IO (P9IOn = 0) and a read instruction is executed on it, the pin state will be read. When P9 has been specified as an output by P9IO (P9IOn = 1) and a read instruction is executed on it, the contents of the Port 9 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P9, the read will be of the pin state or Port 9 Data Register contents as specified by P9IO, while the write will be to the Port 9 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P9 will be a high-impedance input port (P9IO, P9SF = 00H), and the contents of P9 will be 00H.

# 6.12 Port 10 (P10)

P10 (P10\_0-P10\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 10 Mode Register (P10IO). Pull-up resistors can be individually enabled and disabled for each bit by the Port 10 Pull-Up Control Register (P10PUP).

Figure 6-15 shows the configuration of the Port 10 Data Register (P10), Port 10 Mode Register (P10IO), and Port 10 Pull-Up Control Register (P10PUP).



# Figure 6-15 Configuration of P10, P10IO, P10PUP

When P10 has been specified as an input by P10IO (P10IOn = 0) and a read instruction is executed on it, the pin state will be read. When P10 has been specified as an output by P10IO (P10IOn = 1) and a read instruction is executed on it, the contents of the Port 10 Data Register will be read. When calculation, increment, and other read-modify-write instructions are executed on P10, the read will be of the pin state or Port 10 Data Register contents as specified by P10IO, while the write will be to the Port 10 Data Register.

After reset (by  $\overline{\text{RES}}$  signal input, BRK instruction execution, or op code trap), P10 will be a high-impedance input port (P10IO = 00H), and the contents of P10 will be 00H.

# 6.13 Port 12 (P12)

P12 (P12\_0-P12\_7) is an 8-bit input/output port. Its bits can be individually specified as inputs or outputs by the Port 12 Mode Register (P12IO).

In addition to its port function, P12 has been assigned a secondary function (external interrupt pins, etc.). The Port 12 Secondary Control Register (P12SF) selects whether the port function or secondary function will be enabled.

Figure 6-16 shows the configuration of the Port 12 Data Register (P12), Port 12 Mode Register (P12IO), and Port 12 Secondary Function Control Register (P12SF).



# Figure 6-16 Configuration of P12, P12IO, P12SF

When a read instruction is executed on P12, the value read will depend on the contents of P12IO and P12SF, as shown in Table 6-7. When calculation, increment, and other read-modify-write instructions are executed on P12, the read will be of the pin state or Port 12 Data Register contents as specified by P12IO, while the write will be to the Port 12 Data Register.

After reset (by RES signal input, BRK instruction execution, or op code trap), P12 will be a high-impedance input port (P12IO, P12SF = 00H), and the contents of P12 will be 00H.

|              | P12IO | P12SF | Read Data    |
|--------------|-------|-------|--------------|
| P12_0, P12_1 | 0     | 0     | Pin          |
| P12_4-P12_7  | 1     | 0     | Output latch |
|              | 0     | 0     | Pin          |
| P12_2, P12_3 | 1     | 0     | Output latch |
|              | *     | 1     | Pin          |

# Table 6-7 Port 12 Reads

\* indicates 1 or 0.

# Chapter 7

7

# **Clock Generator Circuit**

# 7. Clock Generator Circuit

The clock generator circuit is used for generating the master clock pulse (CLK). The crystal oscillator and necessary elements are connected between OSC0 pin and OSC1 pin.

Figure 7-1 shows an example to connect the crystal generator circuit.



- Notes: 1. The values of C0 and C1 have to be decided in accordance with the specifications of an external crystal oscillator.
  - 2. The ceramic resonator can be used instead of the crystal.
  - 3. Parts that are not illustrated may be required by the frequency band that is used.

# Figure 7-1 Example for Connecting Crystal Oscillator Circuit

In addition, when the master clock pulse is supplied from external, input it at OSC0 pin and then open  $\overline{\text{OSC1}}$  pin.

Figure 7-2 shows an example for external clock input.



Figure 7-2 Example for External Clock Input

The clock generator circuit can be stopped by using stop mode, which can further reduce power consumption.

When stop mode is released by an interrupt, the basic clock will be passed on when the number of clock cycles specified by OST0 and OST1 of SBYCON (bit 4 and bit 5) elapse after the oscillator stabilizes. However, when STOP mode is released by the RES pin, the settings of OST0 and OST1 of SBYCON will be invalid, so apply a low level to the RES pin for longer than the oscillation stabilization time.

# **Chapter 8**

8

# Time-Base Counter (TBC)

8

# 8. Time-Base Counter (TBC)

The Time-Base Counter (TBC) is an 8-bit counter that uses as its input clock the overflow of a 4-bit auto-reload timer that uses the master clock for its input.

TBC's frequency divided output is used as a basic clock for a 16-bit RTO/PWM timer or serial port timer.

After reset (RES signal input, BRK instruction execution, op code trap) TBC will be cleared to 0, and will operate unless the master clock supply stops.



Figure 8-1 shows the configuration of TBC.

- Notes: 1. When the 1/n (4-bit) counter is set with n = 1 and TBCCLK is selected for TM1, the 16bit RTO/PWM timer does not operate normally. (The free-running counter TM1 will count normally.)
  - 2. Refer to Chapter 11, "PWM Function," for the divider.

# Figure 8-1 TBC Configuration

# 8.1 1/n Counter

A 4-bit auto-reload timer that uses CLK as its input clock is provided to allow the same clock pulse (TBCCLK) to be supplied to TBC even when oscillation is changed. The 1/n counter is configured from a 4-bit counter (TBCKDVC) and a 4-bit register (TBCKDVR) that stores the reload value.



TBCKDVC is a 4-bit counter (bit 0-bit 3) with CLK as its input clock. Writes to TBCKDVC are ignored. TBCKDVC can be read, but the upper 4 bits will read as 1.

After reset (RES signal input, BRK instruction execution, op code trap) TBCKDVC will be F0H.



TBCKDVR is a 4-bit register (bit 0-bit 3) that stores the reload value to TBCKDVC.

TBCKDVR can be written, but the upper 4 bits will be ignored. TBCKDVR can be read, but the upper 4 bits will read as 1.

After reset (RES signal input, BRK instruction execution, op code trap) TBCKDVR will be F0H. The 1/n counter will divide CLK by 16, so a 1/16 CLK will be supplied to TBC as TBCCLK.

After a reload value is written to TBCKDVR, it may take up to 16 CLK pulses before the frequency division by the written value affects operation.

# Chapter 9

# 16-Bit RTO/PWM Timer

# 9. 16-Bit RTO/PWM Timer

The 16-bit RTO/PWM Timer is configured from a 16-bit counter, two 16-bit registers, and a control register. It provides two modes PWM/realtime output mode.

Figure 9-1 shows the 16-bit RTO/PWM timer configuration. Table 9-1 lists the 16-bit RTO/PWM timer control SFRs.



# Figure 9-1 16-Bit RTO/PWM Timer Configuration

| Address | Name                   | Symbol  | Symbol | R/W  | Reset |
|---------|------------------------|---------|--------|------|-------|
| [H]     | Name                   | (Byte)  | (Word) | n/ w | State |
| 0090    | Time Banister 0        |         | тмро   |      | 0000  |
| 0091    | Timer Register 8       | _       | TMR8   |      | 0000  |
| 0092    | Timer Register 9       | _       | TMR9   |      | 0000  |
| 0093    | Timer negister 9       |         |        |      | 0000  |
| 00B4☆   | RTO Control Register 4 | RTOCON4 | _      | R/W  | FC    |
| 00B5☆   | RTO Control Register 5 | RTOCON5 |        | ]    | FC    |
| 00C2    | Timer Counter 1        | _       | TM1    |      | 0000  |
| 00C3    |                        |         |        |      |       |
| 00E2☆   | Timer Control Register | TMCON   | _      |      | 00    |
| 00E4    | TM Calact Desister     | _       | TMSEL  |      | 0200  |
| 00E5☆   | TM Select Register     |         |        |      | 0300  |
| 00E6☆   | TMR Mode Register      | TMRMODE | _      |      | 00    |

#### Table 9-1 16-Bit RTO/PWM Timer Control SFRs

Notes: 1. Addresses do not run consecutively.

2. Addresses in the address column marked by stars indicate that the register has bits missing.

9

# 9.1 Counter Configuration

The counter circuit is configured from a 16-bit free-running counter (TM1), an input clock selector, and a control register (TMCON) that controls TM1 operation. TM1 generates an interrupt request whenever an overflow occurs.

Figure 9-2 shows the counter configuration.



Figure 9-2 Counter Configuration

TM1 is a 16-bit counter that can be read or written by the program.

After reset (RES signal input, BRK instruction execution, op code trap) TM1 will be 0000H, stopping operation.

The TM1 count clock is selected by the Timer Control Register (TMCON) from TBC's frequency divided output 0-6 of the TBC count clock (TBCCLK).

TMCON is an 8-bit register that selects the TM1 count clock, and also selects whether the clock operates or stops. After reset (RES signal input, BRK instruction execution, op code trap) TMCON will be 00H, selecting TBCCLK for the TM1 count clock and stopping operation.

Figure 9-3 shows the configuration of TMCON.



Always write "0" to the bits shown as "0". They will always read as "0".

Figure 9-3 TMCON Configuration

# 9.2 TM Select Register

The TM Select Register (TMSEL) is a 16-bit register.

After reset (RES signal input, BRK instruction execution, op code trap) TMSEL will be 0300H. However, it will be 0000H with an ICE.

When the timer is to be used, always write 0300H after reset (RES signal input, BRK instruction execution, op code trap).

Figure 9-4 shows the configuration of TMSEL.



#### Figure 9-4 TMSEL Configuration

# 9.3 Register Modules (TMR8, TMR9)

Two sets of register modules, TMR8 and TMR9, are provided. The two sets have the same configuration except that the SFR addresses assigned to the registers are different.

# 9.3.1 Register Module (TMR8, TMR9) Configuration

A register module has three types of realtime output: toggle RTO, RTO, and PWM mode. It is configured from a 16-bit timer register (TMR8, TMR9), output pins for the realtime output signal (RTO8, RTO9), timing controller, comparator to compare the timer counter value and timer register value, control register to specify realtime output operation (TMRMODE), and control register to control realtime output operation (RTOCON4, RTOCON5).

To use RTO8 and RTO9 as realtime output pins, be sure to set the corresponding bits in the Port 2 Secondary Control Register to "1".



Figure 9-5 Register Module Configuration

(1) Timer Registers (TMR8, TMR9)

The timer registers (TMR8, TMR9) are 16-bit registers. TMR8 and TMR9 are always compared to the counter value of TM1. They can be read and written by the program.

After reset (RES signal input, BRK instruction execution, op code trap) TMR8 and TMR9 will be 0000H.

(2) Realtime Output Control Registers (RTOCON4, RTOCON5)

The realtime output control registers (RTOCON4, RTOCON5) are configured as two bits. When TMR8 or TMR9 match the counter value specified by TMSEL, the contents of TnBF0 (bit 1) will be loaded into TnOUT (bit 0). Set TnBF0 to the level desired after the next event change.

RTOCON4 and RTOCON5 can be read and written by the program. When written, the upper 6 bits will be ignored. When read, the upper 6 bits will read as "1". Note that TnBF0 and TnOUT might not operate correctly just before an RTO event when an SB, RB, XORB or other read-modify-write instruction is executed on RTOCON4 or RTOCON5.

After reset (RES signal input, BRK instruction execution, op code trap) RTOCON4 and RTOCON5 will be FCH.

Figure 9-6 shows the configuration of RTOCON4 and RTOCON5.



— indicates bits that are not provided. They will be read as "1".

n = 8, 9

Figure 9-6 RTOCON4, RTOCON5 Configuration

(3) TMR Mode Register (TMRMODE)

The TMR Mode Register (TMRMODE) is configured as 4 bits. TMRMODE selects the operation of TMR8 and TMR9. It can be read and written by the program.

After reset (RES signal input, BRK instruction execution, op code trap) TMRMODE will be 00H, specifying toggle RTO mode for TMR8 and TMR9.

Figure 9-7 shows the configuration of TMRMODE.



Figure 9-7 TMRMODE Configuration

# 9.3.2 Register Module (TMR8, TMR9) Operation

TMRMODE can select one of three functions for a register module.

- Realtime output mode (RTO)
- Toggle realtime output mode (toggle RTO)
- PWM mode
- (1) Realtime Output Mode (RTO) Operation

When the TM1 counter is running, its value will continuously be compared to TMR8 and TMR9. When the values match, a realtime output interrupt request will be generated and the contents of TnBF0 of RTOCON4 or RTOCON5 (bit 1) will be loaded in TnOUT (bit 0), where n = 8 or 9. Therefore, set TMR8 and TMR9 to the desired time interval until the next event change, and set TnFB0 to the desired level after the next event change.

Figure 9-8 shows an operation example of a register module in RTO mode.

To use RTO8 and RTO9 as realtime output pins, be sure to set the corresponding bits in the Port 2 Secondary Control Register to 1.

(2) Toggle Output Realtime Output Mode (Toggle RTO) Operation

9

When the TM1 counter is running, its value will continuously be compared to TMR8 and TMR9. When the values match, a realtime output interrupt request will be generated and the contents of TnBF0 of RTOCON4 or RTOCON5 (bit 1) will be loaded in TnOUT (bit 0), where n = 8 or 9. The contents of TnFB0 of RTOCON4 or RTOCON5 will then be immediately and automatically inverted.

Figure 9-9 shows an operation example of a register module in toggle RTO mode.

To use RTO8 and RTO9 as realtime output pins, be sure to set the corresponding bits in the Port 2 Secondary Control Register to 1.

(3) PWM Mode Operation

TMR8 and TMR9 can operated in PWM mode as a pair. When PWM mode is specified and the TM1 counter is running, its value will continuously be compared to TMR8. When the values match, an interrupt request will be generated, and the PWM flip-flop will be set (1). When the TM1 counter is running, its value will also continuously be compared to TMR9. When the values match, an interrupt request will be generated, and the PWM flip-flop will be set (1). If a set and reset for the PWM flip-flop occur simultaneously, then the reset will take precedence.

The Q (true) output of the PWM flip-flop will be output from RTO8, and the  $\overline{Q}$  (inverted) output will be output from RTO9.

In PWM mode, TnBF0 (bit 1) and TnOUT (bit 0) of RTOCON4 and RTOCON5 will be invalid (n = 8, 9).

Figure 9-10 shows an operation example of a register module in PWM mode.

To use RTO8 and RTO9 as PWM output pins, be sure to set the corresponding bits in the Port 2 Secondary Control Register to 1.



Figure 9-9 Operation Example of Register Module in Toggle RTO Mode (n = 8, 9)



Figure 9-10 Operation Example of Register Module in PWM Mode



Figure 9-11 Operation Example of Register Module

# Chapter 10

# General 8-Bit Timer

10

## 10. General 8-Bit Timer

The MSM66587 family has one internal general 8-bit timer (GTM). Table 10-1 lists the SFRs for controlling GTM.

| Address<br>[H] | Name                                 | Symbol<br>(Byte) | Symbol<br>(Word) | R/W | Reset<br>State |
|----------------|--------------------------------------|------------------|------------------|-----|----------------|
| 00F8☆          | General 8-Bit Timer Control Register | GTMCON           |                  |     | 30             |
| 00FA           | General 8-Bit Timer Counter          | GTMC             |                  | R/W | 00             |
| 00FB           | General 8-Bit Timer Register         | GTMR             |                  |     | 00             |

| Table 10- | 1 SFRs | for Con | trolling | GTM |
|-----------|--------|---------|----------|-----|
|-----------|--------|---------|----------|-----|

Note: Address in the address column marked by a star indicates that the register has bits missing.

#### 10.1 General 8-Bit Timer

The General 8-Bit Timer is configured from an 8-bit timer/counter (GTMC), an 8-bit timer register that stores the reload value of GTMC (GTMR), and an 8-bit timer control register for controlling operation (GTMCON).



Figure 10-1 GTM Configuration

Note: If the General 8-Bit Timer is used in external clock mode, when stop mode is entered when released by an interrupt the General 8-Bit Timer Counter (GTMC) might increment by 1 depending on the input level of the external clock at the time of release.

(1) General 8-Bit Counter (GTMC)

GTMC is an 8-bit counter that generates an interrupt request and loads the General 8-Bit Timer Register (GTMR) when GTMC overflows. GTMC's count clock is selected by the lower 3 bits of the General 8-Bit Timer Control Register (GTMCON).

After reset (RES signal input, BRK instruction execution, op code trap) GTMC will be 00H, with counting stopped. When an external count clock has been specified by GTMC, during stop mode, it will count on the clock's falling edges.

(2) General 8-Bit Register (GTMR)

GTMR is an 8-bit register that loads its contents to GTMC when GTMC overflows. After reset (RES signal input, BRK instruction execution, op code trap) GTMR will be 00H.

(3) General 8-Bit Timer Control Register (GTMCON)

GTMCON is an 8-bit register, with its lower 4 bits selecting the GTMC count clock and controlling count start and stop. It upper 2 bits select the GEVC count clock.

After reset (RES signal input, BRK instruction execution, op code trap) GTMCON will be 30H, selecting 1/2 TBCCLK as GTMC's count clock and stopping count operation.



Figure 10-2 GTMCON Configuration

# Chapter 11

# **PWM Function**

11

11

## 11. **PWM** Function

The MSM66587 family has one internal PWM channel, configured as a divider circuit for the PWM count clock, a 16-bit counter, three 16-bit registers, and a control register.

If the master clock is 20 MHz, then a period of 100 ns to 209.7152 ms can be selected by the selected valued for PWM counter and input clock.

Figure 11-1 shows the configuration of PWM. Table 11-1 lists the SFRs for controlling PWM.



Figure 11-1 PWM Configuration

| Address<br>[H] | Name                                    | Symbol<br>(Byte) | Symbol<br>(Word) | R/W | Reset<br>State |
|----------------|-----------------------------------------|------------------|------------------|-----|----------------|
| 0050<br>0051   | PWM Counter 0                           |                  | PWC0             | R   | FFFF           |
| 0060<br>0061   | PWC0 Buffer Register                    | _                | PWC0BF           |     | FFFF           |
| 0070<br>0071   | PWR0 Buffer Register                    | _                | - PW0BF          |     | 0000           |
| 00EB☆          | PWMRUN Register                         | PWRUN            |                  |     | 00             |
| 00EC☆          | PWM Control Register 0                  | PWCON0           | —                | R/W | 00             |
| 00F0☆          | PWM Interrupt Register 0                | PWINTQ0          | DWINTO           |     | 00             |
| 00F1☆          | PWM Interrupt Register 1                | PWINTQ1          | PWINTQ           |     | 00             |
| 00F2☆          | PWM Interrupt Enable Register 0 PWINTE0 |                  | DIALINITE        |     | 00             |
| 00F3☆          | PWM Interrupt Enable Register 1         | PWINTE1          | PWINTE           |     | 00             |

#### Table 11-1 PWM Control SFRs

Notes: 1. Addresses do not run consecutively.

2. Addresses in the adress column marked by stars indicates that the register has bits missing.

#### 11.1 Clock Divider Circuit

The clock divider circuit creates the PWM count clock by dividing the master clock. It generates count clocks of 1/2 CLK, 1/4 CLK, 1/8 CLK, 1/16 CLK, 1/32 CLK, and 1/64 CLK.

#### 11.2 PWM Configuration

One PWM set, PWM0, is provided.

PWM is configured from a 16-bit counter (PWC0), 16-bit counter buffer register (PWC0BF), 16bit register (PWR0), 16-bit buffer register (PW0BF), PWC0/PWR0 comparator, output flip/flop, and registers for controlling operation (PWINTQ, PWINTE, PWCON0, PWRUN).

To use the PWM0 pin for the PWM function, set (1) the corresponding bits in the Port 7 Secondary Control Register.

(1) PWM Counter (PWC0)

PWC0 is a 16-bit down counter. Its input clock can be selected from the master clock CLK, 1/2 CLK, 1/4 CLK, 1/8 CLK, 1/16 CLK, 1/32 CLK, and 1/64 CLK. While the PW0RUN bit is "1", PWC0 will count down. When it underflows, the contents of the 16-bit PWM Buffer Register will be loaded into the PWM Register, and the output flip/flop will be set.

PWC0 can be read by the program, but it cannot be written. However, if the PW0RUN bit is 0 (stopped state) and a write to PWC0BF is performed, then those 16 bits will also be written to PWC0.

After reset (RES signal input, BRK instruction execution, op code trap) PWC0 will be FFFFH.

(2) PWM Counter Buffer Register (PWC0BF)

PWC0BF is a 16-bit register for setting the period (stores the PWC0 reload value). PWC0BF contents will be loaded into the 16-bit PWM Counter when PWC0 underflows.

PWC0BF can be read and written by the program. If the PW0RUN bit is "0" (stopped state) and a write to PWC0BF is performed, then those 16 bits will also be written to PWC0.

After reset (RES signal input, BRK instruction execution, op code trap) PWC0BF will be FFFFH.

(3) PWM Register (PWR0)

PWR0 is a 16-bit register that stores the duty value to be output. When PWC0 underflows, the contents of the 16-bit PWM Buffer Register will be loaded into PWR0.

PWR0 cannot be read or written by the program. However, if the PW0RUN bit is 0 (stopped state) and a write to PW0BF is performed, then those 16 bits will also be written to PWR0.

After reset (RES signal input, BRK instruction execution, op code trap) PWR0 will be 0000H.

(4) PWM Buffer Register (PW0BF)

PW0BF is a 16-bit register. When PWC0 underflows, the contents of the 16-bit PWM Register will be loaded into PWM0BF.

PW0BF can be read and written by the program. If the PW0RUN bit is "0" (stopped state) and a write to PW0BF is performed, then those 16 bits will also be written to PWR0.

After reset (RES signal input, BRK instruction execution, op code trap) PW0BF will be 0000H.

(5) Comparator Circuit

The comparator circuit continually compares the values of PWC0 and PWR0 while the PW0RUN bit is 1. When the values match, it generates an interrupt request and resets the output flip/flop.

(6) Output Flip/Flop

The output flip/flop is set ("1") when the PW0RUN bit becomes "1" and when PWC0 overflows. It is reset ("0") when the values of PWC0 and PWR0 match.

(7) PWM Control Register (PWCON0)

PWCON0 is an 4-bit register that specifies the PWC0 count clock and PWM0 output logic. Figure 11-2 shows the configuration of PWCON0.

After reset (RES signal input, BRK instruction execution, op code trap) PWCON0 will be 00H, setting the master clock as PWC0's count clock and making PWM0 active high.



Always write "0" to the bits shown as "0". They will always read as "0".



(8) PWM Run Register (PWRUN)

PWRUN is an 1-bit register that controls PWC0 counting operation to enable or to disable. Figure 11-3 shows the configuration of PWRUN.

After reset (RES signal input, BRK instruction execution, op code trap) PWRUN will be 00H, stopping PWC0 counting.



Always write "0" to the bits shown as "0". They will always read as "0".

Figure 11-3 PWRUN Configuration

11

(9) PWM Interrupt Registers (PWINTQ0, PWINTQ1)

PWM0 issues two interrupt requests: when PWC0 underflows, and when the values of PWC0 and PWR0 match.

PWINTQ0 and PWINTQ1 are 1-bit registers. PWINTQ0 is a flag set (1) when PWC0 underflows. PWINTQ1 is a flag set (1) when the values of PWC0 and PWR0 match. Neither is automatically reset to 0, after their respective interrupts occur, so the program needs to reset them to 0.

If a PWC0 underflow and PWC0 and PWR0 match occur simultaneously (when PWR=0000H), then the PWC0 underflow interrupt request will take precedence. Only the PWINTQ0 bit will be set (1); the PWINTQ1 bit will not be set (1). Figure 11-4 shows the configuration of PWINTQ0, and Figure 11-5 shows the configuration of PWINTQ1.

After reset (RES signal input, BRK instruction execution, and op code trap), PWINTQ0 and PWINTQ1 will be 00H.







Figure 11-5 PWINTQ1 Configuration

(10) PWM Interrupt Enable Registers (PWINTE0, PWINTE1)

PWINTE0 and PWINTE1 are 1-bit registers. PWINTE0 enables and disables interrupt requests generated by PWC0 underflow. PWINTE1 enables and disables interrupt requests generated when PWC0 and PWR0 values match. Figure 11-6 shows the configuration of PWINTE0, and Figure 11-7 shows the configuration of PWINTE1.

After reset (RES signal input, BRK instruction execution, op code trap) PWINTE0 and PWINTE1 will be 00H, disabling PWM0 interrupt requests.







Figure 11-7 PWINTE1 Configuration

# 11.3 PWM Operation

PWM0 control the duty of an output within a particular period (determined by the PWC0 count clock and the contents of PWC0 and PWC0BF).

PWM is started by setting ("1") the RUN bit. At the same time the RUN bit becomes "1", the output flip/flop will be set ("1") and the PWM output pin will output a high level (for active high operation). When the values of PWC0 and PWR0 match, the output flip/flop will be reset ("0"), the PWM output pin will output a low level, and an interrupt request flag will be set ("1"). When PWC0 underflows, the output flip/flop will be set ("1"). At the same time, the contents of PWC0BF will be loaded in PWC0 and the contents of PW0BF will be loaded into PWR0. This operation will repeat until the RUN bit is reset ("0"), with the duty-controlled waveform being output from the PWM output pin.

If a PWC0 underflow and PWC0 and PWR0 match occur simultaneously (when PWR = 0000H), then the PWC0 underflow interrupt request will take precedence. Only the PWINTQ0 bit will be set ("1"); the PWINTQ1 bit will not be set ("1").

Depending on the count clock selected for PWC0, the duty immediately after PWM is started (for just one period) might be shortened. The maximum deviations are listed below.

| Count Clock  | Maximum Deviation |
|--------------|-------------------|
| Master clock | 0                 |
| 1/2 CLK      | -1/2 CLK          |
| 1/4 CLK      | 3/4 CLK           |
| 1/16 CLK     | -15/16 CLK        |
| 1/64 CLK     | -63/64 CLK        |

If PWC0 and PWC0BF are FFFFH, PWM is active high, and PWR is FFFFH, then the duty output will be 1/65536. If the value of PWR is decreased, then the output duty (time interval at high level) will increase. If PWR is 0000H, then the duty will become 65536/65536, or 100%. A duty of 0/ 65536, or 0%, cannot be realized by the PWM block.

The PWM period can be calculated with the following expression.

 $\begin{array}{l} f_{(PWM)}:f_{(OSC)}\times PWCLK\times \frac{1}{N+1} \\ f_{(OSC)}:master clock frequency (Hz) \\ f_{(OSC)}:master clock frequency (Hz) \\ PWCLK:PWM input clock \\ N:value of PWC0 and PWC0BF \end{array}$ 

Example: Assume the master clock frequency is 20 MHz, the PWM input clock is 1/2 CLK, and the value of PWC0BF is 00FFH.

$$f_{(PWM)} = 20,000,000 \times \frac{1}{2} \times \frac{1}{(255 + 1)} = 39,062.5 \text{ Hz} (25.6 \text{ } \mu\text{s})$$

Figure 11-8 shows an example of PWM output operation. Figure 11-9 shows an example of the timing of PWM output changes.



Figure 11-9 PWM Output Change Timing

# Chapter 12

# Baud Rate Generator Functions

12

# 12. Baud Rate Generator Functions

The MSM66587 family has a synchronous serial port for serial communication. It provides an 8bit timer (S1TM) that can be used as a baud rate generator for that serial port. When this timer is not used as a baud rate generator, it can be used as an 8-bit auto-reload timer.

Figure 12-1 shows the configuration of S1TM. Table 12-1 lists the S1TM control SFRs.



Figure 12-1 S1TM Configuration

| Table | 12-1 | S1TM   | Control | SFRs |
|-------|------|--------|---------|------|
| Iable | 12-1 | 311101 | CONTROL | SEUS |

| Address<br>[H] | Name                        | Symbol<br>(Byte) | Symbol<br>(Word) | R/W | Reset<br>State |
|----------------|-----------------------------|------------------|------------------|-----|----------------|
| 0118           | SCI1 Timer Counter          | —                | S1TM             |     | 0000           |
| 0119           | SCI1 Timer Register         |                  | 31111            | R/W | 0000           |
| 011A☆          | SCI1 Timer Control Register | S1CON            |                  |     | 02             |

Note: Address in the address column marked by a star indicates that the register has bits missing.

#### 12.1 SCI1 Timer (S1TM) Configuration

The SCI1 Timer is configured from the 8-bit SCI1 Timer Counter, the 8-bit SCI1 Timer Register (which stores the reload value of the SCI1 Timer Counter), and the SCI1 Control Register (which specifies S1TM operation).

(1) SCI1 Timer Counter (lower 8 bits of 16-bit register S1TM)

The SCI1 Timer Counter is an 8-bit counter. When it overflows, an interrupt request will be generated and it will be loaded with the contents of the 8-bit SCI1 Timer Register. The S1TM count clock is selected by the upper 3 bits (bits 5-7) of the 8-bit SCI1 Timer Control Register (S1CON).

(2) SCI1 Timer Register (higher 8 bits of 16-bit register S1TM)

The SCI1 Timer Register is an 8-bit register. Its contents will be loaded into the SCI1 Timer Counter when the SCI1 Timer Counter overflows.

The SCI1 Timer Counter forms the lower 8 bits, and the SCI1 Timer Register forms the upper 8 bits, of the 16-bit S1TM, which can only be accessed as a word.

After reset (RES signal input, BRK instruction execution, op code trap) S1TM will be 0000H, stopping the count operation.

(3) SCI1 Timer Control Register (S1CON)

S1CON is an 7-bit register. Its upper 4 bits (bits 4-7) select the S1TM count clock and control starting and stopping of count operations. Its next lower 2 bits (bits 2-3) control interrupts. The least significant bit (bit 0) specifies the S1TM mode.

After reset (RES signal input, BRK instruction execution, op code trap) S1CON will be 02H, selecting CLK as the S1TM count clock, selecting auto-reload timer mode, and stopping the count operation.

Figure 12-2 shows the configuration for S1CON.

[Bit descriptions]

• S1MOD (bit 0)

This bit specifies the S1TM operating mode.

When this bit is "0", S1TM will operate in auto-reload timer mode. When "1", S1TM will operate as the SCI1 baud rate generator.

• QSTM1 (bit 2)

This bit will become "1" when the SCI1 Timer Counter overflows. Interrupt processing will automatically reset this bit to "0", so the program must do so.

• ESTM1 (bit 3)

This bit enables and disables interrupt requests from being generated when the SCI1 Timer Counter overflows. When this bit is "1", interrupt requests are enabled. When "0", they are disabled.

• S1RUN (bit 4)

This bit specifies whether the SCI1 Timer Counter runs or stops. When this bit is "0", the SCI1 Timer Counter is disabled. When "1", it is enabled.

• S1CK0-S1CK2 (bits 5-7)

These bits specify the SCI1 Timer Counter count clock.

|             | 7     | 6     | 5     | 4     | 3     | 2     | 1 | 0     |       |      |                                                             |  |
|-------------|-------|-------|-------|-------|-------|-------|---|-------|-------|------|-------------------------------------------------------------|--|
| S1CON       | S1CK2 | S1CK1 | S1CK0 | S1RUN | ESTM1 | QSTM1 | _ | S1M0D |       |      | ddress : 011AH                                              |  |
| Reset state | 0     | 0     | 0     | 0     | 0     | 0     | 1 | 0     | F     | R/W  | access : R/W                                                |  |
|             |       |       |       |       |       |       |   | 0     | -     |      | auto-reload timer mode<br>baud rate generator mode for SCI1 |  |
|             |       |       |       |       |       |       |   | 0     | S1    | TM ( | did not overflow.                                           |  |
|             |       |       |       |       |       |       |   | 1     | S1    | TM   | overflowed.                                                 |  |
|             |       |       |       |       |       |       |   | 0     | S1    | TM o | overflow interrupt requests disabled                        |  |
|             |       |       |       |       |       |       |   | 1     | S1    | TM o | overflow interrupt requests enabled                         |  |
|             |       |       |       |       |       |       |   | 0     | S1    | TM   | count stopped                                               |  |
|             |       |       |       |       |       |       |   | 1     | S1    | TM   | count running                                               |  |
|             |       |       |       |       |       |       |   |       | S1C   | СК   |                                                             |  |
|             |       |       |       |       |       |       |   | 2     | 1     | 0    | S1TM Count Clock                                            |  |
|             |       |       |       |       |       |       |   | 0     | 0     | 0    | CLK                                                         |  |
|             |       |       |       |       |       |       |   | 0     | 0     | 1    | 1/2 CLK                                                     |  |
|             |       |       |       |       |       |       |   | 0     | 1     | 0    | 1/2 TBCCLK                                                  |  |
|             |       |       |       |       |       |       |   | 0     | 1     | 1    | 1/4 TBCCLK                                                  |  |
|             |       | •     |       |       |       |       |   | 1     | 0     | 0    | 1/8 TBCCLK                                                  |  |
|             |       |       |       |       |       |       |   | 1     | 0     | 1    | 1/16 TBCCLK                                                 |  |
|             |       |       |       |       |       |       |   | 1     | 1     | 0    | 1/64 TBCCLK                                                 |  |
|             |       |       |       |       |       |       |   | 1     | 1     | 1    | 1/256 TBCCLK                                                |  |
|             |       |       |       |       |       |       |   | _     | india | ates | s bits that are not provided.                               |  |

— indicates bits that are not provided. They will be read as "1".

#### Figure 12-2 S1CON Configuration

### 12.2 SCI1 Timer Operation

The SCI1 Timer basically operates as an auto-reload timer. When the 8-bit SCI1 Timer Counter overflows, it will be loaded with the value of the 8-bit SCI1 Timer Register. At the same time the overflow generates an interrupt request. The baud rate when SCI1 is used as a baud rate generator can be calculated from the expression below.

Synchronous mode : 
$$B = f_{(BRG)} \times \frac{1}{256 - D} \times \frac{1}{4}$$
  
B : Baud rate  
 $f_{(BRG)}$  : S1TM input clock frequency (Hz)  
D : Reload value (0-255)

Writing a reload value to the SCI1 Timer Register will not change the contents of the SCI1 Timer Counter. When used as a fixed auto-reload counter (baud rate generator) from the start of counting, it is needed by program to write the same value to the SCI1 Timer Counter and SCI1 Timer Register.

# Chapter 13

# Serial Port Functions

13

# 13. Serial Port Functions

The MSM66587 family provides a 1-channel serial port (SCI1). SCI1 also provides a dedicated baud rate generator.

SCI1 has a transmit side and receive side. Its communications are synchronous, with serial data transfer synchronized to a controlled shift clock.

Synchronous mode includes a master mode, which generates the shift clock internally, and slave mode, which accepts an externally supplied shift clock. Table 13-1 lists the serial port modes.

|                           | ansmit<br>Side   | Synchronous Mode | Master Mode |
|---------------------------|------------------|------------------|-------------|
| Port                      | Tran             | (SCI1)           | Slave Mode  |
| Serial<br>Receive<br>Side | Synchronous Mode | Master Mode      |             |
|                           | Rece             | (SCI1)           | Slave Mode  |

Table 13-1 Serial Port Modes

## 13.1 Serial Port Configuration

The serial port is configured from the following registers and other elements.

- Baud rate generator, for generating the transfer speed (refer to Chapter 12: S1TM)
- SCI1 Control Registers (SR1CON, ST1CON), for controlling transmit and receive operations
- SCI1 Buffer Register (S1BUF), for setting transmit and receive data
- SCI1 Status Register (S1STAT)
- SCI1 Transmit/Receive Register

Figure 13-1 shows the configuration of SCI1. Table 13-2 lists the SFRs for controlling the serial port.



Figure 13-1 SCI1 Configuration

| Address<br>[H] | Name                                   | Symbol<br>(Byte) | Symbol<br>(Word) | R/W | Reset<br>State |
|----------------|----------------------------------------|------------------|------------------|-----|----------------|
| 00F6           | SCI1 Transmit/Receive Buffer Register  | S1BUF            |                  |     | undefind       |
| 00F7☆          | SCI1 Status Register                   | S1STAT           |                  | R/W | 00             |
| 011B☆          | SCI1 Transmit Control Register         | ST1CON           |                  | K/W | 8E             |
| 011C☆          | SCI1 Transmit/Receive Control Register | SR1CON           |                  |     | 0E             |

# Table 13-2 Serial Port Control SFRs

Notes: 1. Addresses do not run consecutively.

2. Addresses in the address column marked by stars indicate that the register has bits missing.

# 13.1.1 SCI1 Transmit/Receive Control Register (SR1CON)

SR1CON is a 2-bit register that controls transmit and receive operation.

After reset (RES signal input, BRK instruction execution, op code trap) SR1CON will be 0EH, disabling SCI1 transmit/receive and placing both operations in slave mode.

Do not change SR1MST (bit 4) while data is being transmitted. Change it after the data transmit operation has finished. Also, do not change SR1MST while data is being received. Change it after the data receive operation has finished, or after SR1REN (bit 7) has been reset (0). If SR1CON is changed before SR1REN has been reset, the current or later transmit/receive operations will not execute correctly.

Figure 13-2 shows the configuration of SR1CON.

[Bit descriptions]

• SR1MST (bit 4)

Setting this bit to "0" sets slave mode. Setting it to "1" sets master mode.

• SR1REN (bit 7)

This bit enables and disables transmit/receive operation. Setting this bit to "0" disables SCI1 transmit/receive operation. Setting it to "1" enables SCI1 transmit/receive operation.







## 13.1.2 SCI1 Transmit Control Register (ST1CON)

ST1CON is a 1-bit register that controls SCI1 transmit operation.

After reset (RES signal input, BRK instruction execution, op code trap) ST1CON will be 8EH, placing SCI1 transmit operation in slave mode.

Do not change ST1CON while data is being transmitted. Change it after the data transmit operation has finished. If ST1CON is changed before the data transmit operation has finished, the current or later transmit operations will not execute correctly.

— Note

When using the serial port, be sure to set ST1MST (bit 4) of ST1CON and SR1MST (bit 4) of SR1CON to the same value. (SR1MST = ST1MST = "0" or SR1MST = ST1MST = "1")

Figure 13-3 shows the configuration of ST1CON.

[Bit descriptions]

• ST1MST (bit 4)

Setting this bit to 0 sets slave mode. Setting it to 1 sets master mode.





### 13.1.3 SCI1 Transmit/Receive Buffer Register (S1BUF)

S1BUF is an 8-bit register that saves transmit and receive data for serial port transfer operations. S1BUF has dual functions different for reading and writing. In other words, it serves as a receive buffer when read, and as a transmit buffer when written.

At the time a receive operation finishes, the contents of the SCI1 Receive Register will be transferred to S1BUF's receive buffer, and simultaneously a receive interrupt request will be generated. The contents of the S1BUF receive buffer will be saved until the next receive operation finishes.

After reset (RES signal input, BRK instruction execution, op code trap) S1BUF will be undefined.

#### 13.1.4 SCI1 Transmit/Receive Register

The SCI1 Transmit/Receive Register is an 8-bit shift register that performs the actual shift operations for data transmit and receive.

The SCI1 Transmit/Receive Register and the SCI1 Transmit/Receive Buffer Register (S1BUF) are arranged as two levels. When a receive operation finishes, the data latched in the SCI1 Transmit/ Receive Register will be transferred to S1BUF, and a receive interrupt request will be generated.

The SCI1 Transmit/Receive Register cannot be read or written by the program.

13.1.5 SCI1 Status Register (S1STAT)

The upper 4 bits of S1STAT are the interrupt request control register for serial port transmit ready and receive ready. Bit 1 of S1STAT saves the status (normal or error) when a serial port receive operation finishes.

S1STAT bit 1 is updated at the time a receive operation finishes. When it has been set once (1 = error), then it will not be reset (0) even if the next receive operation finishes without error. After a receive operation finishes, the program should reset (0) bit 1 of S1STAT.

After reset (RES signal input, BRK instruction execution, op code trap) S1STAT will be 00H. Figure 13-4 shows the configuration of S1STAT.

[Bit Descriptions]

• OERR1 (bit 1)

This bit will be set ("1") when an SCI1 receive operation finishes and the CPU cannot read the last receive data. However, even in this case S1BUF will be loaded with new receive data (overrun error).

• RV1IE (bit 4)

This bit enables and disables interrupts generated by an SCI1 receive ready state. Setting this bit to "1" enables interrupts, while resetting to "0" disables interrupts.

• RV1IRQ (bit 5)

This bit becomes "1" when an SCI1 receive ready state occurs. It will not automatically be reset to "0" by execution of the interrupt process, so the program should reset it.

• TR1IE (bit 6)

This bit enables and disables interrupts generated by an SCI1 transmit ready state. Setting this bit to "1" enables interrupts, while resetting to "0" disables interrupts.

• TR1IRQ (bit 7)

This bit becomes "1" when an SCI1 transmit ready state occurs. It will not automatically be reset to "0" by execution of the interrupt process, so the program should reset it.



Always write "0" to the bits shown as "0". When read, "0" is read.

#### Figure 13-4 Configuration of S1STAT

#### 13.2 Serial Port Operation

#### 13.2.1 Transmit Operation

<Synchronous Master Mode>

In synchronous master mode, the clock pulse obtained by the Baud Rate Generator (S1TM) is frequency divided by four, generating the transmit shift clock (ST1CLK). The transmit circuit synchronizes transmit data transfer to ST1CLK.

The start of a transmit operation is triggered by the signal that writes transmit data to S1BUF (WS1BUF: signal output when an instruction is executed that writes to S1BUF, like "STB A, S1BUF"). When WS1BUF is generated, after one clock (master clock) the signal to start the transmit operation (LST1SF) will be generated.

The falling edge of LST1SF transfers the contents of S1BUF to the SC1 Transmit Register.

The transmit operation will then start, setting the signal that indicates transmit operation in progress (ST1FREE) to a low level. When ST1FREE goes low, the transmit shift clock will be output from the TXC1 pin synchronized to the second falling edge of ST1CLK. After a half clock, bit 0 of the transmit data (LSB first) will be output from the TXD1 pin.

After the falling of LST1SF, synchronized to the signal that indicates the start of instruction execution (M1S1), a transmit interrupt request (TX1READY) will be generated, and the interrupt request flag (QSCI1) will be set ("1").

Then in accordance to the specification of SR1CON, transmit data and a parity bit will be output synchronized to TXC1 (that is, ST1CLK), completing transmission of one frame.

TXD1 will change a half clock after the falling edge of ST1CLK just before the falling edge of TXC1. Therefore, the receive side should latch TXD1 on the rising edge of TXC1.

<Synchronous Slave Mode>

In synchronous slave mode, the transmit clock is input externally, so ST1CLK is obtained by detecting edges synchronized to CLK. The transmit circuit synchronizes transmit data transfer to ST1CLK.

The start of a transmit operation is triggered by the signal that writes transmit data to S1BUF (WS1BUF: signal output when an instruction is executed that writes to S1BUF, like "STB A, S1BUF"). When WS1BUF is generated, after one clock (master clock) the signal to start the transmit operation (LST1SF) will be generated.

The falling edge of LST1SF transfers the contents of S1BUF to the SC1 Transmit Register.

The transmit operation will then start, setting the signal that indicates transmit operation in progress (ST1FREE) to a low level. When ST1FREE goes low, after a half clock bit 0 of the transmit data (LSB first) will be output from the TXD1 pin. Bit 1 of the transmit data is then output from the TXD1 pin after another half clock.

After the falling of LST1SF, synchronized to the signal that indicates the start of instruction execution (M1S1), a transmit interrupt request (TX1READY) will be generated, and the interrupt request flag (QSCI1) will be set ("1").

Then in accordance to the specification of SR1CON, transmit data and a parity bit will be output synchronized to TXC1 (that is, ST1CLK), completing transmission of one frame.

TXD1 will change a half clock after the falling edge of ST1CLK generated, after detecting the rising edge of TXC1 externally applied. Therefore, the receiving device should latch TXD1 on the rising edge of TXC1.







#### 13.2.2 Receive Operation

<Synchronous Master Mode>

In synchronous master mode, the clock pulse obtained by the Baud Rate Generator (S1TM) is frequency divided by four, generating the receive shift clock (SR1CLK) and receive data sampling clock.

The second pulse of the 4 divided clock will become the RXD1 pin's input sampling clock, and the third pulse will become SR1CLK. The receive circuit latches receive data synchronized to SR1CLK.

The start of a receive operation begins when the SR1REN bit of SR1CON is set to "1". This will set the signal that indicates receive operation in progress (SR1FREE) to a low level. When SR1FREE goes low, the receive shift clock will be output from the RXC1 pin synchronized to the next SR1CLK.

The next SR1CLK shifts the receive data that has been sampled just before into the SCI1 Receive Register. Receive data is sampled just once.

SR1CLK is generated after the rising edge of RXCT, and receive data is shifted into the SCI1 Receive Register. Therefore, the transmit side can send transmit data synchronized to the falling edge of RXC1. Then in accordance to the specification of SR1CON, receive data will be shifted in sequence into the SCI1 Receive Register synchronized to the receive clock output from RXC1.

When the last receive shift clock has been output, the receive end signal (LSR1BUF) will be generated synchronized to the next SR1CLK. When LSR1BUF is generated the contents of the SCI1 Receive Register (receive data) will be transferred to S1BUF. If there is an overrun error, the overrun error flag (OERR1) will be set "1", the receive interrupt request signal (RX1READY) will be generated synchronized to the signal that indicates the start of instruction execution (M1S1), and the interrupt request flag (QSCI1) will be set "1". Also, SR1FREE will go to a high level, and the SR1REN bit of SR1CON will be "0" to terminate the receive operation.

<Synchronous Slave Mode>

In synchronous slave mode, the start of a receive operation begins when the SR1REN bit of SR1CON is set high. This will set the signal that indicates receive operation in progress (SR1FREE) to a low level, which will accept the receive shift clock input from the RXC1 pin.

The receive shift clock SR1CLK is obtained by detecting the input signal's edges synchronized to CLK. Receive data control is synchronized to SR1CLK.

When the RXC1 pin goes from low to high, the receive shift clock SR1CLK will be generated by the edge detection circuit. When SR1CLK is generated, the receive data just sampled on the RXD1 pin will be shifted in to the SCI1 Receive Register.

RXD1 pin sampling is performed while the RXC1 pin is low. The shift into the SCI1 Receive Register occurs after the RXC1 pin rises, so the transmit side should send data synchronized to the falling edges of the transmit shift clock on the RXC1 pin.

Then in accordance to the specification of SR1CON, receive data will be shifted in sequence into the SCI1 Receive Register synchronized to the input receive clock. Finally SR1CLK is obtained from edge detection of the receive shift clock, and the last receive data is input. After a half clock, the receive end signal (LSR1BUF) will be generated.

When LSR1BUF is generated the contents of the SCI1 Receive Register (receive data) will be transferred to S1BUF. If there is an overrun error, the overrun error flag (OERR1) will be set ("1"), the receive interrupt request signal (RX1READY) will be generated synchronized to the signal that indicates the start of instruction execution (M1S1), and the interrupt request flag (QSCI1) will be set ("1"). Also, SR1FREE will go to a high level. The SR1REN bit of SR1CON will not become low at this time, so if the next receive shift clock is input then the receive operation will start again.



Figure 13-7 **Receive Synchronous Master** Mode Timing Chart Example

13 - 13

MSM66587 Family User's Manual Chapter 13 Serial Port Functions



3

- 14

### Chapter 14

## A/D Converter Functions

#### 14. A/D Converter Functions

The MSM66587 family provides an 8-bit resolution A/D converter with a four channel-analog input multiplexer.

The A/D converter uses a sample-and-hold successive comparison method for converting analog levels to digital data. The conversion result for the selected channel will be stored in the A/D Result Register.

Figure 14-1 shows the configuration of the A/D converter. Table 14-1 lists the SFRs for A/D converter control.



Figure 14-1 A/D Converter Configuration

| Table 14-1 A/D Converter Control SFRs |  |
|---------------------------------------|--|
|---------------------------------------|--|

| Address<br>[H] | Name                           | Symbol<br>(Byte) | R/W | Reset State |
|----------------|--------------------------------|------------------|-----|-------------|
| 002C☆          | A/D Interrupt Control Register | ADINTCON         | R/W | COH         |
| 00D0           | A/D Result Register 0          | ADCR0            | R   | undefind    |
| 00E1☆          | A/D Control Register High      | ADCONH           | R/W | 80H         |

Notes: 1. Addresses do not run consecutively.

2. Addresses in the address column marked by stars indicate that the register has bits missing.

#### 14.1 A/D Converter Configuration

(1) A/D Control Register High (ADCONH)

ADCONH is a 5-bit register that controls the A/D converter. Figure 14-2 shows the configuration of ADCONH. After reset ( $\overline{\text{RES}}$  signal input, BRK instruction execution, op code trap) ADCONH will be 80H.

[Bit Descriptions]

• ADSTM0, ADSTM1 (bit 0, bit1)

These bits specify the A/D conversion channel. The channel change should be performed after STS (bit 4) has been reset to "0". While STS is "1" (A/D conversion in progress), changes to the selected channel will not be effective.

• STS (bit 4)

This bit starts and stops A/D conversion. When this bit is set to 1, A/D conversion will be performed on the channel specified by ADSTM0-ADSTM1 (bit 0, bit 1). This bit will become "0" when A/D conversion finishes.

• ADTM0, ADTM1 (bit 5, bit 6)

These bits specify the number of clocks needed to perform A/D conversion on one channel. Changes to the clock count specification will not be effective during A/D conversion.

|             | 7 | 6     | 5     | 4   | 3   | 2   | 1        | 0      |                  |                 |                                                                                                                 |
|-------------|---|-------|-------|-----|-----|-----|----------|--------|------------------|-----------------|-----------------------------------------------------------------------------------------------------------------|
| ADCONH      | _ | ADTM1 | ADTM0 | STS | "0" | "0" | ADSTM1 / | ADSTMO | ]                |                 | Address : 00E1H                                                                                                 |
| Reset state | 1 | 0     | 0     | 0   | 0   | 0   | 0        | 0      |                  | F               | R/W access : R/W                                                                                                |
|             |   |       |       |     |     |     |          |        |                  |                 |                                                                                                                 |
|             |   |       |       |     |     |     |          |        | ADS <sup>*</sup> | т <u>м</u><br>0 | A/D Selected Channel                                                                                            |
|             |   |       |       |     |     |     |          |        | 0                | 0               | Channel O                                                                                                       |
|             |   |       |       |     |     |     |          |        | 0                | 1               | Channel 1                                                                                                       |
|             |   |       |       |     |     |     |          |        | 1                | 0               | Channel 2                                                                                                       |
|             |   |       |       |     |     |     |          |        | 1                | 1               | Channel 3                                                                                                       |
|             |   |       |       |     |     |     |          | [      | 0                | A/D             | conversion stopped                                                                                              |
|             |   |       |       |     |     |     |          |        | 1                | A/D             | conversion operating                                                                                            |
|             |   |       |       |     |     |     |          |        | ADT              | М<br>0          | Clock Count For A/D Conversion<br>Of One Channel (f = 20 MHz)                                                   |
|             |   |       |       |     |     |     |          |        | 0                | 0               | 384 CLK (19.2 μs)                                                                                               |
|             |   |       |       |     |     |     |          |        | 0                | 1               | 256 CLK (12.8 μs)                                                                                               |
|             |   |       |       |     |     |     |          |        | 1                | 0               | 192 CLK (9.6 μs)                                                                                                |
|             |   |       |       |     |     |     |          |        | 1                | 1               | 128 CLK (6.4 µs)                                                                                                |
|             |   |       |       |     |     |     |          |        | They<br>Alwa     | y will<br>ays w | tes bits that are not provided.<br>be read as "1".<br>rite "0" to the bits shown as "0".<br>always read as "0". |

| Eiguro 1/-2 | Configuration | of |        |
|-------------|---------------|----|--------|
| Figure 14-2 | Configuration | 01 | ADCONT |

(2) A/D Interrupt Control Register (ADINTCON)

ADINTCON is a 2-bit register that mainly controls interrupt requests generated by the A/D converter. Figure 14-3 shows the configuration of ADINTCON. After reset (RES signal input, BRK instruction execution, op code trap) ADINTCON will be C0H.

[Bit Descriptions]

• INTST (bit 1)

This bit indicates that A/D conversion has finished. When "1", A/D conversion has finished. This bit must be reset ("0") by the program.

• ADSTIE (bit 3)

This bit enables and disables interrupt requests generated by A/D conversion finishing. When "0", interrupt requests are disabled. When 1, interrupt requests are enabled.



#### Figure 14-3 Configuration of ADINTCON

(3) A/D Result Register (ADCR0)

The A/D Result Register stores the result of A/D conversion on the selected channel. Figure 14-4 shows the configuration of ADCR0. After reset (RES signal input, BRK instruction execution, op code trap) ADCR0 will be undefined.



Figure 14-4 Configuration of ADCR0

## Chapter 15

## **Peripheral Functions**

#### 15. Peripheral Functions

The MSM66587 family provides a clock out function for supplying a clock to peripheral devices.

#### 15.1 Clock Out Function

The clock out function outputs a clock pulse obtained by dividing the master clock from the CLKOUT pin (secondary function of port P7\_3). The frequency division of the master clock is specified by the Peripheral Control Register (PRPHF) lower 2 bits (bit 0 and bit 1). There are four master clock frequency division ratios: 1/4, 1/8, 1/16, and 1/32. The Port 7 Secondary Control Register bit 3 must be set ("1") to use the CLKOUT pin.

Figure 15-1 shows the configuration of PRPHF.



Figure 15-1 Configuration of PRPHF

### Chapter 16

## **External Interrupt Requests**

#### 16. External Interrupt Requests

The MSM66587 family provides five external interrupt requests of two types. There are four maskable interrupts (INT0-INT3), and one non-maskable interrupt (NMI).

INT0-INT3 are allocated as the secondary functions of Port 6's P6\_0 and P6\_1 and Port 12's P12\_2 and P12\_3. Therefore the appropriate bits in the Port 6 Secondary Control Register and Port 12 Secondary Control Register must be set ("1") to use INT0-INT3.

A dedicated pin (pin 35) is provided for NMI.

The effective edge of INT0-INT3 can be specified by the External Interrupt Control Register (EXICON). The edge specification is disabled and the "L" level is enabled, during the stop mode. The effective edge of NMI can be specified by the NMI Interrupt Control Register (NMICON).

After reset (RES signal input, BRK instruction execution, op code trap) EXICON will be 00H, setting the effective edge of INT0-INT3 to a low level. NMICON will be FCH or 7CH, setting its effective edge to the falling edge.

Figure 16-1 shows the configuration of EXICON, and Figure 16-2 shows the configuration of NMICON. Bit 7 of NMICON is the bit that monitors the NMI pin.

### MSM66587 Family User's Manual Chapter 16 External Interrupt Requests

|             | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |                 |          |                     |
|-------------|-------|-------|-------|-------|-------|-------|-------|-------|-----------------|----------|---------------------|
| EXICON      | EX3M1 | EX3M0 | EX2M1 | EX2M0 | EX1M1 | EX1M0 | EX0M1 | EX0M0 |                 |          | Address : 0109H     |
| Reset state | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |                 |          | R/W access : R/W    |
|             |       |       |       |       |       |       |       |       | EX(             | MC<br>0  | INTO Effective Edge |
|             |       |       |       |       |       |       |       |       | 0               | 0        | Low level           |
|             |       |       |       |       |       |       |       |       | 0               | 1        | Falling edge        |
|             |       |       |       |       |       |       |       |       | 1               | 0        | Rising edge         |
|             |       |       |       |       |       |       |       |       | 1               | 1        | Both edges          |
|             |       |       |       |       |       |       |       |       | EX <sup>-</sup> | 1 M<br>0 | INT1 Effective Edge |
|             |       |       |       |       |       |       |       |       | 0               | 0        | Low level           |
|             |       |       |       |       |       |       |       |       | 0               | 1        | Falling edge        |
|             |       |       |       |       |       |       |       |       | 1               | 0        | Rising edge         |
|             |       |       |       |       |       |       |       |       | 1               | 1        | Both edges          |
|             |       |       |       |       |       |       |       |       | EX              | 21/1     |                     |
|             |       |       |       |       |       |       |       |       | 1               | 0        | INT2 Effective Edge |
|             |       |       |       |       |       |       |       |       | 0               | 0        | Low level           |
|             |       |       |       |       |       |       |       |       | 0               | 1        | Falling edge        |
|             |       |       |       |       |       |       |       |       | 1               | 0        | Rising edge         |
|             |       |       |       |       |       |       |       |       | 1               | 1        | Both edges          |
|             |       |       |       |       |       |       |       |       | EX              |          | INT3 Effective Edge |
|             |       |       |       |       |       |       |       |       | 1               | 0        | -                   |
|             |       |       |       |       |       |       |       |       | 0               | 0        | Low level           |
|             | L     | I     |       |       |       |       |       |       | 0               | 1        | Falling edge        |
|             |       |       |       |       |       |       |       |       | 1               | 0        | Rising edge         |
|             |       |       |       |       |       |       |       |       | 1               | 1        | Both edges          |

Figure 16-1 Configuration of EXICON



— indicates bits that are not provided.

They will be read as "1".

Writes to bit 7 will be ignored.

\* indicates "0" or "1".

The value after reset will be determined by the NMI pin level.

#### Figure 16-2 Configuration of NMICON

### Chapter 17

# Interrupt Request Processing

#### 17. Interrupt Request Processing

The M66587 family provides 13 interrupt source types, 5 external and 9 internal, each of which is assigned a vector. One of the external interrupts is a non-maskable interrupt. Also, the 13 maskable interrupts can be set to three levels of interrupt priority.

Table 17-1 lists the interrupt control SFRs.

| Address [H] | Name                                   | Symbol (Byte) | Symbol (Word) | R/W | Reset State |
|-------------|----------------------------------------|---------------|---------------|-----|-------------|
| 0040☆       | Interrupt Request Register 0           | IRQOL         |               |     | 00          |
| 0041☆       |                                        | IRQ0H         | IRQO          |     | 00          |
| 0042☆       | Interrupt Request Register 1           | IRQ1L         | —             |     | 00          |
| 0044☆       | Interrupt Enable Register 0            | IEOL          | 150           |     | 00          |
| 0045☆       |                                        | IE0H          | IEO           |     | 00          |
| 0046☆       | Interrupt Enable Register 1            | IE1L          | _             | R/W | 00          |
| 0048☆       | Interrupt Priority Control Register 00 | IP00L         | 1000          |     | 00          |
| 0049☆       | interrupt Frionty Control Negister 00  | IP00H         | IP00          |     | 00          |
| 004A☆       | Interrupt Priority Control Register 01 | IP01L         | - IP01        |     | 00          |
| 004B☆       |                                        | IP01H         | IFUI          |     | 00          |
| 004C☆       | Interrupt Priority Control Register 10 | IP10L         | —             |     | 00          |
| 004E☆       | Interrupt Priority Control Register 11 | IP11L         | —             |     | 00          |
| 010C☆       | Interrupt Request Register 2           | IRQ2L         | —             |     | 00          |
| 010D☆       | Interrupt Enable Register 2            | IE2L          | —             |     | 00          |
| 010E☆       | Interrupt Priority Control Register 20 | IP20L         | —             |     | 00          |
| 010F☆       | Interrupt Priority Control Register 21 | IP21L         |               |     | 00          |
| 0108☆       | NMI Control Register                   | NMICON        | —             |     | FC or 7C    |
| 0109☆       | External Interrupt Control Register    | EXICON        |               |     | 00          |

#### Table 17-1 Interrupt Control SFRs

Notes: 1. Addresses do not run consecutively.

2. Addresses in the address column marked by stars indicate that the register has bits missing.

#### 17.1 Non-Maskable Interrupt (NMI)

The NMI interrupt cannot be masked. When the effective edge, specified by NMICON bit 0 and bit 1, is detected, the CPU will immediately shift to the NMI interrupt process.

However, there is a single exception. <u>The NMI interrupt will be masked after reset (RES signal input, BRK instruction execution, op code trap) until the first instruction has completely executed.</u> This function is provided to remove the possibility that an NMI interrupt could be accepted before the System Stack Pointer (SSP) has an appropriate value after reset. The program can eliminate that possibility by using an instruction that sets SSP to an appropriate value as the first instruction after reset.

The following process will be performed in hardware automatically when an NMI interrupt occurs.

- Save Program Counter (PC).
- Save Accumulator (ACC).
- Save Local Register Base (LRB).
- Save Program Status Word (PSW).
- Reset NMI Interrupt Request Flag.
- Disable acceptance of maskable interrupts.
- Disable a multiple occurrence of the NMI interrupt itself.
- Load the value written in the vector table (0008H, 0009H) into the program counter.

Fourteen cycle are required to shift to each of these NMI process. However, if the program memory space is 1MB, 17 cycle are required because cycles required to save the code segment register (CSR) are added.

An RTI instruction is needed at the end of the NMI interrupt routine. The following process will be performed in hardware automatically when the RTI instruction is executed.

- Restore Program Status Word (PSW).
- Restore Local Register Base (LRB).
- Restore Accumulator (ACC).
- Restore Program Counter (PC).
- Enable acceptance of maskable interrupts.
- Enable further NMI interrupts.

This completes the NMI interrupt routine.

Note: When program memory space has been expanded to 1MB, the Code Segment Register (CSR) will be saved and restored in addition to the other registers listed above.

Figure 17-1 shows examples of saving and restoring PC, ACC, LRB, and PSW.

• Interrupt process (when program memory space is 64KB)





Figure 17-1 Examples of Saving and Restoring PC, ACC, LRB and PSW

#### 17.2 Maskable Interrupts

Maskable interrupts are generated by internal peripheral hardware and external pin inputs. Maskable interrupt control is performed with the following.

- Registers set when an interrupt request is generated by each interrupt factor (IRQ)
- Registers that enable interrupts provided by each factor (IE)
- Flag that enables/disables interrupt generation from all maskable interrupts (MIE)
- Flag that enables/disables all priorities (MIP)
- Registers that set priority levels (IP)

Figure 17-2 shows a conceptual diagram of maskable interrupt control. Table 17-2 lists the maskable interrupt vector addresses and bit symbols.

[One interrupt vector for one interrupt factor]



[One interrupt vector for two interrupt factors]



Contents of dotted rectangle exist as a single function block.

#### Figure 17-2 Conceptual Diagram of Maskable Interrupts

| bit | Interrupt Factor                   | Vector Addres | IRQ    | IE     | IPX0    | IPX1    |
|-----|------------------------------------|---------------|--------|--------|---------|---------|
| 0   | External interrupt 0 (INT0)        | 000A          | QINTO  | EINTO  | P0INT0  | P1INT0  |
| 2   | TM1 overflow                       | 000E          | QTM10V | ETM10V | P0TM10V | P1TM10V |
| 11  | RT08 event generation              | 0020          | QRT08  | ERT08  | PORTO8  | P1RT08  |
| 12  | RT09 event generation              | 0022          | QRT09  | ERT09  | PORTO9  | P1RT09  |
| 15  | Serial port transmit/receive ready | 0028          | QSCI1  | ESCI1  | POSCI1  | P1SCI1  |
| 16  | S1TM overflow                      | 002A          | QSTMOV | ESTMOV | POSTMOV | P1STMOV |
| 17  | GTMC overflow                      | 002C          | QGTMOV | EGTMOV | POGTMOV | P1GTMOV |
| 19  | A/D conversion finished            | 0030          | QAD    | EAD    | P0AD    | P1AD    |
| 20  | PWC0 underflow or match            | 0032          | QPW01  | EPW01  | P0PW01  | P1PW01  |
| 23  | External interrupt 1 (INT1)        | 0038          | QINT1  | EINT1  | P0INT1  | P1INT1  |
| 34  | External interrupt 2 (INT2)        | 006E          | QINT2  | EINT2  | P0INT2  | P1INT2  |
| 35  | External interrupt 3 (INT3)        | 0070          | QINT3  | EINT3  | P0INT3  | P1INT3  |

| Table 17-2 Maskable Interrupt Ve | ector Addresses and Bit Symbols |
|----------------------------------|---------------------------------|
|----------------------------------|---------------------------------|

(1) Interrupt Request Registers IRQ (IRQ0L, IRQ0H, IRQ1L)

IRQ are registers that save interrupt requests. Each IRQ becomes "1" when an interrupt signal is generated from an interrupt source, and becomes 0 during the interrupt transition cycle when the interrupt is accepted. IRQ bits can also be set to "0" or "1" by the program.

(2) Interrupt Enable Registers IE (IE0L, IE0H, IE1L)

IE are registers that enable/disable generation of individual interrupts. When an IE bit is "0", generation of the corresponding interrupt will be disabled. When an IE bit is "1", generation of all the interrupts independently enabled by IE will be enabled.

(3) Master Interrupt Enable Flag MIE

MIE is a 1-bit flag in PSW. MIE enables/disables generation of all maskable interrupts. When MIE is "0", generation of all maskable interrupts will be disabled. When MIE is "1", generation of all the interrupts independently enabled by IE will be enabled.

(4) Master Interrupt Priority Flag MIP

MIP is a 1-bit flag in PSW. MIP enables/disables all maskable interrupt priorities. When MIP is "0", priorities set by IPX0 and IPX1 will be disabled, so interrupt generation will be controlled by IE and MIE only. When MIP is "1", all maskable interrupts are given priority levels 0-3 by IPX0 and IPX1.

(5) Interrupt Priority Control Registers IPX0 (IP00L, IP00H, IP10L) IPX1 (IP01L, IP01H)

IPX0 and IPX1 specify maskable interrupt priorities. When a maskable interrupt's corresponding IPX0 and IPX1 bits are PX0xxx and PX1xxx, the priority given to that maskable interrupt will be as follows.

| PX1xxx | PX0xxx | Pr      | iority   |
|--------|--------|---------|----------|
| 0      | 0      | Level 0 | (low)    |
| 0      | 1      | Level 1 | <b>‡</b> |
| 1      | *      | Level 2 | (high)   |

\* indicates "0" or "1"

#### 17.3 Maskable Interrupt Operation

Generation of an interrupt signal causes an interrupt request to be passed to interrupt priority selection logic by the following operation.

- An interrupt request signal is output from the interrupt source.
- When the IRQ bit becomes "1", if either the corresponding IE bit or MIE in PSW is "1", then the interrupt will be held off. When the IRQ bit becomes "1", if both the corresponding IE bit and MIE in PSW is "1", then the interrupt priority selection logic will operate.

The interrupt priority selection logic operates as follows.

- If MIP in PSW is "0", then the interrupt priority selection logic will not operate, and the interrupt will be generated immediately. If MIP in PSW is "1", then the interrupt will be given a priority from one of three levels (level 0 to level 2) by the corresponding IPX0 and IPX1 bits.
- If no other interrupt is being executed at the time the interrupt request is sent to the interrupt priority selection logic, then the interrupt will be generated immediately.
- If one or more other interrupts are already being executed at the time the interrupt request is sent to the interrupt priority selection logic, and if the new interrupt has a higher priority level than any of the executing interrupts, then the interrupt will be generated immediately.
- If one or more other interrupts are already being executed at the time the interrupt request is sent to the interrupt priority selection logic, and if the new interrupt has a lower priority level than any of the executing interrupts, then the interrupt will be held off.

| Generated<br>Process Interrupt<br>Being Executed | Loval O Interrunt         | Level 1 Interrupt<br>Request | Level 2 Interrupt<br>Request | NMI Interrupt<br>Request           |
|--------------------------------------------------|---------------------------|------------------------------|------------------------------|------------------------------------|
| No interrupt process                             | O : Interrupt generated   | O : Interrupt generated      | O : Interrupt generated      | $\mathbf{O}$ : Interrupt generated |
| Level 0 interrupt process                        | $\times$ : Interrupt held | O : Interrupt generated      | O : Interrupt generated      | O : Interrupt generated            |
| Level 1 interrupt process                        | $\times$ : Interrupt held | $\times$ : Interrupt held    | O:Interrupt generated        | O : Interrupt generated            |
| Level 2 interrupt process                        | $\times$ : Interrupt held | $\times$ : Interrupt held    | imes : Interrupt held        | O : Interrupt generated            |
| NMI interrupt process                            | $\times$ : Interrupt held | $\times$ : Interrupt held    | imes : Interrupt held        | $\times$ : Interrupt held          |

Note: When interrupts are generated simultaneously, the one with higher priority will have precedence. When interrupts of the same priority are generated simultaneously, the one with the lower interrupt vector address will have precedence.

The following process will be performed in hardware automatically when a maskable interrupt occurs.

- Save Program Counter (PC).
- Save Accumulator (ACC).
- Save Local Register Base (LRB).
- Save Program Status Word (PSW).
- Reset the IRQ that generated the maskable interrupt process.
- Reset MIE in PSW (disable acceptance of maskable interrupts).
- Record interrupt priority level (disable acceptance of interrupts with equal or lower priority).
- Load the value written in the vector table into the program counter.

Fourteen cycle are required to shift to each maskable interrupt process. However, if the program memory space is 1MB, 17 cycles are required because cycles required to save the code segment register (CSR) are added.

An RTI instruction is needed at the end of the maskable interrupt routine. The following process will be performed in hardware automatically when the RTI instruction is executed.

- The highest priority level in the stored interrupt levels is deleted.
- Restore Program Status Word (PSW), also setting MIE to 1.
- Restore Local Register Base (LRB).
- Restore Accumulator (ACC).
- Restore Program Counter (PC).

This completes the maskable interrupt routine.

Note: When program memory space has been expanded to 1MB, the Code Segment Register (CSR) will be saved and restored in addition to the other registers listed above.

Figure 17-1 shows an example of saving and restoring PC, ACC, LRB, and PSW.

## Chapter 18

## **Bus Port Functions**

18

#### 18. Bus Port Functions

External program memory (normally ROM) can be expanded up to 1MB. External data memory (normally RAM) can be expanded up to 1MB.

Port 0 (P0), Port 1 (P1), and Port 9 (P9\_0-P9\_3) are used as bus ports to access both external program memory and external data memory.

#### 18.1 Bus Port (P0, P1, P9\_0-P9\_3) Functions

P0, P1, and P9\_0-P9\_3 serve as input/output ports for their primary function, and as bus ports for their secondary function.

Switching of P0 between its primary and secondary function is performed automatically depending on the object to be accessed (internal or external memory, program or data memory).

Switching of P1 and P9\_0-P9\_3 between their primary and secondary function is performed automatically when the  $\overline{EA}$  pin is low, but their secondary registers must be set when the  $\overline{EA}$  pin is high.

#### 18.1.1 P0, P1, P9\_0-P9\_3 Operation During Program Memory Access

When internal program memory is accessed (when EA pin is high) P0, P1, and P9\_0-P9\_3 operate as input/output ports.

When external program memory is accessed (when EA pin is low) P0 operates as the port for low address outputs and program data input, and P1 and P9\_0-P9\_3 operate as the ports for high address outputs.

Table 18-1 lists the operations of P0, P1, and P9\_0-P9\_3 during program memory accesses.

#### Table 18-1 P0, P1, P9\_0-P9\_3 Operation During Program Memory Accesses

|               | Access           | Object            | D0 On exetien                                    | P1, P9_0-P9_3           |  |
|---------------|------------------|-------------------|--------------------------------------------------|-------------------------|--|
| <b>EA</b> pin | Memory Address   |                   | P0 Operation                                     | Operation               |  |
| High          | Internal program | Note 1            | Input/output port                                |                         |  |
| Low           | External program | 00000H-<br>FFFFDH | Low address<br>outputs and program<br>data input | High address<br>outputs |  |

Note 1. The external program memory area is 10000H-FFFFDH. To access this area, the secondary registers of P1 and P9 (P1SF, P9SF) must be set.

#### 18.1.2 P0, P1, P9\_0-P9\_3 Operation During Data Memory Access

When internal data memory is accessed (when access object is 0000H-9FFH) P0, P1 and P9\_0-P9\_3 operate as input/output ports.

When external data memory is accessed (access object is A00H-FFFFH) P0 operates as the port for low address outputs and data input/output. P1 and P9\_0-P9\_3 operates as the port for high address outputs only for pins that have been set ("1") in the Port 1 and Port 9 Secondary Control Registers. P1 and P9\_0-P9\_3 operates as an input/output port for pins that have been reset ("0") in the Port 1 and Port 9 Secondary Control Registers. However, if the EA pin is low, then P1 and P9\_0-P9\_3 will operate as the port for high address outputs regardless of the Port 1 and Port 9 Secondary Control Registers.

Table 18-2 lists the operations of P0, P1 and P9\_0-P9\_3 during data memory accesses.

| Access        | Object      | P0                                              | P1, P9_0-P9_3                            |  |
|---------------|-------------|-------------------------------------------------|------------------------------------------|--|
| Memory        | Address     | Operation                                       | Operation When<br>Secondary Function Set |  |
| Internal data | 0000H-9FFH  | Input/output port                               |                                          |  |
| External data | A00H-FFFFFH | Low address<br>outputs and data<br>input/output | High address<br>outputs                  |  |

Table 18-2 P0, P1 , P9\_0-P9\_3 Operation During Data Memory Accesses

#### 18.2 External Memory Access

#### 18.2.1 External Program Memory Access

Program space up to 1MB (0000H-FFFFDH) can be accessed by the 16-bit Program Counter (PC) and 4-bit Code Segment Register (CSR). When the  $\overline{EA}$  pin has been set to a high level, external program memory is accessed at program addresses 10000H-FFFFDH. When the  $\overline{EA}$  pin has been set to a low level, external program memory is accessed at program addresses 00000H-FFFFDH.

When EA is set high and 10000H-FFFFDH (for MSM66586, C000-FFFFDH) is used for external program memory, the Port 1 Secondary Control Register and Port 9 Secondary Control Register (high address outputs) need to be set. The Port 5 Secondary Control Register (ALE and PSEN outputs) also needs to be set.



Figure 18-1 shows a external program memory (ROM) interface example

Figure 18-1 External ROM Interface Example

#### 18.2.2 External Program Memory Access Timing

Figure 18-2 and Figure 18-3 show external program memory access timing diagrams.

A function for inserting wait cycles (see Section 5.2, "Ready Function") is provided for external memory with slow access time. It should be implemented to match the access time of the external memory used. However, relative to internal program memory accesses, one cycle is inserted automatically for each byte accessed during external program memory accesses. ROMRDY is a register that specifies further cycles to be inserted in addition to the one cycle inserted automatically.

Refer to Chapter 20, "Electrical Characteristics," for actual AC characteristics.



Figure 18-2 External Program Memory Access Timing Diagram (No Waits)



Figure 18-3 External Program Memory Access Timing Diagram (2 Wait Cycles)

#### 18.2.3 External Data Memory Access

Data space up to 1MB (00000H-FFFFFH) can be accessed by the 16-bit Program Counter (PC) and 4-bit Data Segment Register (DSR). When data addresses 0000H-9FFH are accessed, internal data memory will be accessed. When data addresses A00H-FFFFFH are accessed, external data memory will be accessed. However, external data memory will be accessed in 8-bit units (bytes).

To use external data memory, the Port 1 and Port 9 Secondary Control Registers (high address outputs) must be set in accordance with external memory addresses. Also, the Port 5 Secondary Control Register bit 5 (ALE output) and Port 7 Secondary Control Register bit 0 and bit 1 ( $\overline{WR}$  and  $\overline{RD}$  outputs) must be set ("1"). However, when the  $\overline{EA}$  pin is low, P1, P9 and P5\_5 will switch to high address outputs and ALE output regardless of the Secondary Control Registers.

Add external pull-up resistors to the  $\overline{\text{WR}}$  and  $\overline{\text{RD}}$  pins as necessary.

Figure 18-4 shows a data memory (RAM) interface example.



Figure 18-4 External RAM Interface Example

#### 18.2.4 External Data Memory Access Timing

Figure 18-5 and Figure 18-6 show external data memory access timing diagrams.

A function for inserting wait cycles (see Section 5.2, "Ready Function") is provided for external memory with slow access time. It should be implemented to match the access time of the external memory used. However, relative to internal data memory accesses, three or four cycles are inserted automatically for each byte accessed during external data memory accesses. RAMRDY is a register that specifies further cycles to be inserted in addition to the three or four cycles inserted automatically.

Refer to Chapter 20, "Electrical Characteristics," for actual AC characteristics.



Figure 18-5 External Data Memory Access Timing Diagram (No Waits)



Figure 18-6 External Data Memory Access Timing Diagram (2 Wait Cycles)

## Chapter 19

# Flash Memory

19

#### 19. Flash Memory

#### 19.1 Summary

The MSM66Q587 replaces the internal program memory (64KB mask-ROM) of the MSM66587 with an electrically erasable and reprogrammable non-volatile memory (64KB flash memory). With two types of flash memory reprogramming modes, the program memory can be reprogrammed even after installation in the system.

#### 19.2 Features

Power supply voltage

The flash memory is reprogrammable and read by a single 5 V power supply (4.5 to 5.5 V).

• Reprogramming modes

There are two types of flash memory reprogramming modes.

- Serial mode (reprogramming is possible before and after installation on the circuit board)
- User mode (reprogramming is possible after installation on the circuit board)
- Erasure block

The flash memory is erased in 1KB blocks (erasure of a sector).

• Reprogramming and erasing time

The reprogramming and erasing time of the flash memory is as follows:

- Page reprogramming (64-byte units) ... 3 ms
- Sector erasure (1KB units)..... 10 ms
- Write protect function

The flash memory contains a built-in supply voltage sense and reset function that automatically triggers a reset if the supply voltage drops to 2 V or lower, and a built-in power-on delay function that automatically inhibits reprogramming for approximately 20 ms when power is turned on.

In addition, there is an acceptor function to prevent accidental programming or erasing if the program runs out of control when in the user mode.

#### 19.3 Reprogramming Modes

The flash memory of the MSM66Q587 has the following two reprogramming modes:

#### (1) Serial Mode

In this mode, reprogramming is performed on the system or using a single microprocessor. The serial mode is used mainly for the development of user software.

In the serial mode, reprogramming is performed while the microprocessor is being reset or is in the stop mode. OKI flash memory writer (model no. PW66K) is used to perform the reprogramming.

#### (2) User Mode

In this mode, reprogramming is performed by the system. The user mode is used mainly in the development of user software. This mode is also used for final adjustments after product assembly, or for program maintenance after shipping.

In the user mode, reprogramming is performed by microprocessor operation, a program for reprogramming must be stored in advance in ROM using the serial mode.

Figure 19-1 shows a block diagram of the flash memory reprogramming modes.



Figure 19-1 Reprogramming Modes Block Diagram

#### 19.4 Serial Mode

#### 19.4.1 Serial Mode Summary

In the serial mode, reprogramming is possible either after installation on a circuit board or using a single microprocessor.

A flash memory writer (PW66K) dedicated for use with the serial mode is used to perform the reprogramming.

Reprogramming is performed in the serial mode while the CPU is being reset or is in the STOP mode.

19.4.2 Setting the Serial Mode

Specified pins are connected to the flash memory writer. The serial mode is automatically set by performing a reprogramming or read operation. When the write or read operation is completed, the setting is canceled.

(1) Pins Used for Serial Mode

Table 19-1 lists the pins used in the serial mode.

The serial mode can only be set while the CPU is being reset or is in the STOP mode. A high voltage from the flash memory writer is applied to the  $\overline{\text{EA}}$  pin to set the serial mode. Therefore, be careful of this pin. V<sub>DD</sub> is connected so that the V<sub>DD</sub> of the user's system can be monitored.

| Pin Number        | Primary Function Name | Flash Memory Function Name                     |
|-------------------|-----------------------|------------------------------------------------|
| 32                | P8_6                  | FLACLK (serial clock input)                    |
| 33                | P8_7                  | FLADAT (serial data I/O)                       |
| 36                | ĒĀ                    | FLAMOD (high voltage input to set serial mode) |
| 9, 17, 37, 67, 93 | V <sub>DD</sub>       | Monitoring V <sub>DD</sub> of user's system    |
| 16, 40, 68, 94    | GND                   | Ground                                         |

Table 19-1 Pins Used for Serial Mode

Note: During the serial mode, a high voltage that is greater than the supply voltage (approximately 11 V) is applied to the EA pin.

#### (2) Serial Mode Connections

With the serial mode, it is necessary to connect the flash memory writer (PW66K) to pins P8\_6, P8\_7,  $\overline{EA}$ ,  $V_{DD}$  and GND of the MSM66Q587 of the user's system. Install a switch on the user's system to isolate the flash memory when reprogramming and reading in the serial mode.

Figure 19-2 shows serial mode connection circuit example 1.



Figure 19-2 Serial Mode Connection Circuit Example 1

If a switch cannot be installed on the user's system, instead of using the P8\_6 and P8\_7 pins with the user's system, connect them only to the flash memory writer. Also, connect each of the P8\_6, P8\_7, and  $\overline{EA}$  pins to V<sub>DD</sub> through a resistor of approximately 100 k $\Omega$ .

Figure 19-3 shows the 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 memory writer does not apply "L" level to the  $\overline{\text{RES}}$  pin, the "L" level should be applied by the user application system.



#### Figure 19-3 Serial Mode Connection Circuit Example 2

(3) Serial Mode Reprogramming Method

The serial mode reprograms flash memory with the flash memory writer (PW66K). If reprogramming is to be performed with only a single microprocessor, use the attached FWADP66587 write adapter.

The procedure for reprogramming with the flash memory writer is listed below. Refer to the PW66K User's Manual for details.

- 1) Connect the flash memory writer to pins P8\_6, P8\_7, EA, V<sub>DD</sub> and GND.
- 2) Set the microprocessor to RESET or STOP mode.
- A flash memory writer protocol error will occur if not in the reset or STOP modes.
- 3) Perform the reprogram or read operation with the flash memory writer.
  - The serial mode will automatically be set.
- 4) Verify that normal operation of the flash memory writer has ended.
  - The serial mode is automatically canceled.
- 5) Cancel RESET or STOP mode.
  - The CPU executes the program reprogrammed into the flash memory.
- (4) Notes Regarding Serial Mode Usage

If reprogramming while in the STOP mode, during the reprogramming operation, do not generate an interrupt or do not initiate a reset using  $\overline{\text{RES}}$  pin input. (After the serial mode is canceled, the CPU may run out of control.)

If an interrupt or reset has been initiated, reprogram the program in flash memory.

#### 19.5 User Mode

#### 19.5.1 User Mode Summary

The user mode reprograms the flash memory from the user's system. Reprogramming is possible after the microprocessor is mounted on the user's system.

The user mode executes program to reprogram flash memory. The program is devised in advance to contain commands that execute reprogramming and a method of I/O for the reprogramming data.

It is necessary for the program to be written into the flash memory in advance in the serial mode or in the parallel mode.

Figure 19-4 shows a block diagram of the user mode.



Figure 19-4 User Mode Block Diagram

#### 19.5.2 User Mode Reprogramming

The MSM66Q587 contains special function registers (SFRs) for reprogramming with the user mode.

The flash memory control register (FLACON), flash memory address register (FLAADRS), and flash memory acceptor (FLAACP) are controlled to perform reprogramming operations in the user mode.

Table 19-2 lists a summary of the user mode SFRs.

| Address (U) | Name                          | Abbreviation | Abbreviation | R/W         | 8/16      | Reset     |
|-------------|-------------------------------|--------------|--------------|-------------|-----------|-----------|
| Address (H) | Name                          | (BYTE)       | (WORD)       | <b>H/ W</b> | operation | status    |
| 01F0☆       | Flash memory acceptor         | FLAACP       | —            | W           | 8         | "0"       |
| 01F1☆       | Flash memory control register | FLACON       | —            | R/W         | 8         | 0E4       |
| 01F2☆       | Elach mamory address register |              | FLAADRS      | R/W         | 16        | Undefined |
| 01F3        | Flash memory address register |              | FLAADHO      | r/ W        | 10        | Undenned  |

#### Table 19-2 User Mode SFRs

Note: The symbol  $\doteqdot$  in the above addresses indicates a missing bit.

(1) Flash Memory Address Register (FLAADRS)

Bits 6 to 15 (FA6 to 15) of the FLAADRS register set the address of reprogramming or sector erasure for the flash memory when performing reprogramming or sector erasure.

Figure 19-5 shows the FLAADRS configuration.

#### FLAADRS

|   | 15   | 14 | 4  | 13   | 12  | ) | 11   | 10  |   | 9   | 8   |    | 7  | 6   | 5 | 4 | 3 | 2  | 1       | 0     |
|---|------|----|----|------|-----|---|------|-----|---|-----|-----|----|----|-----|---|---|---|----|---------|-------|
|   | FA15 | FA | 14 | FA13 | FA1 | 2 | FA11 | FA1 | 0 | FA9 | FA8 | E. | A7 | FA6 | _ |   | _ |    |         |       |
| _ |      |    |    |      |     |   |      |     |   |     |     |    |    |     |   |   |   | Ac | ddress: | 01F2H |

R/W access: R/W

|                           |              |                     |                                                          | Reprogramming                                                               |                                                   |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|---------------------------|--------------|---------------------|----------------------------------------------------------|-----------------------------------------------------------------------------|---------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 15 14 13 12 11 10 9 8 7 6 |              |                     |                                                          |                                                                             |                                                   |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                      | 6                                                                                                                                                                                                                                                                                                                                                                                            | address                                                                                                                                                                                                                                                                                                                                                                                                                |  |
| 0                         | 0            | 0                   | 0                                                        | 0                                                                           | 0                                                 | 0                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                            | 0000H-003FH                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 0                         | 0            | 0                   | 0                                                        | 0                                                                           | 0                                                 | 0                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                    | 1                                                                                                                                                                                                                                                                                                                                                                                            | 0040H-007FH                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 0                         | 0            | 0                   | 0                                                        | 0                                                                           | 0                                                 | 0                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                            | 0080H-00BFH                                                                                                                                                                                                                                                                                                                                                                                                            |  |
|                           |              |                     |                                                          |                                                                             |                                                   |                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
| 1                         | 1            | 1                   | 1                                                        | 1                                                                           | 1                                                 | 1                                                                                                                                                                                                                                                                    | 1                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                    | 0                                                                                                                                                                                                                                                                                                                                                                                            | OFF80H-0FFBFH                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 1                         | 1            | 1                   | 1                                                        | 1                                                                           | 1                                                 | 1                                                                                                                                                                                                                                                                    | 1                                                                                                                                                                                                                                                                                                                                | 1                                                                                                                                                                                                                                                                                                                                                    | 1                                                                                                                                                                                                                                                                                                                                                                                            | OFFCOH-OFFFFH                                                                                                                                                                                                                                                                                                                                                                                                          |  |
|                           | 15<br>0<br>0 | 15 14<br>0 0<br>0 0 | 15     14     13       0     0     0       0     0     0 | 15     14     13     12       0     0     0     0       0     0     0     0 | FA1<br>15 14 13 12 11<br>0 0 0 0 0 0<br>0 0 0 0 0 | FA15-6           15         14         13         12         11         10           0         0         0         0         0         0           0         0         0         0         0         0           0         0         0         0         0         0 | FA15-6           15         14         13         12         11         10         9           0         0         0         0         0         0         0           0         0         0         0         0         0         0         0           0         0         0         0         0         0         0         0 | FA15-6           15         14         13         12         11         10         9         8           0         0         0         0         0         0         0         0           0         0         0         0         0         0         0         0           0         0         0         0         0         0         0         0 | FA15-6           15         14         13         12         11         10         9         8         7           0         0         0         0         0         0         0         0         0           0         0         0         0         0         0         0         0         0           0         0         0         0         0         0         0         0         0 | FA15-6         15       14       13       12       11       10       9       8       7       6         0       0       0       0       0       0       0       0       0       0         0       0       0       0       0       0       0       0       1       0         0       0       0       0       0       0       0       1       0         0       0       0       0       0       0       0       1       0 |  |

#### When Performing Reprogramming

#### When Performing Sector erasure

|   |             |   |   |   | FA1   | 5-6 |   | Sector erasure address |   |   |                        |
|---|-------------|---|---|---|-------|-----|---|------------------------|---|---|------------------------|
|   | 15 14 13 12 |   |   |   | 11 10 |     | 9 | 8                      | 7 | 6 | Sector erasure address |
|   | 0           | 0 | 0 | 0 | 0     | 0   | * | *                      | * | * | 0000H-03FH             |
| - | 0           | 0 | 0 | 0 | 0     | 1   | * | *                      | * | * | 0400H-07FH             |
|   | 0           | 0 | 0 | 0 | 1     | 0   | * | *                      | * | * | 0800H-0BFH             |
|   |             |   |   |   |       |     |   |                        |   |   |                        |
|   | 1           | 1 | 1 | 1 | 1     | 0   | * | *                      | * | * | 0F800H-0FBFFH          |
|   | 1           | 1 | 1 | 1 | 1     | 1   | * | *                      | * | * | OFCOOH-OFFFFH          |

Note: **\*** indicates "0" or "1".

"-" indicates bits that do not exist. When read, read as "1".

#### Figure 19-5 FLAADRS Configuration

(2) Flash Memory Acceptor (FLAACP)

The FLAACP is an acceptor used when data is set in the flash memory control register. By writing the values n5H and nAH (n = 0 to F) consecutively, the acceptor is set to "1". It is reset to "0" when the flash memory is reprogrammed or erased.

The FLAACP configuration is shown in figure 19-6.



Figure 19-6 FLAACP Configuration

(3) Flash Memory Control Register (FLACON)

FLACON is a 4-bit register used to control reprogramming and erasing of the flash memory.

The FLACON configuration is shown in figure 19-7.



"-" indicates bits that do not exist. When read, read as "1".

Figure 19-7 FLACON Configuration

Writing to the FLACON register is enabled after n5H and nAH (n = 0 to F) are written consecutively to the FLAACP and the flash memory acceptor is set to "1". The FLAACP register is reset to "0" after reprogramming or erasing flash memory. When another reprogramming or erasing operation is performed on flash memory, the flash memory acceptor must be set to "1" again.

#### • PRG (bit 0)

After PRG (bit 0) of the FLACON register is set to "1" and one instruction is executed, the CPU enters a HOLD state, and the data in the RAM address area of 300H to 33FH is transferred to the flash memory and the reprogramming is executed.

When the reprogramming is complete, the HOLD state is canceled and this bit is reset to "0". <u>Previously set the reprogramming address and data to the FLAADRS register and the internal</u> <u>RAM address area of 300H to 33FH.</u>

Notes: If an interrupt occurs during reprogramming the flash memory, the interrupt processing will be postponed until after the reprogramming is complete. While reprogramming the flash memory, if the RES pin input asserts a reset, the reset

processing will be postponed until after the reprogramming is complete.



Figure 19-8 shows the relation between internal RAM and flash memory.

Figure 19-8 Relation between Internal RAM and Flash Memory

#### • SERS (bit 1)

After SERS (bit 1) of the FLACON register is set to "1" and one instruction is executed, the CPU enters a HOLD state, and a sector of flash memory is erased (1KB).

When the erasing is complete, the HOLD state is canceled and this bit is reset to "0". <u>Set the</u> address to be erased to the FLAADRS register in advance.

Notes: If an interrupt occurs while the flash memory is being erased, the interrupt processing is postponed until after the erase operation is complete. While erasing the flash memory, if the RES pin input asserts a reset, the reset processing will be postponed until after the erase operation is complete.

#### • FCLK0, 1 (bits 3, 4)

FCLK0 (bit 3) and FCLK1 (bit 4) of the FLACON register are bits to set the clock division ratio (flash memory control CLK) to control the necessary wait time (CPU hold time) when erasing or reprogramming the flash memory. At reset, since FCLK0 and FCLK1 are cleared to "0", 1/16 CLK is selected as the flash memory control CLK. Flash memory erasure and reprogramming times for each original frequency are shown in tables 19-3 and 19-4 respectively.

| FC | LK | Erasure time (msec) |                 |      |      |                 |                 |                 |  |  |  |  |
|----|----|---------------------|-----------------|------|------|-----------------|-----------------|-----------------|--|--|--|--|
| 1  | 0  | CLK =<br>5 MHz      | CLK =<br>10 MHz |      |      | CLK =<br>16 MHz | CLK =<br>18 MHz | CLK =<br>20 MHz |  |  |  |  |
| 0  | 0  | 25.0                | 17.0            | 15.7 | 14.7 | 14.0            | 13.4            | 13.0            |  |  |  |  |
| 0  | 1  | 17.0                | 13.0            | 12.3 | 11.9 | 11.5            | 11.2            | 11.0            |  |  |  |  |
| 1  | 0  | 13.0                | 11.0            | 10.7 | 10.4 | 10.3            | 10.1            | 10.0            |  |  |  |  |
| 1  | 1  | 11.0                | 10.0            | 9.8  | 9.7  | 9.6             | 9.6             | 9.3             |  |  |  |  |

| Table 19-3 | Flash M | Memory | Erasure | Time |
|------------|---------|--------|---------|------|
|------------|---------|--------|---------|------|

Set FCLK0 and FCLK1 such that the <u>flash memory erase time is 10 msec or greater</u> (all of table 19-3 except for the shaded sections). The formula for calculating erasure time, t (sec), is shown below.

 $t = n \times \frac{1}{f Hz} \times 5000 + 0.009$  (n: specified by FCLK)

| FC | FCLK Reprogramming time (msec) |                |                 |                 |                 |                 |                 |                 |
|----|--------------------------------|----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
| 1  | 0                              | CLK =<br>5 MHz | CLK =<br>10 MHz | CLK =<br>12 MHz | CLK =<br>14 MHz | CLK =<br>16 MHz | CLK =<br>18 MHz | CLK =<br>20 MHz |
| 0  | 0                              | 18.0           | 10.0            | 8.7             | 7.7             | 7.0             | 6.4             | 6.0             |
| 0  | 1                              | 10.0           | 6.0             | 5.3             | 4.9             | 4.5             | 4.2             | 4.0             |
| 1  | 0                              | 6.0            | 4.0             | 3.7             | 3.4             | 3.3             | 3.1             | 3.0             |
| 1  | 1                              | 4.0            | 3.0             | 2.8             | 2.7             | 2.6             | 2.6             | 2.5             |

#### Table 19-4 Flash Memory Reprogramming Time

Set FCLK0 and FCLK1 such that the <u>flash memory reprogramming time is 3 msec or greater</u> (all of table 19-4 except for the shaded sections). The formula for calculating reprogramming time, t (sec), is shown below.

$$t = n \times \frac{1}{f Hz} \times 5000 + 0.002$$
 (n: specified by FCLK)

(4) Flowchart Examples for User Mode

Reprogramming with the user mode first erases the flash memory with a sector erasure, and then performs the write operation in 64-byte units.

Figure 19-9 shows an example flowchart of sector erasure and figure 19-10 shows an example flowchart of reprogramming.



Figure 19-9 Sector Erase Flowchart Example



- 1) Set FLAADRS (FA6 to 15) with the upper 10 bits of the address to be reprogrammed in 64-byte units.
- 2) Use serial I/O or an external memory access to set the reprogramming data in 300H to 33FH of the internal RAM.
- 3) Write n5H and nAH (n = 0 to F) consecutively to FLAACP so that the flash memory acceptor is set to "1". After erasing or reprogramming the flash memory, the flash memory acceptor is reset to "0".
- 4) The write (PRG) flag of the FLACON register is set to "1". Performing the reprogramming operation resets the PRG flag to "0".
- After the PRG flag is set, the CPU executes one instruction. (One instruction is to be executed immediately after the instruction that sets the PRG flag.)
- 6) After executing one instuction, the CPU automatically enters the HOLD state.
- 7) When the CPU enters the HOLD state, the data in the RAM address area of 300H to 33FH is transferred to the flash memory and is reprogrammed.
- 8) When the flash memory reprogramming is complete, the HOLD state is automatically canceled and the CPU executes the next instruction.
- 9) Verify that the flash memory has been reprogrammed with the data. ROM table reference instructions can be used to verify the data.
- 10) Because reprogramming is performed in 64-byte units, 16 reprogramming cycles are required after the sector erasure.



19

(5) Example Data Verification Programs to Check Erased or Reprogrammed Data

• After the flash memory address range of 5000H to 53FFH (1KB) is erased, the following example program verifies that 1KB of data has been erased.

|     | MOV<br>MOVB | FLAADRS, #5000H<br>FLAACP, #05H | Set the erase start address (5000H).                |
|-----|-------------|---------------------------------|-----------------------------------------------------|
|     | MOVB        | FLAACP, #0AH                    | Set the flash memory acceptor.                      |
|     | MOVB        | FLACON, #02H                    | Set the SERS flag.                                  |
|     | NOP         |                                 | (Erasing begins after executing one instruction.)   |
|     | L           | A, #0FFFFH                      | Set "0FFFFH" in the accumulator.                    |
|     | MOV         | ER0, #5000H                     | Set the flash memory address to ER0.                |
| LOO | P:          |                                 |                                                     |
|     | CMPC        | A, [ER0]                        | Compare the accumulator and flash memory data.      |
|     | JC          | NE, ERR                         | If different, jump to the error routine.            |
|     | ADD         | ER0, #0002H                     | Increment the flash memory address by 2.            |
|     | JBR         | R1.2, LOOP                      | If 1KB of data have not been checked, jump to LOOP. |
|     |             | •                               |                                                     |
|     |             | •                               |                                                     |
| ERR | : ·         |                                 | Perform error processing.                           |

• After reprogramming the flash memory address range of 5500H to 553FH (64 bytes), the following example program verifies that 64 bytes of data have been written.

It is assumed that the reprogramming data has been stored in advance in internal RAM addresses 300H to 33FH.

|     | MOV<br>MOVB | FLAADRS, #5500H<br>FLAACP, #05H | Set the reprogramming start address (5500H).                                                    |
|-----|-------------|---------------------------------|-------------------------------------------------------------------------------------------------|
|     | MOVB        | FLAACP, #0AH                    | Set the flash memory acceptor.                                                                  |
|     | MOVB        | FLACON, #11H                    | Set the PRG flag.                                                                               |
|     | NOP         |                                 | (Reprogramming begins after executing one instruction.)                                         |
|     | MOV         | DP, #300H                       | Set DP with the internal RAM address.                                                           |
|     | MOV         | ER0, #5500H                     | Set ER0 with the flash memory address.                                                          |
|     | SDD         |                                 | Set the data descriptor.                                                                        |
| LOO | P:          |                                 |                                                                                                 |
|     | LC          | A, [ER0]                        | Load the accumulator with the flash memory data.                                                |
|     | CMP         | A, [DP+]                        | After comparing the accumulator and internal RAM data, increment the internal RAM address by 2. |
|     | JC          | NE, ERR                         | If different, jump to the error routine.                                                        |
|     | ADDB        | R0, #02H                        | Increment the flash memory address by 2.                                                        |
|     | JBR         | R0.6, LOOP                      | If 64 bytes of data have not been checked, jump to LOOP.                                        |
|     | OBIT        |                                 |                                                                                                 |
|     |             |                                 |                                                                                                 |
| ERR | : •         |                                 | Perform error processing.                                                                       |

(6) Notes on Usage Regarding User Mode

Be careful of the following items when developing software to be used in the user mode.

- If an interrupt is generated during reprogramming or erasing the flash memory, the interrupt processing is postponed until after the reprogramming or erasing operation is complete. (If timer or other interrupts are to be used, be sure to account for the flash memory reprogramming and erasing times.)
- While reprogramming or erasing the flash memory, when the RES pin input asserts a reset, the reset processing is postponed until after the reprogramming or erasing operation is complete.
- Since erasing is performed in 1KB units, to reprogram even 1 byte, it is necessary to perform a 64-byte write operation 16 times.
- Do not erase the area of flash memory that the reprogramming program is using. (After being erased, the CPU will run out of control.)
- Corresponding to one erasure, perform only one write operation to the same address, even if writing the same data.
- When flash memory is erased, the data is set to "0FFH". Thereafter, writing "0FFH" data is considered as one reprogramming operation.
- The PRG and SERS flags of the FLACON register must be set only one at a time. If both the PRG and SERS flags are set to "1", neither reprogramming nor erasing operations will be performed.
- Reprogramming and erasing operations initiated by ICE cannot be evaluated.

#### 19.6 Programming Notes

(1) Reprogramming Immediately after Power is Supplied to Flash Memory

Flash memory reprogramming is automatically inhibited for approximately 20 msec after power is turned on ( $V_{DD} = 5.0 \text{ V} \pm 10\%$ ). Therefore, when reprogramming is to be performed soon after power is turned on, be sure to wait for the above power-on reset time.

(2) Note when STOP Mode is Canceled

The flash memory requires at least 1 msec of standby time when the STOP mode is canceled. Therefore, set the standby control (SBYCON) register to ensure the wait time when the STOP mode is canceled.

## Chapter 20

# **Electrical Characteristics**

#### 20. Electrical Characteristics

### 20.1 Absolute Maximum Ratings

| Parameter                    | Symbol           |           | Condition       | Rating                        | Unit |
|------------------------------|------------------|-----------|-----------------|-------------------------------|------|
| Digital power supply voltage | V <sub>DD</sub>  |           |                 | -0.3 to +7.0                  | V    |
| Input voltage                | VI               |           |                 | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Output voltage               | V <sub>0</sub>   | GN        | ID = AGND = 0 V | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Analog reference voltage     | V <sub>REF</sub> |           | Ta = 25°C       | -0.3 to V <sub>DD</sub> + 0.3 | V    |
| Analog input voltage         | V <sub>AI</sub>  |           |                 | -0.3 to V <sub>REF</sub>      | V    |
| Dower dissinction            | P                | T- 7090   | Per package     | 650                           | mW   |
| Power dissipation            | PD               | Ta = 70°C | Per output      | 8                             | mW   |
| Storage temperature          | T <sub>STG</sub> |           |                 | -50 to +150                   | °C   |

#### 20.2 Recommended Operating Conditions

| Parameter                | Symbol           | C         | Condition                                    | Range                      | Unit   |  |
|--------------------------|------------------|-----------|----------------------------------------------|----------------------------|--------|--|
|                          |                  | MSM66587A |                                              |                            |        |  |
| Digital nowar auguly     |                  | MSM66P587 | $f_{OSC} \le 20 \text{ MHz}$                 | 4.5 to 5.5                 |        |  |
| Digital power supply     | V <sub>DD</sub>  | MSM66Q587 |                                              |                            | V      |  |
| voltage                  |                  | MSM66587A | f < 10 MHz                                   | 07 to 55                   |        |  |
|                          |                  | MSM66P587 | $f_{OSC} \le 10 \text{ MHz}$                 | 2.7 to 5.5                 |        |  |
| Analog reference voltage | V <sub>REF</sub> |           | —                                            | $V_{DD}$ – 0.3 to $V_{DD}$ | V      |  |
| Analog input voltage     | V <sub>AI</sub>  |           | _                                            | AGND to V <sub>REF</sub>   | V      |  |
| Memory hold voltage      | V <sub>DDH</sub> | f         | <sub>OSC</sub> = 0 Hz                        | 2.0 to 5.5                 | V      |  |
|                          | fosc             | VDE       | ) = 5 V ±10%                                 | 2 to 20                    | MHz    |  |
| Operating frequency      |                  | MSM66587A |                                              | 2 to 10                    | MHz    |  |
|                          |                  | MSM66P587 | V <sub>DD</sub> = 2.7 to 5.5 V               | 2 10 10                    | IVITIZ |  |
|                          |                  | MSM66587A |                                              |                            |        |  |
| Temperature range        | Та               | MSM66P587 | —                                            | -30 to +70                 | °C     |  |
|                          |                  | MSM66Q587 | V <sub>DD</sub> = 4.5 to 5.5 V               |                            |        |  |
|                          |                  | 1         | VIOS loads                                   | 20                         |        |  |
| For out                  | N                |           | P0, P5_4, P5_5,<br>P7_0, P7_1                | 2                          | _      |  |
| Fan-out                  | N                | TTL loads | P1, P2, P4, P6,<br>P7_2-P7_7,<br>P8-P10, P12 | 1                          | _      |  |

#### 20.3 Allowable Output Current

|                        | N                          | /ISM66587A/I<br>MSM660 | ( 22 |      | V, Ta = -30<br>V, Ta = -30 | ,    |
|------------------------|----------------------------|------------------------|------|------|----------------------------|------|
| Parameter              | Pin                        | Symbol                 | Min. | Тур. | Max.                       | Unit |
| "H" output pin (1 pin) | All output pins            | I <sub>OH</sub>        |      | —    | -2                         |      |
| "H" output pin (total) | Total of all output pins   | Σl <sub>OH</sub>       |      | —    | -40                        |      |
| "L" output pin (1 pin) | All output pins            | I <sub>OL</sub>        |      | —    | 5                          |      |
|                        | Total of P0, P1, P5 and P7 |                        |      |      |                            | mA   |
|                        | Total of P2, P9 and P10    |                        |      |      | 50                         | IIIA |
| "L" output pin (total) | Total of P4 and P8         | $\Sigma I_{OL}$        | —    | _    | 50                         |      |
|                        | Total of P6 and P12        |                        |      |      |                            |      |
|                        | Total of all output pins   |                        |      |      | 100                        |      |

MSM665874/P587 (Vp 2.7 to 5.5 V Ta = -30 to +70°C)

Note: Power and ground connections must be made to all external  $V_{\text{DD}}$  and GND pins.

#### 20.4 **DC** Characteristics

#### 20.4.1 DC Characteristics ( $V_{DD} = 5 V \pm 10\%$ )

| MSM66587A/P587/Q587 (V <sub>DD</sub> = 5 V ±10%, Ta = -30 to +70° |                                  |                                       |                     |      |                       |      |  |  |
|-------------------------------------------------------------------|----------------------------------|---------------------------------------|---------------------|------|-----------------------|------|--|--|
| Parameter                                                         | Symbol                           | Condition                             | Min.                | Тур. | Max.                  | Unit |  |  |
| Input high voltage 1                                              | VIH                              |                                       | 0.44V <sub>DD</sub> | _    | V <sub>DD</sub> + 0.3 |      |  |  |
| Input high voltage 2, 4, 5, 6, 7                                  | VIH                              |                                       | 0.80V <sub>DD</sub> | —    | V <sub>DD</sub> + 0.3 |      |  |  |
| Input low voltage 1                                               | VIL                              |                                       | -0.3                | _    | 0.16V <sub>DD</sub>   |      |  |  |
| Input low voltage 2, 4, 5, 6, 7                                   | VIL                              |                                       | -0.3                |      | 0.2V <sub>DD</sub>    |      |  |  |
| Output high voltage 1, 4                                          |                                  | I <sub>0</sub> = -400 μA              | $V_{DD}-0.4$        |      |                       |      |  |  |
|                                                                   | V <sub>OH</sub>                  | I <sub>0</sub> = -2.0 mA              | $V_{DD} - 0.6$      |      | _                     |      |  |  |
| Output high voltage 2                                             | VOH                              | I <sub>0</sub> = −200 μA              | $V_{DD} - 0.4$      |      |                       | V    |  |  |
|                                                                   |                                  | I <sub>0</sub> = -2.0 mA              | $V_{DD} - 0.6$      | _    | _                     |      |  |  |
| Output low voltage 1, 4                                           |                                  | I <sub>0</sub> = 3.2 mA               |                     | —    | 0.4                   |      |  |  |
|                                                                   | V <sub>OL</sub>                  | l <sub>0</sub> = 5.0 mA               |                     |      | 0.8                   |      |  |  |
| Output low voltage 2                                              | VOL                              | l <sub>0</sub> = 1.6 mA               | —                   | _    | 0.4                   |      |  |  |
|                                                                   |                                  | l <sub>0</sub> = 5.0 mA               | —                   | _    | 0.8                   |      |  |  |
| Input leakage current 3, 6                                        |                                  |                                       | —                   | _    | 1/–1                  |      |  |  |
| Input current 5                                                   | I <sub>IH</sub> /I <sub>IL</sub> | $V_I = V_{DD}/0 V$                    | —                   | _    | 1/-250                | μA   |  |  |
| Input current 7                                                   |                                  |                                       |                     |      | 15/–15                |      |  |  |
| Output leakage current 1, 2, 4                                    | ILO                              | $V_0 = V_{DD}/0 V$                    | _                   | _    | ±10                   | μA   |  |  |
| Pull-up resistor 2                                                | R <sub>pull</sub>                | $V_I = 0 V$                           | 25                  | 50   | 100                   | kΩ   |  |  |
| Input capacitance                                                 | CI                               | f = 1 MHz, Ta = 25                    | ~ —                 | 5    |                       | рF   |  |  |
| Output capacitance                                                | Co                               | T = T WITZ, Ta = 2J                   |                     | 7    |                       | рі   |  |  |
| Analog reference power supply                                     | 1                                | A/D conversion opera                  | ting —              | —    | 4                     | mA   |  |  |
| current                                                           | IREF                             | A/D conversion stop                   | ped —               | —    | 10                    | μA   |  |  |
| Supply current                                                    | 1.                               | V <sub>DD</sub> = 2 V, Ta = 25°       | C* —                | 0.2  | 10                    |      |  |  |
| (STOP mode)                                                       | I <sub>DDS</sub>                 | *                                     |                     | 1    | 100                   | μA   |  |  |
| Supply Current                                                    |                                  | f                                     | 87A —               | 8    | 15                    |      |  |  |
| (HALT mode)                                                       | IDDH                             | f <sub>OSC</sub> = 20 MHz,<br>No Load | 587 —               | 10   | 25                    | mA   |  |  |
|                                                                   |                                  | MSM66Q                                | 587 —               | 17   | 30                    |      |  |  |
| Supply Current                                                    |                                  | fue 20 MHz MSM665                     | 87A —               | 25   | 40                    |      |  |  |
|                                                                   | I <sub>DD</sub>                  | f <sub>OSC</sub> = 20 MHz,<br>No Load | 587 —               | 45   | 70                    | mA   |  |  |
|                                                                   |                                  | MSM66Q                                | 587 —               | 45   | 70                    |      |  |  |

MSM665871/P587/0587 (Va 5 V +10% Ta \_30 to 170°C)

1. Applies to P0.

2. Applies to P1, P2, P4, P6, P7\_2-P7\_7, P8-P10, P12.

- 3. Applies to Ain.
- 4. Applies to P5\_4, P5\_5, P7\_0, P7\_1.
- 5. Applies to RES.
- 6. Applies to  $\overline{EA}$ , NMI.
- 7. Applies to OSC0.
- \* For input ports,  $V_{DD}$  or 0 V. For other cases, unloaded.

#### 20.4.2 DC Characteristics ( $V_{DD} = 2.7$ to 5.5 V)

| MISMI66587A/P587 (VDD = 2.7 to 5.5 V, Ta = -30 to +70°C |                                  |                      |                          |                       |      |                       |      |  |
|---------------------------------------------------------|----------------------------------|----------------------|--------------------------|-----------------------|------|-----------------------|------|--|
| Parameter                                               | Symbol                           | Cond                 | dition                   | Min.                  | Тур. | Max.                  | Unit |  |
| Input high voltage 1                                    | v                                |                      |                          | 0.44V <sub>DD</sub>   | —    | V <sub>DD</sub> + 0.3 |      |  |
| Input high voltage 2, 4, 5, 6, 7                        | VIH                              | -                    | —                        | 0.80V <sub>DD</sub>   | _    | V <sub>DD</sub> + 0.3 |      |  |
| Input low voltage 1                                     | V                                |                      |                          | -0.3                  | —    | 0.16V <sub>DD</sub>   |      |  |
| Input low voltage 2, 4, 5, 6, 7                         | VIL                              | -                    | —                        | -0.3                  | —    | 0.2V <sub>DD</sub>    |      |  |
|                                                         |                                  | I <sub>0</sub> = -4  | 400 μA                   | $V_{DD} - 0.4$        | _    |                       |      |  |
| Output high voltage 1, 4                                |                                  | I <sub>0</sub> = -2  | 2.0 mA                   | $V_{DD} - 0.6$        | _    |                       |      |  |
|                                                         | V <sub>OH</sub>                  | $I_0 = -2$           | 200 µA                   | $V_{DD} - 0.4$        | _    | —                     | V    |  |
| Output high voltage 2                                   |                                  | MSM66587A            | I <sub>0</sub> = −1.0 mA | V 0.0                 |      |                       |      |  |
|                                                         |                                  | MSM66P587            | I <sub>0</sub> = -2.0 mA | V <sub>DD</sub> – 0.8 | —    |                       |      |  |
| Outrut law valtage 1.4                                  |                                  | I <sub>0</sub> = 3   | 3.2 mA                   |                       | _    | 0.5                   |      |  |
| Output low voltage 1, 4                                 |                                  | I <sub>0</sub> = 5   | 5.0 mA                   | _                     | —    | 0.9                   |      |  |
|                                                         | V <sub>OL</sub>                  | I <sub>0</sub> = 1   | .6 mA                    | —                     | _    | 0.5                   |      |  |
| Output low voltage 2                                    |                                  | MSM66587A            | l <sub>0</sub> = 2.5 mA  | —                     | _    | 0.9                   |      |  |
|                                                         |                                  | MSM66P587            | l <sub>0</sub> = 5.0 mA  |                       | _    | 1.2                   |      |  |
| Input leakage current 3, 6                              |                                  |                      |                          | —                     |      | 1/–1                  |      |  |
| Input current 5                                         | I <sub>IH</sub> /I <sub>IL</sub> | V <sub>I</sub> = V   | <sub>'DD</sub> /0 V      |                       | _    | 1/-250                | μA   |  |
| Input current 7                                         |                                  |                      |                          | —                     | _    | 15/–15                |      |  |
| Output leakage current 1, 2, 4                          | ILO                              | V <sub>0</sub> = V   | / <sub>DD</sub> /0 V     |                       | _    | ±10                   | μA   |  |
| Pull-up resistor                                        | R                                | $V_I = 0 V, V_{DD}$  | = 5 V ±10%               | 25                    | 50   | 100                   | ko   |  |
| Pull-up resistor                                        | R <sub>pull</sub>                | $V_I = 0 V, V_{DD}$  | = 3 V ±10%               | 40                    | 100  | 200                   | kΩ   |  |
| Input capacitance                                       | Cı                               | £ 1 MU-              | T- 05%0                  | _                     | 5    |                       | - F  |  |
| Output capacitance                                      | Co                               | f = 1 MHz, Ta = 25°C |                          |                       | 7    |                       | pF   |  |
|                                                         |                                  | A/D conversion       | V <sub>DD</sub> = 5.5 V  |                       | _    | 4                     |      |  |
| Analog reference power                                  |                                  | operating            | V <sub>DD</sub> = 3.3 V  |                       | _    | 2                     | mA   |  |
| supply current                                          | I <sub>REF</sub>                 | A/D conversion       | V <sub>DD</sub> = 5.5 V  | —                     |      | 10                    | μA   |  |
|                                                         |                                  | stopped              | V <sub>DD</sub> = 3.3 V  | _                     |      | 5                     | μΑ   |  |

MSM66587A/P587 ( $V_{DD}$  = 2.7 to 5.5 V, Ta = -30 to +70°C)

1. Applies to P0.

2. Applies to P1, P2, P4, P6, P7\_2-P7\_7, P8-P10, P12.

3. Applies to Ain.

4. Applies to P5\_4, P5\_5, P7\_0, P7\_1.

5. Applies to RES.

6. Applies to  $\overline{EA}$ , NMI.

7. Applies to OSC0.

| Parameter                  | Symbol           |                                       | Condition                             |                            | Min.                 | Тур.                       | Max.      | Unit |    |    |  |
|----------------------------|------------------|---------------------------------------|---------------------------------------|----------------------------|----------------------|----------------------------|-----------|------|----|----|--|
| Supply current (STOP mode) | 1                | V <sub>DD</sub> =                     | = 2 V, Ta = 2                         | 5°C*                       |                      | 0.2                        | 10        |      |    |    |  |
|                            | I <sub>DDS</sub> |                                       | *                                     |                            |                      | 1                          | 100       | - μA |    |    |  |
|                            |                  | T <sub>OSC</sub> = 10 MHZ,<br>No Load | V EV.100/                             | MSM66587A                  | —                    | 4                          | 8         |      |    |    |  |
| Supply surrent (UALT mode) |                  |                                       | t <sub>osc</sub> = 10 MHz,<br>No Load | f <sub>OSC</sub> = 10 MHz, | $ T_{OSC} = 10$ MHz, | V <sub>DD</sub> = 5 V ±10% | MSM66P587 | _    | 5  | 15 |  |
| Supply current (HALT mode) | IDDH             |                                       |                                       | V 0.V 100/                 | MSM66587A            | _                          | 2         | 4    | mA |    |  |
|                            |                  |                                       | V <sub>DD</sub> = 3 V ±10%            | MSM66P587                  | _                    | 3                          | 10        |      |    |    |  |
|                            |                  |                                       |                                       |                            |                      | MSM66587A                  | _         | 15   | 25 |    |  |
| Supply surrent             |                  | ho Load                               | $ f_{0SC} = 10 \text{ MHz},$          | V <sub>DD</sub> = 5 V ±10% | MSM66P587            | —                          | 30        | 50   |    |    |  |
| Supply current             |                  |                                       | V 0.V 100/                            | MSM66587A                  | _                    | 7                          | 13        | mA   |    |    |  |
|                            |                  |                                       | $V_{DD} = 3 V \pm 10\%$               |                            | _                    | 13                         | 25        | ]    |    |    |  |

MSM66587A/P587 (V<sub>DD</sub> = 2.7 to 5.5 V, Ta = -30 to +70°C)

 $^{\ast}$   $\,$  For input ports,  $V_{DD}$  or 0 V. For other cases, unloaded.

#### 20.5 AC Characteristics

### 20.5.1 AC Characteristics (V<sub>DD</sub> = 5 V $\pm$ 10%)

(1) External Program Memory Control

|                         | $(V_{DD} = 5 V \pm 10\%, Ta = -30 \text{ to } +70^{\circ}\text{C}$ |                        |                     |                       |      |  |  |  |  |
|-------------------------|--------------------------------------------------------------------|------------------------|---------------------|-----------------------|------|--|--|--|--|
| Parameter               | Symbol                                                             | Condition              | Min.                | Max.                  | Unit |  |  |  |  |
| Clock (OSC) pulse width | t <sub>oW</sub>                                                    | —                      | 25                  |                       |      |  |  |  |  |
| ALE pulse width         | t <sub>AW</sub>                                                    |                        | $2 t_{\phi W} - 2$  |                       |      |  |  |  |  |
| <b>PSEN</b> pulse width | t <sub>PW</sub>                                                    |                        | $2 t_{\phi W} - 5$  | _                     |      |  |  |  |  |
| PSEN pulse delay time   | t <sub>PAD</sub>                                                   |                        | $t_{\varphi W} - 3$ | t <sub>¢W</sub> + 3   |      |  |  |  |  |
| Low address setup time  | t <sub>ALS</sub>                                                   |                        | $2 t_{\phi W} - 3$  | 2 t <sub>¢W</sub> + 3 | ns   |  |  |  |  |
| Low address hold time   | t <sub>ALH</sub>                                                   | C <sub>L</sub> = 50 pF | $t_{\varphi W} - 3$ | t <sub>¢W</sub> + 3   | 110  |  |  |  |  |
| High address setup time | t <sub>AHS</sub>                                                   |                        | $4 t_{\phi W} - 3$  | 4 t <sub>oW</sub> + 3 |      |  |  |  |  |
| High address hold time  | t <sub>APH</sub>                                                   |                        | 0                   | t <sub>øW</sub> + 3   |      |  |  |  |  |
| Instruction setup time  | t <sub>IS</sub>                                                    |                        | 15                  | _                     |      |  |  |  |  |
| Instruction hold time   | t <sub>IH</sub>                                                    |                        | 0                   | t <sub>oW</sub> – 3   |      |  |  |  |  |



| Parameter               | Symbol           | Condition              | Min.                 | Max.                  | Unit |
|-------------------------|------------------|------------------------|----------------------|-----------------------|------|
| Clock (OSC) pulse width | t <sub>oW</sub>  | _                      | 25                   | _                     |      |
| ALE pulse width         | t <sub>AW</sub>  |                        | $2 t_{\phi W} - 2$   |                       |      |
| RD pulse width          | t <sub>RW</sub>  |                        | $2 t_{\phi W} - 5$   |                       |      |
| WR pulse width          | tww              |                        | $2 t_{\phi W} - 5$   |                       |      |
| RD pulse delay time     | t <sub>RAD</sub> |                        | $t_{\phi W} - 3$     | t <sub>¢W</sub> + 3   |      |
| WR pulse delay time     | t <sub>WAD</sub> |                        | $t_{\phi W} - 3$     | t <sub>¢W</sub> + 3   |      |
| Low address setup time  | t <sub>ALS</sub> | C <sub>L</sub> = 50 pF | $2 t_{\phi W} - 3$   | 2 t <sub>oW</sub> + 3 | nc   |
| Low address hold time   | t <sub>ALH</sub> | 0L = 30 pi             | $t_{\phi W} - 3$     | t <sub>¢W</sub> + 3   | ns   |
| High address setup time | t <sub>AHS</sub> |                        | $3 t_{\phi W} - 3$   | 3 t <sub>ow</sub> + 3 |      |
| High address hold time  | t <sub>AHH</sub> |                        | $t_{\varphi W} - 3$  | t <sub>¢W</sub> + 3   |      |
| Memory data setup time  | t <sub>MS</sub>  |                        | 15                   |                       |      |
| Memory data hold time   | t <sub>MH</sub>  | _                      | 0                    | $t_{\varphi W} - 3$   |      |
| Data delay time         | t <sub>DD</sub>  |                        | t <sub>ALH</sub> – 0 | t <sub>ALH</sub> + 5  |      |
| Data hold time          | t <sub>DH</sub>  |                        | $t_{\phi W} - 3$     | t <sub>¢W</sub> + 3   |      |

(2) External Data Memory Control





- (3) Serial Port Contorl
  - Master mode

#### $(V_{DD} = 5 \text{ V} \pm 10\%, \text{ Ta} = -30 \text{ to} +70^{\circ}\text{C})$

| Parameter               | Symbol             | Condition             | Min.                | Тур. | Max. | Unit |
|-------------------------|--------------------|-----------------------|---------------------|------|------|------|
| Clock (OSC) pulse width | t <sub>øW</sub>    |                       | 25                  | —    |      |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                       | 8 t <sub>oW</sub>   | —    |      |      |
| Output data setup time  | t <sub>STMXS</sub> |                       | $4 t_{\phi W} - 5$  | —    |      | ns   |
| Output data hold time   | t <sub>STMXH</sub> | $C_L = 50 \text{ pF}$ | $3 t_{\phi W} - 10$ |      |      | 115  |
| Input data setup time   | t <sub>SRMXS</sub> |                       | 20                  | —    |      |      |
| Input data hold time    | t <sub>SRMXH</sub> |                       | 0                   | —    | —    |      |



| Parameter               | Symbol             | Condition              | Min.                   | Тур. | Max. | Unit |  |
|-------------------------|--------------------|------------------------|------------------------|------|------|------|--|
| Clock (OSC) pulse width | t <sub>¢W</sub>    | —                      | 25                     | —    |      |      |  |
| Serial clock cycle time | t <sub>SCKC</sub>  |                        | 8 t <sub>oW</sub>      | —    |      |      |  |
| Output data setup time  | tstmxs             |                        | $2 t_{\phi W} - 15$    |      |      | ns   |  |
| Output data hold time   | t <sub>STMXH</sub> | C <sub>L</sub> = 50 pF | $4 t_{\varphi W} - 10$ |      |      | 115  |  |
| Input data setup time   | t <sub>SRMXS</sub> |                        | 20                     |      |      |      |  |
| Input data hold time    | t <sub>SRMXH</sub> |                        | 5                      |      |      |      |  |

Slave mode

 $(V_{DD} = 5 \text{ V} \pm 10\%, \text{ Ta} = -30 \text{ to } +70^{\circ}\text{C})$ 



AC timing mesurement point



### 20.5.2 AC Characteristics ( $V_{DD}$ = 2.7 to 5.5 V)

(1) External Program Memory Control

| $MISM0658/A/PS8/ (V_{DD} = 2.7 \text{ to } 5.5 \text{ V}, \text{ Ia} = -30 \text{ to } +70$ |                  |                       |                        |                       |      |  |  |  |
|---------------------------------------------------------------------------------------------|------------------|-----------------------|------------------------|-----------------------|------|--|--|--|
| Parameter                                                                                   | Symbol           | Condition             | Min.                   | Max.                  | Unit |  |  |  |
| Clock (OSC) pulse width                                                                     | $t_{\phi W}$     | —                     | 50                     |                       |      |  |  |  |
| ALE pulse width                                                                             | t <sub>AW</sub>  |                       | 2 t <sub>¢W</sub> – 4  |                       |      |  |  |  |
| PSEN pulse width                                                                            | t <sub>PW</sub>  |                       | 2 t <sub>oW</sub> – 10 | —                     |      |  |  |  |
| PSEN pulse delay time                                                                       | t <sub>PAD</sub> |                       | t <sub>¢W</sub> – 6    | t <sub>¢W</sub> + 6   |      |  |  |  |
| Low address setup time                                                                      | t <sub>ALS</sub> |                       | 2 t <sub>¢W</sub> – 6  | 2 t <sub>oW</sub> + 6 | ns   |  |  |  |
| Low address hold time                                                                       | t <sub>ALH</sub> | $C_L = 50 \text{ pF}$ | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   | 115  |  |  |  |
| High address setup time                                                                     | t <sub>AHS</sub> |                       | 4 t <sub>ow</sub> – 6  | 4 t <sub>oW</sub> + 6 |      |  |  |  |
| High address hold time                                                                      | t <sub>APH</sub> |                       | 0                      | t <sub>¢W</sub> + 6   |      |  |  |  |
| Instruction setup time                                                                      | t <sub>IS</sub>  |                       | 30                     |                       |      |  |  |  |
| Instruction hold time                                                                       | t <sub>IH</sub>  |                       | 0                      | $t_{\varphi W} - 6$   |      |  |  |  |

MSM66587A/P587 ( $V_{DD}$  = 2.7 to 5.5 V, Ta = -30 to +70°C)



| Parameter               | Symbol           | Condition              | Min.                   | Max.                  | Unit |
|-------------------------|------------------|------------------------|------------------------|-----------------------|------|
| Clock (OSC) pulse width | $t_{\varphi W}$  |                        | 50                     |                       |      |
| ALE pulse width         | t <sub>AW</sub>  |                        | 2 t <sub>¢W</sub> – 4  |                       |      |
| RD pulse width          | t <sub>RW</sub>  |                        | 2 t <sub>¢W</sub> – 10 |                       |      |
| WR pulse width          | t <sub>WW</sub>  |                        | 2 t <sub>¢W</sub> – 10 |                       |      |
| RD pulse delay time     | t <sub>RAD</sub> |                        | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   |      |
| WR pulse delay time     | t <sub>WAD</sub> |                        | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   |      |
| Low address setup time  | t <sub>ALS</sub> | C <sub>L</sub> = 50 pF | 2 t <sub>¢W</sub> – 6  | 2 t <sub>ow</sub> + 6 | ns   |
| Low address hold time   | t <sub>ALH</sub> | 0L = 30 pi             | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   | 115  |
| High address setup time | t <sub>AHS</sub> |                        | 3 t <sub>oW</sub> – 6  | 3 t <sub>oW</sub> + 6 |      |
| High address hold time  | t <sub>AHH</sub> |                        | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   |      |
| Memory data setup time  | t <sub>MS</sub>  |                        | 30                     |                       |      |
| Memory data hold time   | t <sub>MH</sub>  |                        | 0                      | $t_{\phi W} - 6$      |      |
| Data delay time         | t <sub>DD</sub>  |                        | t <sub>ALH</sub> – 0   | t <sub>ALH</sub> + 10 |      |
| Data hold time          | t <sub>DH</sub>  |                        | $t_{\phi W} - 6$       | t <sub>¢W</sub> + 6   |      |

(2) External Data Memory Control

MSM66587A/P587 (V<sub>DD</sub> = 2.7 to 5.5 V, Ta = -30 to +70°C)



- (3) Serial Port Control
  - Master mode

#### MSM66587A/P587 ( $V_{DD}$ = 2.7 to 5.5 V, Ta = -30 to +70°C)

|                         |                    |                        | ( ==                   |      |      |      |
|-------------------------|--------------------|------------------------|------------------------|------|------|------|
| Parameter               | Symbol             | Condition              | Min.                   | Тур. | Max. | Unit |
| Clock (OSC) pulse width | t <sub>oW</sub>    | —                      | 50                     | —    |      |      |
| Serial clock cycle time | t <sub>SCKC</sub>  |                        | 8 t <sub>oW</sub>      | —    | —    |      |
| Output data setup time  | t <sub>STMXS</sub> |                        | $4 t_{\varphi W} - 10$ |      |      | ne   |
| Output data hold time   | t <sub>STMXH</sub> | C <sub>L</sub> = 50 pF | $3 t_{\varphi W} - 20$ |      |      | ns   |
| Input data setup time   | t <sub>SRMXS</sub> |                        | 30                     | —    |      |      |
| Input data hold time    | t <sub>SRMXH</sub> |                        | 0                      | —    |      |      |



Slave mode •

Parameter Symbol Condition Min. Тур. Max. Unit Clock (OSC) pulse width 50  $t_{\phi W}$ Serial clock cycle time t<sub>SCKC</sub>  $8 t_{\phi W}$  $2 t_{\phi W} - 30$ Output data setup time t<sub>STMXS</sub> ns Output data hold time tsтмхн  $C_L = 50 \text{ pF}$  $4 t_{\phi W} - 20$ \_\_\_\_ \_\_\_\_ Input data setup time t<sub>SRMXS</sub> 30 \_ \_ Input data hold time 10 t<sub>SRMXH</sub> \_\_\_\_ \_\_\_\_



AC timing mesurement point



MSM66587A/P587 ( $V_{DD}$  = 2.7 to 5.5 V, Ta = -30 to +70°C)

#### 20.6 A/D Converter Characteristics

#### 20.6.1 A/D Converter Characteristics (V<sub>DD</sub> = 5 V $\pm$ 10%)

#### (Ta = -30 to +70°C, $V_{DD}$ = $V_{REF}$ = 5 V ±10%, AGND = GND = 0 V, $f_{OSC}$ = 20 MHz)

| Parameter                    | Condition         | Min.                                       | Тур. | Max. | Unit |       |
|------------------------------|-------------------|--------------------------------------------|------|------|------|-------|
| Resolution                   | n                 | Refer to the recommended                   | —    | 8    |      | Bit   |
| Linearity error              | EL                | circuit (Fig. 20-1)<br>Analog input source | —    | _    | ±2   |       |
| Differential linearity error | ED                | impedance                                  |      | _    | ±1   | LSB   |
| Zero scale error             | E <sub>ZS</sub>   | $R_{I} \le 5 \ k\Omega$                    |      | _    | +2   | LOD   |
| Full scale error             | E <sub>FS</sub>   | t <sub>CONV</sub> = 19.219.2 μsec          | _    | _    | -2   |       |
| Conversion time              | t <sub>CONV</sub> | by ADTM set data                           | 6.4  |      | 19.2 | µs/ch |

#### 20.6.2 A/D Converter Characteristics ( $V_{DD}$ = 3 V ±10%)

#### MSM66587A/P587 (Ta = -30 to +70°C, $V_{DD} = V_{REF} = 3 V \pm 10\%$ , AGND = GND = 0 V, $f_{OSC} = 10 MHz$ )

| Parameter                    | Symbol            | Condition                                  | Min. | Тур. | Max. | Unit  |
|------------------------------|-------------------|--------------------------------------------|------|------|------|-------|
| Resolution                   | n                 | Refer to the recommended                   |      | 8    |      | Bit   |
| Linearity error              | EL                | circuit (Fig. 20-1)<br>Analog input source | _    | —    | ±1   |       |
| Differential linearity error | ED                | impedance                                  | _    |      | ±0.5 |       |
| Zero scale error             | E <sub>ZS</sub>   | $R_l \le 5 \ k\Omega$                      | _    | _    | +1   | LSB   |
| Full scale error             | E <sub>FS</sub>   | t <sub>CONV</sub> = 38.4 µsec              |      |      | -1   |       |
| Conversion time              | t <sub>CONV</sub> | ADTM = 00b (384CLK selection)              |      | 38.4 |      | µs/ch |



Figure 20-1 Recommended Circuit

#### Definition of terms

1. Resolution

Resolution is t2he minimum input analog value that can be resolved. With 8 bits,  $2^8 = 256$  so resolution can be to (V<sub>REF</sub> – AGND) ÷ 256.

2. Linearity error

Linearity error is the difference between actual conversion characteristics and ideal conversion characteristics of an 8-bit A/D converter (so this does not include quantization error).

Ideal conversion characteristics would be to divide the voltage between  $V_{\text{REF}}$  and AGND into 256 equal steps.

3. Differential linearity error

Differential linearity error indicates slope of conversion characteristics. The change in analog input voltage value that would change the digital output by one bit is ideally 1 LSB = ( $V_{REF}$  – AGND) ÷ 256, so differential linearity error is the difference between this ideal bit size and the actual bit size anywhere in the conversion range.

4. Zero scale error

Zero scale error is the difference between actual conversion characteristics and ideal conversion characteristics at the point where digital output switches from 00H to 01H.

5. Full scale error

Full scale error is the difference between actual conversion characteristics and ideal conversion characteristics at the point where digital output switches from FEH to FFH.

### Chapter 21

# Special Function Registers (SFRs)

#### 21. Special Function Registers (SFRs)

The 256-byte area 0000H-00FFH in data memory space is the SFR area. The 256-byte area 0100H-01FFH is the expanded SFR area. There are restrictions that limit expanded SFR and SFR addressing.

The SFR and expanded SFR areas are register groups allocated special functions like the following.

- Peripheral hardware mode registers
- Arithmetic register (ACC)
- Control registers (PSW, LRBL, LRBH, SSP)

Table 21-1 lists the SFRs. Terms in the table have the following meanings.

- Address[H] Addresses are expressed in hexadecimal.
- Function This is what the SFR function is called.
- Byte, Word: *symbol* This symbol indicates an I/O function register. The unit indicates whether it can be accessed by byte or by word.
  - This indicates that the function cannot be accessed by this unit.
- Bit Symbol: *symbol* This symbol indicates an I/O function register.
  - blank The I/O register is allocated to this bit as well. However, this bit has no need to be accessed on a bit basis and can not be accessed on a bit basis, so, the bit symbol is not needed.
  - This symbol indicates a bit that represents that an I/O funciton register does not exist.
     Programming should be done assuming the bit is always undefined.

Operation of this bit may differ with ICE evaluation and the actual chip (Mask version, OTP version, etc.).

- 0 <u>Always write "0" to this bit.</u> Write 0 to this bit even when writing a byte or word that includes it. This bit will always read as "0".
- 1Always write "1" to this bit.Write 1 to this bit even when writing a byte or word that<br/>includes it.This bit will always read as "1".
- (1) All writes to this bit will be ignored. <u>This bit will always read as "1".</u>

|             | Undefined     | This indicates a bit that does not support the I/O function.<br>Programming should be done on the assumption that the<br>value of this bit is always undefined.<br>Operation of this bit when an in-circuit emulator is used may<br>differ from operation when an actual chip (such as MASK or<br>OTP versions) is used. |
|-------------|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • R/W       | This indicate | es whether the specified SFR can be read (R) or written (W).<br>R/W Can be read and written.<br>R Can only be read.<br>W Can only be written.                                                                                                                                                                            |
| Reset state |               | indicates SFR contents after reset (RES signal input, BRK execution, op code trap).                                                                                                                                                                                                                                      |

- Reference page This indicates the page that discusses the configuration of the bit symbols.
- Note: Stars indicate SFRs that exist only in flash-version devices. For details, please refer to Chapter 19, "Flash Memory".

#### Notes:

Do not perform the following operations on the SFRs listed below.

- 1. Write operations on read-only SFRs.
- 2. Read operations on write-only SFRs.
- 3. 16-bit operations on 8-bit-only SFRs.
- 4. 8-bit operations on 16-bit only SFRs.
- 5. Operations on addresses which have not been allocated as register and so on.
- 6. Operations in the area for emulator use.

#### Table 21-1 SFR List

| Address | Function                   | -      |       |           |           |        | Bit Symb | Bit Symbol |           |           |           | R/W         | Reset     | Refere-       |
|---------|----------------------------|--------|-------|-----------|-----------|--------|----------|------------|-----------|-----------|-----------|-------------|-----------|---------------|
| [H]     |                            | Byte   | Word  | 7         | 6         | 5      | 4        | 3          | 2         | 1         | 0         | <b>n/ w</b> | State     | nce<br>Page   |
| 0000    | System Stack Pointer       | _      | 000   |           |           |        |          |            |           |           |           |             | FFFF      |               |
| 0001    | System Stack Pointer       | _      | SSP   |           |           |        |          |            |           |           |           | 1           | FFFF      | P3-20         |
| 0002    | Land Davieter Dese         | LRBL   | LRB   |           |           |        |          |            |           |           |           | 1           | undefined | D2 10         |
| 0003    | Local Register Base        | LRBH   | LKD   |           |           |        |          |            |           |           |           | 1           | undenned  | P3-19         |
| 0004    | Program Status Word        | PSWL   | PSW   | MAB       | F1        | BCB1   | BCB0     | F0         | SCB2      | SCB1      | SCB0      | ]           | 00        | P3-15         |
| 0005    | Program Status word        | PSWH   | P3W   | CY        | ZF        | HC     | DD       | S          | MIP       | OV        | MIE       |             | 00        | P3-15         |
| 0006    | Accumulator                | ACCL   | ACC   |           |           |        |          |            |           |           |           | R/W         | 00        | <b>DQ 4 4</b> |
| 0007    | Accumulator                | ACCH   | AUU   |           |           |        |          |            |           |           |           |             | 00        | P3-14         |
| 0008    | Table Segment Register     | TSR    | DSTSR | 0         | 0         | 0      | 0        |            |           |           |           | 1           | 00        | P3-23         |
| 0009    | Data Segment Register      | DSR    | D212K | 0         | 0         | 0      | 0        |            |           |           |           |             | 00        | P3-24         |
| 000B    | ROM Window Register        | ROMWIN | —     |           |           |        |          |            |           |           |           |             | 00        | P5-2          |
| 000C    | ROM Ready Control Register | ROMRDY | —     | (1)       | (1)       | (1)    | (1)      | (1)        | (1)       | ORDY1     | ORDY0     | ]           | FF        | P5-4          |
| 000D    | RAM Ready Control Register | RAMRDY | —     | (1)       | ARDY12    | ARDY11 | ARDY10   | (1)        | ARDY02    | ARDY01    | ARDY00    |             | FF        | P5-3          |
| 000E    | Stop Code Acceptor         | STPACP | —     | —         | —         | —      | _        |            |           |           |           | W           | "0"       | P4-5          |
| 000F    | Standby Control Register   | SBYCON | _     | (1)       | (1)       | OST1   | OST0     | (1)        | FLT       | HLT       | STP       |             | C8        | P4-3          |
| 0010    | Port 0 Data Register       | P0     |       | P0_7      | P0_6      | P0_5   | P0_4     | P0_3       | P0_2      | P0_1      | P0_0      |             | 00        | P6-10         |
| 0011    | Port 1 Data Register       | P1     |       | P1_7      | P1_6      | P1_5   | P1_4     | P1_3       | P1_2      | P1_1      | P1_0      |             | 00        | P6-11         |
| 0012    | Port 2 Data Register       | P2     | _     | P2_7      | P2_6      | P2_5   | P2_4     | P2_3       | P2_2      | P2_1      | P2_0      | ]           | 00        | P6-12         |
| 0014    | Port 4 Data Register       | P4     | _     | P4_7      | P4_6      | P4_5   | P4_4     | P4_3       | P4_2      | P4_1      | P4_0      |             | 00        | P6-14         |
| 0015    | Port 5 Data Register       | P5     |       | (1)       | (1)       | P5_5   | P5_4     | undefined  | undefined | undefined | undefined |             | undefined | P6-16         |
| 0016    | Port 6 Data Register       | P6     |       | undefined | undefined | P6_5   | P6_4     | P6_3       | P6_2      | P6_1      | P6_0      |             | undefined | P6-17         |
| 0017    | Port 7 Data Register       | P7     |       | P7_7      | P7_6      | P7_5   | P7_4     | P7_3       | P7_2      | P7_1      | P7_0      |             | 00        | P6-19         |
| 0018    | Port 0 Mode Register       | P010   | _     | P0I07     | P0106     | P0105  | P0I04    | P0I03      | P0102     | P0I01     | P0100     | R/W         | 00        | P6-10         |
| 0019    | Port 1 Mode Register       | P1I0   |       | P1I07     | P1I06     | P1I05  | P1I04    | P1I03      | P1I02     | P1I01     | P1I00     | ]           | 00        | P6-11         |
| 001A    | Port 2 Mode Register       | P2I0   | —     | P2I07     | P2I06     | P2I05  | P2I04    | P2I03      | P2I02     | P2I01     | P2I00     |             | 00        | P6-12         |
| 001C    | Port 4 Mode Register       | P4I0   |       | P4I07     | P4I06     | P4I05  | P4I04    | P4I03      | P4I02     | P4I01     | P4I00     |             | 00        | P6-14         |
| 001D    | Port 5 Mode Register       | P5I0   | _     | (1)       | (1)       | P5I05  | P5I04    | undefined  | undefined | undefined | undefined |             | undefined | P6-16         |
| 001E    | Port 6 Mode Register       | P6I0   | _     | undefined | undefined | P6I05  | P6I04    | P6I03      | P6I02     | P6I01     | P6I00     | ]           | undefined | P6-17         |
| 001F    | Port 7 Mode Register       | P7I0   |       | P7I07     | P7I06     | P7I05  | P7I04    | P7I03      | P7I02     | P7I01     | P7I00     |             | 00        | P6-19         |

MSM66587 Family User's Manual Chapter 21 Special Function Registers (SFRs)

| Address      | Function                                   | Byte     | Word |        |        |        | Bit Symb | ol     |         |         |         | R/W | 10000 | Refere-<br>nce |
|--------------|--------------------------------------------|----------|------|--------|--------|--------|----------|--------|---------|---------|---------|-----|-------|----------------|
| [H]          | Function                                   | Dyte     | word | 7      | 6      | 5      | 4        | 3      | 2       | 1       | 0       |     | State | Page           |
| 0020         | Port 8 Data Register                       | P8       |      | P8_7   | P8_6   | P8_5   | P8_4     | P8_3   | P8_2    | P8_1    | P8_0    |     | 00    | P6-21          |
| 0021         | Port 9 Data Register                       | P9       | _    | P9_7   | P9_6   | P9_5   | P9_4     | P9_3   | P9_2    | P9_1    | P9_0    |     | 00    | P6-22          |
| 0022         | Port 10 Data Register                      | P10      | _    | P10_7  | P10_6  | P10_5  | P10_4    | P10_3  | P10_2   | P10_1   | P10_0   |     | 00    | P6-24          |
| 0028         | Port 8 Mode Register                       | P8I0     | _    | P8I07  | P8106  | P8I05  | P8I04    | P8I03  | P8I02   | P8I01   | P8I00   |     | 00    | P6-21          |
| 0029         | Port 9 Mode Register                       | P9I0     |      | P9I07  | P9I06  | P9I05  | P9I04    | P9I03  | P9I02   | P9I01   | P9I00   | ]   | 00    | P6-22          |
| 002A         | Port 10 Mode Register                      | P10I0    |      | P10I07 | P10I06 | P10I05 | P10I04   | P10I03 | P10I02  | P10I01  | P10I00  | ]   | 00    | P6-24          |
| 002C         | A/D Interrupt Control Register             | ADINTCON | _    | (1)    | (1)    | 0      | 0        | ADSTIE | 0       | INTST   | 0       | 1   | C0    | P14-4          |
| 0031         | Port 1 Secondary Control Register          | P1SF     | _    | XDM15  | XDM14  | XDM13  | XDM12    | XDM11  | XDM10   | XDM9    | XDM8    | ]   | 00    | P6-11          |
| 0032         | Port 2 Secondary Control Register          | P2SF     | —    | (1)    | 0      | RT09   | RT08     | 0      | 0       | 0       | 0       | 1   | 80    | P6-12          |
| 0034         | Port 4 Secondary Control Register          | P4SF     | _    | 0      | 0      | 0      | 0        | 0      | 0       | 0       | ETMCK   | 1   | 00    | P6-14          |
| 0035         | Port 5 Secondary Control Register          | P5SF     | _    | (1)    | (1)    | ALE    | PSEN     | (1)    | (1)     | (1)     | (1)     | 1   | CF    | P6-16          |
| 0036         | Port 6 Secondary Control Register          | P6SF     | _    | 0      | 0      | TXC1   | RXC1     | TXD1   | RXD1    | INT1    | INTO    | 1   | 00    | P6-17          |
| 0037         | Port 7 Secondary Control Register          | P7SF     | _    | 0      | 0      | 0      | PWM0     | CLKOUT | WAIT    | RD      | WR      | 1   | 00    | P6-19          |
| 0039         | Port 9 Secondary Control Register          | P9SF     |      | 0      | 0      | 0      | 0        | XDM19  | XDM18   | XDM17   | XDM16   |     | 00    | P6-22          |
| 0040         |                                            | IRQOL    | IRQ0 | 0      | 0      | 0      | 0        | 0      | QTM10V  | 0       | QINTO   | R/W | 00    |                |
| 0041         | Interrupt Request Register 0               | IRQ0H    | INQU | QSCI1  | 0      | 0      | QRT09    | QRT08  | 0       | 0       | 0       | -   | 00    | 1              |
| 0042         | Interrupt Request Register 1               | IRQ1L    | _    | QINT1  | 0      | 0      | QPW01    | QAD    | 0       | QGTMOV  | QSTMOV  | 1   | 00    |                |
| 0044         |                                            | IEOL     | 150  | 0      | 0      | 0      | 0        | 0      | ETM10V  | 0       | EINTO   | 1   | 00    | 1              |
| 0045         | Interrupt Enable Register 0                | IEOH     | IE0  | ESCI1  | 0      | 0      | ERT09    | ERT08  | 0       | 0       | 0       | 1   | 00    |                |
| 0046         | Interrupt Enable Register 1                | IE1L     | _    | EINT1  | 0      | 0      | EPW01    | EAD    | 0       | EGTMOV  | ESTMOV  | 1   | 00    |                |
| 0048         | Interrupt Drightly Control Degister 00     | IP00L    | 1000 | 0      | 0      | 0      | 0        | 0      | P0TM10V | 0       | POINTO  | 1   | 00    |                |
| 0049         | Interrupt Priority Control Register 00     | IP00H    | IP00 | P0SCI1 | 0      | 0      | P0RT09   | PORTO8 | 0       | 0       | 0       | 1   | 00    | P17-6          |
| 004A         | Laterment Delayity Operators I Danistan Of | IP01L    | 1004 | 0      | 0      | 0      | 0        | 0      | P1TM10V | 0       | P1INT0  |     | 00    |                |
| 004B         | Interrupt Priority Control Register 01     | IP01H    | IP01 | P1SCI1 | 0      | 0      | P1RT09   | P1RT08 | 0       | 0       | 0       | 1   | 00    | 1              |
| 004C         | Interrupt Priority Control Register 10     | IP10L    |      | P0INT1 | 0      | 0      | P0PW01   | P0AD   | 0       | POGTMOV | POSTMOV |     | 00    |                |
| 004E         | Interrupt Priority Control Register 11     | IP11L    | —    | P1INT1 | 0      | 0      | P1PW01   | P1AD   | 0       | P1GTMOV | P1STMOV |     | 00    |                |
| 0050<br>0051 | PWM Counter 0                              |          | PWC0 |        |        |        |          |        |         |         |         | R   | FFFF  | P11-2          |

| Address | Function                              | Byte           | Word     |        | Bit Symbol |        |        |        |        | R/W    | Reset  | Refere- |           |         |
|---------|---------------------------------------|----------------|----------|--------|------------|--------|--------|--------|--------|--------|--------|---------|-----------|---------|
| [H]     | Function                              | Dyte           | woru     | 7      | 6          | 5      | 4      | 3      | 2      | 1      | 0      |         | State     | Page    |
| 0060    | DW/C0 Duffer Degister                 | —              | PWC0BF   |        |            |        |        |        |        |        |        |         | FFFF      |         |
| 0061    | PWC0 Buffer Register                  | —              | FWGUDF   |        |            |        |        |        |        |        |        |         |           | P11-3   |
| 0070    | PWR0 Buffer Register                  | —              | PW0BF    |        |            |        |        |        |        |        |        |         | 0000      | FII-5   |
| 0071    | r who bullet negister                 | _              | T WODI   |        |            |        |        |        |        |        |        | _       | 0000      |         |
| 0090    | Timer Degister 9                      | —              | TMR8     |        |            |        |        |        |        |        |        |         | 0000      |         |
| 0091    | Timer Register 8                      | —              | TIVINO   |        |            |        |        |        |        |        |        | R/W     | 0000      |         |
| 0092    | Timer Register 9                      | _              | TMR9     |        |            |        |        |        |        |        |        |         | 0000      |         |
| 0093    |                                       | _              | TIVIN9   |        |            |        |        |        |        |        |        |         | 0000      | P9-5    |
| 00B4    | RTO Control Register 8                | RTOCON4        |          | (1)    | (1)        | (1)    | (1)    | (1)    | (1)    | T8BF0  | T80UT  |         | FC        |         |
| 00B5    | RTO Control Register 9                | RTOCON5        |          | (1)    | (1)        | (1)    | (1)    | (1)    | (1)    | T9BF0  | T90UT  |         | FC        | ]       |
| 00C2    | Timer Counter 1                       | —              | TM1      |        |            |        |        |        |        |        |        |         | 0000      | P9-2    |
| 00C3    |                                       | —              | I IVI I  |        |            |        |        |        |        |        |        |         | 0000      | F9-2    |
| 00D0    | A/D Result Register 0                 | ADCR0          | —        |        |            |        |        |        |        |        |        | R       | undefined | P14-4   |
| 00E1    | A/D Control Register H                | ADCONH         | —        | (1)    | ADTM1      | ADTM0  | STS    | 0      | 0      | ADSTM1 | ADSTM0 |         | 80        | P14-3   |
| 00E2    | Timer Control Register                | TMCON          | —        | TM1RUN | TM1CK2     | TM1CK1 | TM1CK0 | 0      | 0      | 0      | 0      |         | 00        | _       |
| 00E4    | TM Setting Register                   |                | TMSEL    | 0      | 0          | 0      | 0      | 0      | 0      | 0      | 0      |         | 0300      | P9-3    |
| 00E5    |                                       | _              | TWOLL    | 0      | 0          | 0      | 0      | 0      | 0      | 1      | 1      |         | 0300      |         |
| 00E6    | TMR Mode Register                     | TMRMODE        | —        | 0      | 0          | 0      | 0      | T9MD1  | T9MD0  | T8MD1  | T8MD0  |         | 00        | P9-6    |
| 00EB    | PWM Run Register                      | PWRUN          |          | 0      | 0          | 0      | 0      | 0      | 0      | 0      | PWORUN |         | 00        | - P11-4 |
| 00EC    | PWM Control Register 0                | PWCON0         |          | 0      | 0          | 0      | 0      | PW0ACT | PW0CK2 | PW0CK1 | PW0CK0 | _       | 00        | P11-4   |
| 00F0    | PWM Interrupt Register 0              | <b>PWINTQ0</b> | PWINTQ   | 0      | 0          | 0      | 0      | 0      | 0      | 0      | QPW0   | R/W     | 00        | P11-5   |
| 00F1    | PWM Interrupt Register 1              | PWINTQ1        | FWINIQ   | 0      | 0          | 0      | 0      | 0      | 0      | 0      | QPWR0  |         | 00        | P11-0   |
| 00F2    | PWM Interrupt Enable Register 0       | PWINTE0        | PWINTE   | 0      | 0          | 0      | 0      | 0      | 0      | 0      | EPW0   |         | 00        | P11-6   |
| 00F3    | PWM Interrupt Enable Register 1       | PWINTE1        | PVVIIVIE | 0      | 0          | 0      | 0      | 0      | 0      | 0      | EPWR0  |         | 00        | PII-0   |
| 00F6    | SCI1 Transmit/Receive Buffer Register | S1BUF          |          |        |            |        |        |        |        |        |        |         | undefined | I P13-5 |
| 00F7    | SCI1 Status Register                  | S1STAT         |          | TR1IRQ | TR1IE      | RV1IRQ | RV1IE  | 0      | 0      | 0ERR1  | 0      |         | 00        | P13-6   |
| 00F8    | General 8-Bit Timer Control Register  | GTMCON         | _        | 0      | 0          | (1)    | (1)    | GTMRUN | GTMCK2 | GTMCK1 | GTMCK0 |         | 30        |         |
| 00FA    | General 8-Bit Timer Counter           | GTMC           | _        |        |            |        |        |        |        |        |        |         | 00        | P10-2   |
| 00FB    | General 8-Bit Timer Register          | GTMR           |          |        |            |        |        |        |        |        |        |         | 00        | 1       |

#### Expanded SFR Area

| Address        | <b>F</b> unction                       | Byte    | Word    |           |           |         | Bit Symb | ol      |         |         |         | R/W | Reset     | Refere-        |
|----------------|----------------------------------------|---------|---------|-----------|-----------|---------|----------|---------|---------|---------|---------|-----|-----------|----------------|
| [H]            | Function                               | -       | word    | 7         | 6         | 5       | 4        | 3       | 2       | 1       | 0       |     | State     | Page           |
| 0100           | Memory Size Acceptor                   | MEMSACP |         |           |           |         |          |         |         |         |         | W   | "0"       | <b>DO</b> 4    |
| 0101           | Memory Size Control Register           | MEMSCON |         | (1)       | (1)       | (1)     | (1)      | (1)     | (1)     | LROM    | LRAM    |     | FC        | P3-1           |
| 0107           | Peripheral Control Register            | PRPHF   |         | undefined | undefined | (1)     | (1)      | (1)     | (1)     | CKOUT1  | CKOUTO  |     | undefined | P15-1          |
| 0108           | NMI Control Register                   | NMICON  | _       | NMIRD     | (1)       | (1)     | (1)      | (1)     | (1)     | NMIM1   | NMIM0   |     | FCor7C    | P16-3          |
| 0109           | External Interrupt Control Register    | EXICON  |         | EX3M1     | EX3M0     | EX2M1   | EX2M0    | EX1M1   | EX1M0   | EX0M1   | EX0M0   |     | 00        | P16-2          |
| 010C           | Interrupt Request Register 2           | IRQ2L   |         | 0         | 0         | 0       | 0        | QINT3   | QINT2   | 0       | 0       |     | 00        |                |
| 010D           | Interrupt Enable Register 2            | IE2L    | —       | 0         | 0         | 0       | 0        | EINT3   | EINT2   | 0       | 0       |     | 00        | D17.4          |
| 010E           | Interrupt Priority Control Register 20 | IP20L   |         | 0         | 0         | 0       | 0        | P0INT3  | P0INT2  | 0       | 0       | R/W | 00        | P17-4<br>P17-5 |
| 010F           | Interrupt Priority Control Register 21 | IP21L   |         | 0         | 0         | 0       | 0        | P1INT3  | P1INT2  | 0       | 0       |     | 00        |                |
| 0118           | SCI1Timer Counter                      | —       | S1TM    |           |           |         |          |         |         |         |         |     | 0000      | <b>B</b> 40.0  |
| 0119           | SCI1Timer Register                     | —       | 51111   |           |           |         |          |         |         |         |         |     | 0000      | P12-2          |
| 011A           | SCI1Timer Control Register             | S1CON   | _       | S1CK2     | S1CK1     | S1CK0   | S1RUN    | ESTM1   | QSTM1   | (1)     | S1MOD   | ]   | 02        | P12-3          |
| 011B           | SCI1Transmit Control Register          | ST1CON  | —       | (1)       | 0         | 0       | ST1MST   | (1)     | 1       | 1       | 0       | R   | 8E        | P13-4          |
| 011C           | SCI1Transmit/Receive Control Register  | SR1CON  | —       | SR1REN    | 0         | 0       | SR1MST   | (1)     | 1       | 1       | 0       | R/W | 0E        | P13-3          |
| 011E           | TBC Clock Dividing Counter             | TBCKDVC |         | (1)       | (1)       | (1)     | (1)      |         |         |         |         | R   | F0        | P8-2           |
| 011F           | TBC Clock Division Register            | TBCKDVR | _       | (1)       | (1)       | (1)     | (1)      |         |         |         |         |     | F0        | F0-2           |
| 0120           | Port 12 Data Register                  | P12     | _       | P12_7     | P12_6     | P12_5   | P12_4    | P12_3   | P12_2   | P12_1   | P12_0   |     | 00        |                |
| 0122           | Port 12 Mode Register                  | P12I0   | _       | P12I07    | P12I06    | P12I05  | P12I04   | P12I03  | P12I02  | P12I01  | P12I00  |     | 00        | P6-25          |
| 0124           | Port 12 Secondary Control Register     | P12SF   | —       | 0         | 0         | 0       | 0        | INT3    | INT2    | 0       | 0       |     | 00        |                |
| 0130           | Port 0 Pull-Up Control Register        | POPUP   | _       | P0PUP7    | P0PUP6    | P0PUP5  | P0PUP4   | P0PUP3  | P0PUP2  | P0PUP1  | P0PUP0  | R/W | 00        | P6-10          |
| 0131           | Port 1 Pull-Up Control Register        | P1PUP   |         | P1PUP7    | P1PUP6    | P1PUP5  | P1PUP4   | P1PUP3  | P1PUP2  | P1PUP1  | P1PUP0  |     | 00        | P6-11          |
| 0134           | Port 4 Pull-Up Control Register        | P4PUP   | _       | P4PUP7    | P4PUP6    | P4PUP5  | P4PUP4   | P4PUP3  | P4PUP2  | P4PUP1  | P4PUP0  |     | 00        | P6-14          |
| 0139           | Port 9 Pull-Up Control Register        | P9PUP   | _       | P9PUP7    | P9PUP6    | P9PUP5  | P9PUP4   | P9PUP3  | P9PUP2  | P9PUP1  | P9PUP0  |     | 00        | P6-22          |
| 013A           | Port 10 Pull-Up Control Register       | P10PUP  |         | P10PUP7   | P10PUP6   | P10PUP5 | P10PUP4  | P10PUP3 | P10PUP2 | P10PUP1 | P10PUP0 |     | 00        | P6-24          |
| s≵01F0         | Flash Memory Acceptor                  | FLAACP  |         | —         | _         | _       | _        |         |         |         |         | W   | "0"       | <b>D</b> 40.0  |
| <b>Ֆ</b> 01F1  | Flash Memory Control Register          | FLACON  | _       | —         | —         | _       | FCLK1    | FCLK0   | —       | SERS    | PRG     |     | E4        | P19-8          |
| ☆01F2<br>☆01F3 | Flash Memory Address Register          | —       | FLAADRS |           |           | —       | —        | —       | —       | —       | —       | R/W | undefined | P19-7          |

## 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).

### MSM66587 Family

User's Manual

First Edition:September 1997Second Edition:January 2000

© 2000 Oki Electric Industry Co., Ltd.

FEUL66587-02