

# CMOS 8-BIT SINGLE CHIP MICROCOMPUTER **E0C88365 TECHNICAL MANUAL**

E0C88365 Technical Hardware E0C88365 Technical Software





## CMOS 8-bit Single Chip Microcomputer

# **E0C88365 Technical Manual**

#### Introduction

This Manual contains separate descriptions of the hardware and software of the E0C88365 CMOS 8-bit single chip microcomputers.

## I. E0C88365 Technical Hardware

This section of the Manual describes the functions, circuit configuration and control system of the E0C88365.

### II. E0C88365 Technical Software

This section of the Manual describes the programming of the E0C88365.

# **I** E0C88365 Technical Hardware

# Contents

| 1 | INT | FRODUCTION                                                    | <i>I-1</i>  |
|---|-----|---------------------------------------------------------------|-------------|
|   | 1.1 | Features                                                      | I-1         |
|   | 1.2 | Block Diagram                                                 | <i>I-2</i>  |
|   | 1.3 | Pin Layout Diagram                                            | <i>I-3</i>  |
| 2 | PO  | WER SUPPLY                                                    | I-4         |
|   | 2.1 | Operating Voltage                                             | <i>I-4</i>  |
|   | 2.2 | Internal Power Supply Circuit                                 |             |
|   | 2.3 | Heavy Load Protection Mode                                    |             |
| 3 | CPl | U AND BUS CONFIGURATION                                       |             |
|   | 3.1 | CPU                                                           |             |
|   | 3.2 | Internal Memory                                               |             |
|   |     | 3.2.1 ROM                                                     | <i>I-5</i>  |
|   |     | 3.2.2 RAM                                                     |             |
|   |     | 3.2.3 I/O memory                                              |             |
|   | 3.3 | Exception Processing Vectors                                  |             |
|   | 3.4 | CC (Customized Condition Flag)                                |             |
|   | 3.5 | Chip Mode                                                     |             |
|   |     | 3.5.1 MCU mode and MPU mode                                   | <i>I-6</i>  |
|   |     | 3.5.2 Bus mode                                                |             |
|   | 3.6 | External Bus                                                  |             |
|   |     | 3.6.1 Data bus 3.6.2 Address bus                              |             |
|   |     | 3.6.3 Read $(\overline{RD})$ /write $(\overline{WR})$ signals |             |
|   |     | 3.6.4 Chip enable ( $\overline{CE}$ ) signal                  |             |
|   |     | 3.6.5 WAIT control                                            | <i>I-11</i> |
|   |     | 3.6.6 Bus authority release state                             |             |
| 4 | INI | TIAL RESET                                                    | <i>I-13</i> |
|   | 4.1 | Initial Reset Factors                                         |             |
|   |     | 4.1.1 RESET terminal                                          |             |
|   | 4.0 | 4.1.2 Initial reset sequence                                  |             |
|   | 4.2 | Initial Settings After Initial Reset                          |             |
| 5 | PEI | RIPHERAL CIRCUITS AND THEIR OPERATION                         | <i>I-15</i> |
|   | 5.1 | I/O Memory Map                                                |             |
|   | 5.2 | System Controller and Bus Control                             |             |
|   |     | 5.2.1 Bus mode settings                                       |             |
|   |     | 5.2.2 Address decoder ( $\overline{CE}$ output) settings      |             |
|   |     | 5.2.4 Setting the bus authority release request signal        |             |
|   |     | 5.2.5 Stack page setting                                      |             |
|   |     | 5.2.6 Control of system controller                            | <i>I-30</i> |
|   |     | 5.2.7 Programming notes                                       | <i>I-32</i> |

| 5.3     | Watchdog Timer                                         |             |
|---------|--------------------------------------------------------|-------------|
|         | 5.3.1 Configuration of watchdog timer                  | I-33        |
|         | 5.3.2 Interrupt function                               | I-33        |
|         | 5.3.3 Control of watchdog timer                        | I-33        |
|         | 5.3.4 Programming note                                 | <i>I-33</i> |
| 5.4     | Oscillation Circuit                                    | I-34        |
|         | 5.4.1 Configuration of oscillation circuits            |             |
|         | 5.4.2 Mask option                                      |             |
|         | 5.4.3 OSC1 oscillation circuit                         |             |
|         | 5.4.4 OSC3 oscillation circuit                         |             |
|         | 5.4.5 Switching the CPU clocks                         |             |
|         | 5.4.6 Control of oscillation circuit                   |             |
|         | 5.4.7 Programming notes                                |             |
| <i></i> |                                                        |             |
| 5.5     | Input Ports (K ports)                                  |             |
|         | 5.5.1 Configuration of input ports                     |             |
|         | 5.5.2 Mask option                                      |             |
|         | 5.5.3 Interrupt function and input comparison register |             |
|         | 5.5.4 Control of input ports                           |             |
|         | 5.5.5 Programming note                                 |             |
| 5.6     | Output Ports (R ports)                                 |             |
|         | 5.6.1 Configuration of output ports                    |             |
|         | 5.6.2 Mask option                                      |             |
|         | 5.6.3 High impedance control                           |             |
|         | 5.6.4 DC output                                        |             |
|         | 5.6.5 Special output                                   |             |
|         | 5.6.6 Control of output ports                          |             |
|         | 5.6.7 Programming notes                                |             |
| 5.7     | I/O Ports (P ports)                                    |             |
|         | 5.7.1 Configuration of I/O ports                       | I-53        |
|         | 5.7.2 Mask option                                      |             |
|         | 5.7.3 I/O control registers and I/O mode               |             |
|         | 5.7.4 Control of I/O ports                             |             |
|         | 5.7.5 Programming notes                                | <i>I-56</i> |
| 5.8     | Serial Interface                                       | <i>I-57</i> |
|         | 5.8.1 Configuration of serial interface                | I-57        |
|         | 5.8.2 Mask option                                      | I-58        |
|         | 5.8.3 Transfer modes                                   | I-58        |
|         | 5.8.4 Clock source                                     | I-59        |
|         | 5.8.5 Transmit-receive control                         | I-60        |
|         | 5.8.6 Operation of clock synchronous transfer          | I-61        |
|         | 5.8.7 Operation of asynchronous transfer               | I-65        |
|         | 5.8.8 Interrupt function                               |             |
|         | 5.8.9 Control of serial interface                      | I-71        |
|         | 5.8.10 Programming notes                               | I-75        |
| 5.9     | Clock Timer                                            | <i>I-76</i> |
|         | 5.9.1 Configuration of clock timer                     |             |
|         | 5.9.2 Interrupt function                               |             |
|         | 5.9.3 Control of clock timer                           |             |
|         | 5.9.4 Programming notes                                |             |
| 5.10    | Stopwatch Timer                                        |             |
| 0       | 5.10.1 Configuration of stopwatch timer                |             |
|         | 5.10.2 Count up pattern                                |             |

|      | 5.10.3 Interrupt function                                       | <i>I-82</i>    |
|------|-----------------------------------------------------------------|----------------|
|      | 5.10.4 Control of stopwatch timer                               | <i>I-83</i>    |
|      | 5.10.5 Programming notes                                        | <i>I-85</i>    |
| 5.11 | Programmable Timer                                              | . I-86         |
|      | 5.11.1 Configuration of programmable timer                      |                |
|      | 5.11.2 Count operation and setting basic mode                   |                |
|      | 5.11.3 Setting of input clock                                   |                |
|      | 5.11.4 Timer mode                                               |                |
|      | 5.11.5 Event counter mode                                       |                |
|      | 5.11.6 Pulse width measurement timer mode                       | <i>I-89</i>    |
|      | 5.11.7 Interrupt function                                       |                |
|      | 5.11.8 Setting of TOUT output                                   | <i>I-90</i>    |
|      | 5.11.9 Transmission rate setting of serial interface            |                |
|      | 5.11.10 Control of programmable timer                           | <i>I-92</i>    |
|      | 5.11.11 Programming notes                                       | <i>I-9</i> 8   |
| 5.12 | LCD Controller                                                  | . <i>I-99</i>  |
|      | 5.12.1 Configuration of LCD controller                          |                |
|      | 5.12.2 LCD power supply                                         |                |
|      | 5.12.3 LCD driver                                               |                |
|      | 5.12.4 Display memory                                           | . <i>I-101</i> |
|      | 5.12.5 Display control                                          | . <i>I-103</i> |
|      | 5.12.6 CL and FR outputs                                        | . <i>I-103</i> |
|      | 5.12.7 Control of LCD controller                                | . <i>I-104</i> |
|      | 5.12.8 Programming notes                                        | . <i>I-105</i> |
| 5.13 | Sound Generator                                                 | I-106          |
|      | 5.13.1 Configuration of sound generator                         |                |
|      | 5.13.2 Control of buzzer output                                 |                |
|      | 5.13.3 Setting of buzzer frequency and sound level              |                |
|      | 5.13.4 Digital envelope                                         |                |
|      | 5.13.5 One-shot output                                          |                |
|      | 5.13.6 Control of sound generator                               | . <i>I-109</i> |
|      | 5.13.7 Programming notes                                        | . <i>I-111</i> |
| 5.14 | Analog Comparator                                               | <i>I-112</i>   |
| 0.11 | 5.14.1 Configuration of analog comparator                       |                |
|      | 5.14.2 Mask option                                              |                |
|      | 5.14.3 Analog comparator operation                              |                |
|      | 5.14.4 Control of analog comparator                             |                |
|      | 5.14.5 Programming notes                                        |                |
| 5.15 | Supply Voltage Detection (SVD) Circuit                          |                |
| 5.15 | 5.15.1 Configuration of SVD circuit                             |                |
|      | 5.15.2 Operation of SVD circuit                                 |                |
|      | 5.15.3 Control of SVD circuit                                   |                |
|      | 5.15.4 Programming notes                                        |                |
| 5 16 |                                                                 |                |
| 5.16 | Interrupt and Standby Status                                    |                |
|      | 5.16.1 Interrupt generation conditions                          |                |
|      | 5.16.2 Interrupt factor flag                                    |                |
|      | 5.16.4 Interrupt priority register and interrupt priority level |                |
|      | 5.16.5 Exception processing vectors                             |                |
|      | 5.16.6 Control of interrupt                                     |                |
|      | 5.16.7 Programming notes                                        |                |
| 5 17 |                                                                 |                |
| 5.17 | Notes for Low Current Consumbtion                               | 1-140          |

#### **CONTENTS**

| 6 | BAS | SIC EXTERNAL WIRING DIAGRAM              | I-124        |
|---|-----|------------------------------------------|--------------|
| 7 | ELI | ECTRICAL CHARACTERISTICS                 | I-125        |
|   | 7.1 | Absolute Maximum Rating                  | <i>I-125</i> |
|   | 7.2 | Recommended Operating Conditions         | <i>I-125</i> |
|   | 7.3 | DC Characteristics                       | <i>I-126</i> |
|   | 7.4 | Analog Circuit Characteristics           | <i>I-127</i> |
|   | 7.5 | Power Current Consumption                | <i>I-129</i> |
|   | 7.6 | AC Characteristics                       | <i>I-129</i> |
|   | 7.7 | Oscillation Characteristics              | <i>I-133</i> |
|   | 7.8 | Characteristics Curves (reference value) | <i>I-134</i> |
| 8 | PAI | D LAYOUT                                 | I-140        |
|   | 8.1 | Diagram of Pad Layout                    | I-140        |
|   | 8.2 | Pad Coordinates                          | I-141        |

# 1 INTRODUCTION

The E0C88365 microcomputer features the E0C88 (Model 3) CMOS 8-bit core CPU along with 64K bytes of ROM, 3K bytes of RAM, three different timers and a serial interface with optional asynchronization or clock synchronization.

These devices are fully operable over a wide range of voltages, and can perform high speed operations even at low voltage. Like all the equipment in the E0C Family, these microcomputers have low power consumption. A 19-bit external address bus and 4 bits chip enable signals make it possible for these microcomputers to control up to  $512K \times 4$  bytes of memory, making them ideal for high performance data bank and pager systems.

#### 1.1 Features

Table 1.1.1 lists the features of the E0C88365.

Table 1.1.1 Main features

| Model                             | E0C88365                                                                                                          |  |  |  |  |  |  |
|-----------------------------------|-------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Core CPU                          | E0C88 (MODEL3) CMOS 8-bit core CPU                                                                                |  |  |  |  |  |  |
| OSC1 Oscillation circuit          | Crystal oscillation circuit/external clock input 32.768 kHz/38.4 kHz/76.8 kHz/96 kHz/153.6 kHz (Typ.)             |  |  |  |  |  |  |
| OSC3 Oscillation circuit          | CR oscillation circuit 2.5 MHz (Max.)                                                                             |  |  |  |  |  |  |
| Instruction set                   | 608 types (Usable for multiplication and division instructions)                                                   |  |  |  |  |  |  |
| Min. instruction execution time   | 0.8 μsec/2.5 MHz (2 clock)                                                                                        |  |  |  |  |  |  |
| Internal ROM capacity             | 64K byte                                                                                                          |  |  |  |  |  |  |
| Internal RAM capacity             | 3K byte/RAM                                                                                                       |  |  |  |  |  |  |
|                                   | 4,608 bits/display memory                                                                                         |  |  |  |  |  |  |
| Bus line                          | Address bus: 19 bits (Also usable as a general output port when not used as a bus)                                |  |  |  |  |  |  |
|                                   | Data bus: 8 bits (Also usable as a general I/O port when not used as a bus)                                       |  |  |  |  |  |  |
|                                   | CE signal: 4 bits ¬                                                                                               |  |  |  |  |  |  |
|                                   | WR signal: 1 bit (Also usable as a general output port when not used as a bus)                                    |  |  |  |  |  |  |
|                                   | RD signal: 1 bit                                                                                                  |  |  |  |  |  |  |
| Input port                        | 10 bits (2 bits can be set for event counter external clock input and bus request signal input terminal)          |  |  |  |  |  |  |
| Output port                       | 17 bits (6 bits can be set for buzzer output, LCD control, FOUT, TOUT and bus acknowledge signal output terminal) |  |  |  |  |  |  |
| I/O port                          | 8 bits (4 bits each can be set for serial interface input/output and analog comparator input)                     |  |  |  |  |  |  |
| Serial interface                  | 1ch (Optional clock synchronous system or asynchronous system)                                                    |  |  |  |  |  |  |
| Timer                             | Programmable timer (8 bits): 2ch                                                                                  |  |  |  |  |  |  |
|                                   | (1ch can be set as a an event counter or 2ch as a 16 bits programmable timer for 1ch)                             |  |  |  |  |  |  |
|                                   | Clock timer (8 bits): 1ch                                                                                         |  |  |  |  |  |  |
|                                   | Stopwatch timer (8 bits): 1ch                                                                                     |  |  |  |  |  |  |
| Power supply circuit to           | Built-in (booster type, 5 potentials)                                                                             |  |  |  |  |  |  |
| drive liquid crystals             |                                                                                                                   |  |  |  |  |  |  |
| LCD driver                        | Dot matrix type                                                                                                   |  |  |  |  |  |  |
|                                   | 80 segments × 18 commons (1/5 bias)                                                                               |  |  |  |  |  |  |
|                                   | Expandable external LCD driver                                                                                    |  |  |  |  |  |  |
| Sound generator                   | Envelope function, equipped with volume control                                                                   |  |  |  |  |  |  |
| Watchdog timer                    | Built-in                                                                                                          |  |  |  |  |  |  |
| Analog comparator                 | 2ch built-in                                                                                                      |  |  |  |  |  |  |
| Supply voltage detection          | Can detect up to 16 different voltage levels                                                                      |  |  |  |  |  |  |
| (SVD) circuit                     |                                                                                                                   |  |  |  |  |  |  |
| Interrupt                         | External interrupt: Input interrupt 2 systems (3 types)                                                           |  |  |  |  |  |  |
|                                   | Internal interrupt: Timer interrupt 3 systems (9 types)                                                           |  |  |  |  |  |  |
|                                   | Serial interface interrupt 1 system (3 types)                                                                     |  |  |  |  |  |  |
| Supply voltage                    | 2.2 V–5.5 V (Max. 2.5 MHz)                                                                                        |  |  |  |  |  |  |
| Con- SLEEP                        | 300 nA (Typ.)                                                                                                     |  |  |  |  |  |  |
| sumed HALT (32.768 kHz)           | 2 μA (Typ.)                                                                                                       |  |  |  |  |  |  |
| current In operation (32.768 kHz) | 14 µА (Тур.)                                                                                                      |  |  |  |  |  |  |
| In operation (2.5 MHz)            | 1.5 mA (Typ.)                                                                                                     |  |  |  |  |  |  |
| Supply form                       | Chip                                                                                                              |  |  |  |  |  |  |

<sup>\*</sup> The number of bits cited for output ports and I/O ports does not include those shared with the bus.

# 1.2 Block Diagram



Fig. 1.2.1 E0C88365 block diagram

# 1.3 Pin Layout Diagram

Table 1.3.1 E0C88365 pin description

| Pin name                                 | Pin No.       | In/out    | Function                                                                                                |
|------------------------------------------|---------------|-----------|---------------------------------------------------------------------------------------------------------|
| V <sub>DD</sub>                          | 93            | - III/OUL | Power supply (+) terminal                                                                               |
|                                          |               |           |                                                                                                         |
| Vss                                      | 94, 126, 151  | _         | Power supply (GND) terminal                                                                             |
| VD1                                      | 92            | -         | Regulated voltage output terminal for oscillators                                                       |
| VC1-VC5                                  | 89–85         | О         | LCD drive voltage output terminals                                                                      |
| CA-CE                                    | 84–80         | _<br>     | Booster capacitor connection terminals for LCD                                                          |
| OSC1                                     | 95            | I         | OSC1 oscillation input terminal                                                                         |
| 0000                                     | 0.6           |           | (select crystal oscillation/external clock input with mask option)                                      |
| OSC2                                     | 96            | 0         | OSC1 oscillation output terminal                                                                        |
| OSC3                                     | 90            | I         | OSC3 oscillation input terminal                                                                         |
| OSC4                                     | 91            | 0         | OSC3 oscillation output terminal                                                                        |
| MCU/MPU                                  | 99            | I         | Terminal for setting MCU or MPU modes                                                                   |
| K00-K07                                  | 109–102       | I         | Input port (K00–K07) terminal                                                                           |
| K10/EVIN                                 | 101           | I         | Input port (K10) terminal or event counter external clock (EVIN) input terminal                         |
| K11/BREQ                                 | 100           | I         | Input port (K11) terminal or bus request signal (BREQ) input terminal                                   |
| R00-R07/A0-A7                            | 127–134       | О         | Output port (R00–R07) terminals or address bus (A0–A7)                                                  |
| R10-R17/A8-A15                           | 135–142       | 0         | Output port (R10–R17) terminals or address bus (A8–A15)                                                 |
| R20-R22/A16-A18                          | 143–145       | 0         | Output port (R20–R22) terminals or address bus (A16–A18)                                                |
| R23/RD                                   | 146           | О         | Output port (R23) terminal or read signal (RD) output terminal                                          |
| $R24/\overline{WR}$                      | 147           | О         | Output port (R24) terminal or write signal (WR) output terminal                                         |
| R25/CL                                   | 148           | О         | Output port (R25) terminal or LCD synchronous signal (CL) output terminal                               |
| R26/FR                                   | 149           | О         | Output port (R26) terminal or LCD frame signal (FR) output terminal                                     |
| R27/TOUT                                 | 150           | О         | Output port (R27) terminal                                                                              |
|                                          |               |           | or programmable timer underflow signal (TOUT) output terminal                                           |
| R30-R33/ <del>CE0</del> - <del>CE3</del> | 152–155       | 0         | Output port (R30–R33) terminals or chip enable ( $\overline{CE0}$ – $\overline{CE3}$ ) output terminals |
| R34/FOUT                                 | 156           | О         | Output port (R34) terminal or clock (FOUT) output terminal                                              |
| R35-R37                                  | 157–159       | О         | Output port (R35–R37) terminal                                                                          |
| R40-R47                                  | 160–167       | О         | Output port (R40–R47) terminal                                                                          |
| R50/BZ                                   | 168           | О         | Output port (R50) terminal or buzzer (BZ) output terminal                                               |
| R51/BACK                                 | 169           | О         | Output port (R51) terminal or bus acknowledge signal (BACK) output terminal                             |
| P00-P07/D0-D7                            | 125–118       | I/O       | I/O port (P00–P07) terminals or data bus (D0–D7)                                                        |
| P10/SIN                                  | 117           | I/O       | I/O port (P10) terminal or serial I/F data input (SIN) terminal                                         |
| P11/SOUT                                 | 116           | I/O       | I/O port (P11) terminal or serial I/F data output (SOUT) terminal                                       |
| P12/SCLK                                 | 115           | I/O       | I/O port (P12) terminal or serial I/F clock (SCLK) I/O terminal                                         |
| P13/SRDY                                 | 114           | I/O       | I/O port (P13) terminal or serial I/F ready signal (SRDY) output terminal                               |
| P14/CMPP0                                | 113           | I/O       | I/O port (P14) terminal or comparator 0 non-inverted input terminal                                     |
| P15/CMPM0                                | 112           | I/O       | I/O port (P15) terminal or comparator 0 inverted input terminal                                         |
| P16/CMPP1                                | 111           | I/O       | I/O port (P16) terminal or comparator 1 non-inverted input terminal                                     |
| P17/CMPM1                                | 110           | I/O       | I/O port (P17) terminal or comparator 1 inverted input terminal                                         |
| COM0-COM17                               | 79–62         | 0         | LCD common output terminals                                                                             |
| SEG0-SEG79                               | 170–188, 1–61 | 0         | LCD segment output terminals                                                                            |
| RESET                                    | 98            | I         | Initial reset input terminal                                                                            |
| TEST *1                                  | 97            | I         | Test input terminal                                                                                     |

<sup>\*1</sup>  $\overline{\text{TEST}}$  is the terminal used for shipping inspection of the IC. For normal operation be sure it is connected to VDD.

# 2 POWER SUPPLY

In this section, we will explain the operating voltage and the configuration of the internal power supply circuit of the E0C88365.

# 2.1 Operating Voltage

The E0C88365 operating power voltage is as follows:

2.2 V to 5.5 V

# 2.2 Internal Power Supply Circuit

The E0C88365 incorporate the power supply circuit shown in Figure 2.2.1. When voltage within the range described above is supplied to VDD (+) and Vss (GND), all the voltage needed for the internal circuit is generated internally in the IC.

Roughly speaking, the power supply circuit is divided into two sections.

One section is the oscillation system voltage regulator. The oscillation and internal circuits operate on the voltage VD1, output by this circuit. VD1 voltage value is approx. 2.1 V.

Note: Under no circumstances should V<sub>D1</sub> terminal output be used to drive external circuit.

The second circuit section is the power supply circuit for the LCD system which generates the drive voltage for the LCD. Drive voltage has five potentials VC1–VC5 for 1/5 bias: VC1 and VC2 are generated by the LCD voltage regulator, and are boosted to generate VC3–VC5. These five potentials are output externally at each of the terminals and can be used to supply an external expanded LCD driver.

See Chapter 7, "ELECTRICAL CHARACTERIS-TICS" for the voltage values.

In the E0C88365, the LCD drive voltage is supplied to the built-in LCD driver which drives the LCD panel connected to the SEG and COM terminals.

Note: Do not use terminals Vc1–Vc5 except to supply voltage to the expanded LCD driver. The load resistor between the Vss and Vc1 terminals is necessary when a large LCD panel is used.

# 2.3 Heavy Load Protection Mode

The E0C88365 has a heavy load protection function for stable operation even when the supply voltage fluctuates by driving a heavy load. The heavy load protection mode becomes valid when the peripheral circuits are in the following status:

- (1) The OSC3 oscillation circuit is switched ON (OSCC = "1" and not in SLEEP)
- (2) The buzzer output is switched ON (BZON = "1" or BZSHT = "1")



Fig. 2.3.1 Configuration of heavy load protection mode control circuit

For details of the OSC3 oscillation circuit and buzzer output, see "5.4 Oscillation Circuit" and "5.13 Sound Generator", respectively.



# 3 CPU AND BUS CONFIGURATION

In this section, we will explain the CPU, operating mode and bus configuration.

#### 3.1 CPU

The E0C88365 utilize the E0C88 8-bit core CPU whose resistor configuration, command set, etc. are virtually identical to other units in the family of processors incorporating the E0C88.

See the "E0C88 Core CPU Manual" for the E0C88.

Specifically, the E0C88365 employ the Model 3 E0C88 CPU which has a maximum address space of 512K bytes  $\times$  4.

# 3.2 Internal Memory

The E0C88365 is equipped with internal ROM and RAM as shown in Figure 3.2.1. Small scale applications can be handled by one chip. It is also possible to utilize internal memory in combination with external memory.

Furthermore, internal ROM can be disconnected from the bus and the resulting space released for external applications.

|         | E0C88365           |
|---------|--------------------|
| 011FFFH | ROM<br>(8K bytes)  |
| 010000H |                    |
| 00FFFFH | I/O memory         |
| 00FF00H |                    |
| 00FD5FH | Display memory     |
| 00F800H |                    |
| 00F7FFH | RAM<br>(3K bytes)  |
| 00EC00H |                    |
| 00EBFFH | Undefined<br>area  |
| 00E000H |                    |
| 00DFFFH | ROM<br>(56K bytes) |
| 00000Н  |                    |

Fig. 3.2.1 Internal memory map

#### 3.2.1 ROM

The internal ROM capacity is shown in Table 3.2.1.1.

Table 3.2.1.1 Internal ROM capacity

| Model    | ROM capacity | Address         |  |  |
|----------|--------------|-----------------|--|--|
| E0C88365 | 64K bytes    | 000000H-00DFFFH |  |  |
|          |              | 010000H-011FFFH |  |  |

The ROM areas shown above can be released to external memory depending on the setting of the  $MCU/\overline{MPU}$  terminal. (See "3.5 Chip Mode".)

#### 3.2.2 RAM

The internal RAM capacity is shown in Table 3.2.2.1.

Table 3.2.2.1 Internal RAM capacity

| Model    | RAM capacity | Address         |  |  |
|----------|--------------|-----------------|--|--|
| E0C88365 | 3K bytes     | 00EC00H-00F7FFH |  |  |

Even when external memory which overlaps the internal RAM area is expanded, the RAM area is not released to external memory. Access to this area is via internal RAM.

#### 3.2.3 I/O memory

A memory mapped I/O method is employed in the E0C88365 for interfacing with internal peripheral circuit. Peripheral circuit control bits and data register are arranged in data memory space. Control and data exchange are conducted via normal memory access. I/O memory is arranged in page 0: 00FF00H–00FFFFH area.

See Section 5.1, "I/O Memory Map", for details of the I/O memory.

Even when external memory which overlaps the I/O memory area is expanded, the I/O memory area is not released to external memory. Access to this area is via I/O memory.

### 3.2.4 Display memory

The E0C88365 is equipped with an internal display memory which stores a display data for LCD driver.

Display memory is arranged in page 0: 00Fx00H-00Fx5FH (x = 8-DH) in the data memory area. See Section 5.12, "LCD Controller", for details of the display memory. Like the I/O memory, display memory cannot be released to external memory.

# 3.3 Exception Processing Vectors

000000H–000023H in the program area of the E0C88365 is assigned as exception processing vectors. Furthermore, from 000026H to 0000FFH, software interrupt vectors are assignable to any two bytes which begin with an even address. Table 3.3.1 lists the vector addresses and the exception processing factors to which they correspond.

Table 3.3.1 Vector addresses and the corresponding exception processing factors

|                | exception processing juctors               |              |
|----------------|--------------------------------------------|--------------|
| Vector address | Exception processing factor                | Priority     |
| 000000H        | Reset                                      | High         |
| 000002H        | Zero division                              | $\uparrow$   |
| 000004H        | Watchdog timer (NMI)                       |              |
| 000006Н        | Programmable timer 1 interrupt             |              |
| 000008H        | Programmable timer 0 interrupt             |              |
| 00000AH        | K10, K11 input interrupt                   |              |
| 00000CH        | K04-K07 input interrupt                    |              |
| 00000EH        | K00-K03 input interrupt                    |              |
| 000010H        | Serial I/F error interrupt                 |              |
| 000012H        | Serial I/F receiving complete interrupt    |              |
| 000014H        | Serial I/F transmitting complete interrupt |              |
| 000016H        | Stopwatch timer 100 Hz interrupt           |              |
| 000018H        | Stopwatch timer 10 Hz interrupt            |              |
| 00001AH        | Stopwatch timer 1 Hz interrupt             |              |
| 00001CH        | Clock timer 1/60 Hz interrupt              |              |
| 00001EH        | Clock timer 8 Hz interrupt                 |              |
| 000020H        | Clock timer 2 Hz interrupt                 | $\downarrow$ |
| 000022H        | Clock timer 1 Hz interrupt                 | Low          |
| 000024H        | System reserved (cannot be used)           | No           |
| 000026H        |                                            | - 1.5        |
| :              | Software interrupt                         | priority     |
| 0000FEH        |                                            | rating       |

For each vector address and the address after it, the start address of the exception processing routine is written into the subordinate and super ordinate sequence. When an exception processing factor is generated, the exception processing routine is executed starting from the recorded address.

When multiple exception processing factors are generated at the same time, execution starts with the highest priority item.

The priority sequence shown in Table 3.3.1 assumes that the interrupt priority levels are all the same. The interrupt priority levels can be set by software in each system. (See Section 5.16 "Interrupt and Standby Status".)

Note: For exception processing other than reset, SC (system condition flag) and PC (program counter) are evacuated to the stack and branches to the exception processing routines. Consequently, when returning to the main routine from exception processing routines, please use the RETE instruction.

See the "E0C88 Core CPU Manual" for information on CPU operations when an exception processing factor is generated.

## 3.4 CC (Customized Condition Flag)

The E0C88365 does not use the customized condition flag (CC) in the core CPU. Accordingly, it cannot be used as a branching condition for the conditional branching instruction (JRS, CARS).

# 3.5 Chip Mode

#### 3.5.1 MCU mode and MPU mode

The chip operating mode can be set to one of two settings using the  $MCU/\overline{MPU}$  terminal.

■ MCU mode...Set the MCU/MPU terminal to HIGH Switch to this setting when using internal ROM. With respect to areas other than internal memory, external memory can even be expanded. See Section 3.5.2, "Bus mode", for the memory map.

In the MCU mode, during initial reset, only systems in internal memory are activated.

Internal ROM is normally fixed as the top portion of the program memory common area (logical space 0000H–7FFFH). Exception processing vectors are assigned in internal ROM. Furthermore, the application initialization routines that start with reset exception processing must likewise be written to internal ROM. Since bus and other settings which correlate with external expanded memory can be executed in software, this processing is executed in the initialization routine written to internal ROM. Once these bus mode settings are made, external memory can be accessed.

When accessing internal memory in this mode, the chip enable  $(\overline{CE})$  and read  $(\overline{RD})$ /write  $(\overline{WR})$  signals are not output to external memory, and the data bus (D0–D7) becomes non active. Consequently, in cases where addresses overlap in external and internal memory, the areas in external memory will be unavailable.

#### ■ MPU mode...Set the MCU/MPU terminal to LOW

Internal ROM area is released to an external device source. Internal ROM then becomes unusable and when this area is accessed, chip enable  $(\overline{CE})$  and read  $(\overline{RD})/\text{write}(\overline{WR})$  signals are output to external memory and the data bus (D0–D7) becomes active. These signals are not output to an external source when other areas of internal memory are accessed.

In the MPU mode, the system is activated by external memory.

When employing this mode, the exception processing vectors and initialization routine must be assigned within the common area (000000H–007FFFH).

You can select whether to use the built-in pull-up resistor of the MCU/ $\overline{\text{MPU}}$  terminal by the mask option.

Note: Setting of MCU/MPU terminal is latched at the rising edge of a reset signal input from the RESET terminal. Therefore, if the setting is to be changed, the RESET terminal must be set to LOW level once again.

#### 3.5.2 Bus mode

In order to set bus specifications to match the configuration of external expanded memory, two different bus modes described below are selectable in software.

#### ■ Single chip mode



Fig. 3.5.2.1 Memory map for the single chip mode

The single chip mode setting applies when the E0C88365 is used as a single chip microcomputer without external expanded memory. Since this mode employs internal ROM, the system can only be operated in the MCU mode discussed in Section 3.5.1. In the MPU mode, the system cannot be set to the single chip mode.

Since there is no need for an external bus line in this mode, terminals normally set for bus use can be used as general purpose output ports or I/O ports.

Accordingly, the output port is in a 42-bit configuration in the E0C88365. The I/O port is in a 16-bit configuration in this model.

CPU operation in this mode is equivalent to the E0C88 core CPU Model 3 minimum mode. Addresses assigned to internal memory within physical space 000000H to 00FFFFH are only effective as a target for accessing.

Note: When using the addresses 010000H to 011FFFH as a program area, the CB register must be set to 2 by software. When reading data (font, constant, etc.) on the addresses 010000H to 011FFFH, the page must be set to 1. Moreover, subroutine calls and returns between Bank 1 and Bank 2 cannot be done because the CPU only supports the minimum mode.

#### ■ Expanded 512K mode

The expanded 512K mode setting applies when the E0C88365 is used with less than 512K bytes  $\times$  4 of external expanded memory. This mode is usable regardless of the MCU/MPU mode setting.

Because internal ROM is being used in the MCU mode, external memory can be assigned to the area from 080000H to 27FFFFH.

Since the internal ROM area is released in the MPU mode, external memory in all two models can be assigned to the area from 000000H to 1FFFFFH.

The area from 00F000H to 00FFFFH is assigned to internal memory and cannot be used to access an external device.

CPU operation in this mode is equivalent to the E0C88 core CPU Model 3 maximum mode, the area within physical space 000000H to 1FFFFFH in the MPU mode or physical space 080000H to 27FFFFH + internal memory in the MCU mode is effective as a target for accessing. In the above mentioned physical space, since program memory and data memory can be secured with an optional (maximum 512K bytes × 4 program + data) size, this mode is suitable for systems with large-scale program and data capacity.

The address range of chip enable  $(\overline{CE})$  signals in this mode is fixed at 512K bytes.



Fig. 3.5.2.2 Memory map for the expanded 512K mode

There is an explanation on how all these settings are actually made in "5.2 System Controller and Bus Control" of this Manual.

#### 3.6 External Bus

The E0C88365 has bus terminals that can address a maximum of  $512K \times 4$  bytes and memory (and other) devices can be externally expanded according to the range of each bus mode described in the previous section.



Fig. 3.6.1 External bus lines

Below is an explanation of external bus terminals. For information on control methods, see Section 5.2, "System Controller and Bus Control".

#### 3.6.1 Data bus

The E0C88365 possess an 8-bit external data bus (D0–D7). The terminals and I/O circuits of data bus D0–D7 are shared with I/O ports P00–P07, switching between these functions being determined by the bus mode setting.

In the single chip mode, the 8-bit terminals are all set as I/O ports P00–P07 and in the other expanded modes, they are set as data bus (D0–D7). When set as data bus, the data register and I/O

When set as data bus, the data register and I/O control register of each I/O port are detached from the I/O circuits and usable as a general purpose data register with read/write capabilities. The P00 to P07 terminals have a bus holder, therefore the terminal outputs VDD level or VSS level even when the terminal is in high-impedance input status.



Fig. 3.6.1.1 Correspondence between data bus and I/O ports

#### 3.6.2 Address bus

The E0C88365 possess a 19-bit external address bus A0–A18. The terminals and output circuits of address bus A0–A18 are shared with output ports R00–R07 (=A0–A7), R10–R17 (=A8–A15) and R20–R22 (=A16–A18), switching between these functions being determined by the bus mode setting. In the single chip mode, the 19-bit terminals are all set as output ports R00–R07, R10–R17 and R20–R22. In the expanded 512K mode, the 19-bit terminals are all set as the address bus (A16–A18).

When set as an address bus, the data register and high impedance control register of each output port are detached from the output circuit and used as a general purpose data register with read/write capabilities.



Fig. 3.6.2.1 Correspondence between address bus and output ports

# 3.6.3 Read ( $\overline{RD}$ )/write ( $\overline{WR}$ ) signals

The output terminals and output circuits for the read  $(\overline{RD})/$  write  $(\overline{WR})$  signals directed to external devices are shared respectively with output ports R23 and R24, switching between these functions being determined by the bus mode setting. In the single chip mode, both of these terminals are set as output port terminals and in the other expanded modes, they are set as read  $(\overline{RD})/$  write  $(\overline{WR})$  signal output terminals. When set as read  $(\overline{RD})/$  write  $(\overline{WR})$  signal output terminal, the data register and high impedance control register for each output port (R23, R24) are detached from the output circuit and is usable as a general purpose data register with read/write capabilities.

These two signals are only output when the memory area of the external device is being accessed. They are not output when internal memory is accessed.

See Section 3.6.5, "WAIT control", for the output timing of the signal.



Fig. 3.6.3.1 Correspondence between read  $(\overline{RD})$ /write  $(\overline{WR})$  signal and output ports

## 3.6.4 Chip enable $(\overline{CE})$ signal

The E0C88365 is equipped with address decoders which can output four different chip enable  $(\overline{CE})$  signals.

Consequently, four devices equipped with a chip enable  $(\overline{CE})$  or chip select  $(\overline{CS})$  terminal can be directly connected without setting the address decoder to an external device.

The four chip enable  $(\overline{CE0}-\overline{CE3})$  signal output terminals and output circuits are shared with output ports R30–R33 and in modes other than the single chip mode, the selection of chip enable  $(\overline{CE})$  or output port can be set in software for each of the four bits.

When set for chip enable  $(\overline{\text{CE}})$  output, the data register and high impedance control register for each output port are detached from the output circuit and is usable as general purpose data register with read/write capabilities. In the single chip mode, these terminals are set as output ports R30–R33.



Fig. 3.6.4.1 Correspondence between  $\overline{CE}$  signals and output ports

The address range assigned to the four chip enable  $(\overline{CE})$  signals is determined by the bus mode setting. Table 3.6.4.1 shows the address ranges which are assigned to the chip enable  $(\overline{CE})$  signal in each mode. When accessing the internal memory area, the  $\overline{CE}$  signal is not output. Care should be taken here because the address range for these portions of memory involves irregular settings.

The arrangement of memory space for external devices does not necessarily have to be continuous from a subordinate address and any of the chip enable signals can be used to assign areas in memory.

Each of these signals is only output when the memory area of the external device is being accessed. They are not output when internal memory is accessed.

See Section 3.6.5, "WAIT control", for the output timing of signal.

Table 3.6.4.1  $\overline{CE0}$ – $\overline{CE3}$  address settings

#### (1) Expanded 512K mode

| OF simes! | Addres          | s range                           |  |  |  |
|-----------|-----------------|-----------------------------------|--|--|--|
| CE signal | MCU mode        | MPU mode                          |  |  |  |
| CE0       | 200000H-27FFFH  | 000000H-00DFFFFH, 010000H-07FFFFH |  |  |  |
| CE1       | 080000H-0FFFFH  | 080000H-0FFFFH                    |  |  |  |
| CE2       | 100000H-17FFFFH | 100000H-17FFFFH                   |  |  |  |
| CE3       | 180000H-1FFFFH  | 180000H-1FFFFH                    |  |  |  |

#### 3.6.5 WAIT control

In order to insure accessing of external low speed devices during high speed operations, the E0C88365 is equipped with a WAIT function which prolongs access time. (See the "E0C88 Core CPU Manual" for details of the WAIT function.)

The WAIT state numbers to be inserted can be selected in software from a series of 8 as shown in Table 3.6.5.1.

Table 3.6.5.1 Selectable WAIT state numbers

| Selection No. | 1 | 2 | 3 | 4 | 5 | 6  | 7  | 8  |
|---------------|---|---|---|---|---|----|----|----|
| Insert states | 0 | 2 | 4 | 6 | 8 | 10 | 12 | 14 |

<sup>\*</sup> One state is a 1/2 cycle of the clock in length.

The WAIT states set in software are inserted between bus cycle states T3–T4.

Note, however, that WAIT states cannot be inserted when an internal register and internal memory are being accessed and when operating with the OSC1 oscillation circuit (see "5.4 Oscillation Circuit"). Consequently, WAIT state settings are meaningless in the single chip mode.

Figure 3.6.5.1 shows the memory read/write timing charts.





Fig. 3.6.5.1 Memory read/write cycle

#### 3.6.6 Bus authority release state

The E0C88365 is equipped with a bus authority release function on request from an external device so that DMA (Direct Memory Access) transfer can be conducted between external devices. The internal memory cannot be accessed by this function.

There are two terminals used for this function: the bus authority release request signal (BREQ) input terminal and the bus authority release acknowledge signal (BACK) output terminal.

The BREQ input terminal is shared with input port terminal K11 and the BACK output terminal with output port terminal R51, use with setting to BREQ/BACK terminals done in software. In the single chip mode, or when using a system which does not require bus authority release, set respective terminals as input and output ports.



Fig. 3.6.6.1  $\overline{BREQ}/\overline{BACK}$  terminals

When the bus authority release request ( $\overline{BREQ}$  = LOW) is received from an external device, the E0C88365 switch the address bus, data bus,  $\overline{RD}/\overline{WR}$  signal, and  $\overline{CE}$  signal lines to a high impedance state, output a LOW level from the  $\overline{BACK}$  terminal and release bus authority.

As soon as a LOW level is output from the  $\overline{BACK}$  terminal, the external device can use the external bus. When  $\overline{DMA}$  is completed, the external device returns the  $\overline{BREQ}$  terminal to HIGH and releases bus authority.

Figure 3.6.6.2 shows the bus authority release sequence.

During bus authority release state, internal memory cannot be accessed from the external device. In cases where external memory has areas which overlap areas in internal memory, the external memory areas can be accessed accordance with the  $\overline{\text{CE}}$  signal output by the external device.

Note: Be careful with the system, such that an external device does not become the bus master, other than during the bus release status.

After setting the BREQ terminal to LOW level, hold the BREQ terminal at LOW level until the BACK terminal becomes LOW level. If the BREQ terminal is returned to HIGH level, before the BACK terminal becomes LOW level, the shift to the bus authorization release status will become indefinite.



Fig. 3.6.6.2 Bus authority release sequence

# 4 INITIAL RESET

Initial reset in the E0C88365 is required in order to initialize circuits. This section of the Manual contains a description of initial reset factors and the initial settings for internal registers, etc.

#### 4.1 Initial Reset Factors

There is a initial reset factor for the E0C88365 as shown below.

#### RESET terminal

Figure 4.1.1 shows the configuration of the initial reset circuit.

The CPU and peripheral circuits are initialized by means of initial reset factors. When the factor is canceled, the CPU commences reset exception processing. (See "E0C88 Core CPU Manual".)

When this occurs, reset exception processing vectors, Bank 0, 000000H–000001H from program memory are read out and the program (initialization routine) which begins at the readout address is executed.



Fig. 4.1.1 Configuration of initial reset circuit

#### 4.1.1 RESET terminal

Initial reset can be done by executed externally inputting a LOW level to the  $\overline{RESET}$  terminal. Be sure to maintain the  $\overline{RESET}$  terminal at LOW level for the regulation time after the power on to assure the initial reset.

In addition, be sure to use the  $\overline{RESET}$  terminal for the first initial reset after the power is turned on. The  $\overline{RESET}$  terminal is equipped with a pull-up resistor. You can select whether or not to use by mask option.

#### 4.1.2 Initial reset sequence

After cancellation of the LOW level input to the  $\overline{\text{RESET}}$  terminal, when the power is turned on, the start-up of the CPU is held back until the oscillation stabilization waiting time (0.25 sec.) has elapsed. Figure 4.1.2.1 shows the operating sequence following initial reset release.



Fig. 4.1.2.1 Initial reset sequence

## 4.2 Initial Settings After Initial Reset

The CPU internal registers are initialized as follows during initial reset.

Table 4.2.1 Initial settings

| Register name               | Code | Bit length | Setting value |
|-----------------------------|------|------------|---------------|
| Data register A             | Α    | 8          | Undefined     |
| Data register B             | В    | 8          | Undefined     |
| Index (data) register L     | L    | 8          | Undefined     |
| Index (data) register H     | Н    | 8          | Undefined     |
| Index register IX           | IX   | 16         | Undefined     |
| Index register IY           | IY   | 16         | Undefined     |
| Program counter             | PC   | 16         | Undefined*    |
| Stack pointer               | SP   | 16         | Undefined     |
| Base register               | BR   | 8          | Undefined     |
| Zero flag                   | Z    | 1          | 0             |
| Carry flag                  | C    | 1          | 0             |
| Overflow flag               | V    | 1          | 0             |
| Negative flag               | N    | 1          | 0             |
| Decimal flag                | D    | 1          | 0             |
| Unpack flag                 | U    | 1          | 0             |
| Interrupt flag 0            | 10   | 1          | 1             |
| Interrupt flag 1            | I1   | 1          | 1             |
| New code bank register      | NB   | 8          | 01H           |
| Code bank register          | СВ   | 8          | Undefined*    |
| Expand page register        | EP   | 8          | 00H           |
| Expand page register for IX | XP   | 8          | 00H           |
| Expand page register for IY | YP   | 8          | 00H           |

\* Reset exception processing loads the preset values stored in 0 bank, 0000H–0001H into the PC. At the same time, 01H of the NB initial value is loaded into CB.

Initialize the registers which are not initialized at initial reset using software.

Since the internal RAM and display memory are not initialized at initial reset, be sure to initialize using software.

The respectively stipulated initializations are done for internal peripheral circuits. If necessary, the initialization should be done using software. For initial value at initial reset, see the sections on the I/O memory map and peripheral circuit descriptions in the following chapter of this Manual.

# 5 PERIPHERAL CIRCUITS AND THEIR OPERATION

The peripheral circuits of the E0C88365 is interfaced with the CPU by means of the memory mapped I/O method. For this reason, just as with other memory access operations, peripheral circuits can be controlled by manipulating I/O memory. Below is a description of the operation and control method for each individual peripheral circuit.

# 5.1 I/O Memory Map

Table 5.1.1(a) I/O Memory map (00FF00H-00FF02H, MCU mode)

| Address | Bit | Name   |              | Fu         | nction       |       |       | 1          | 0           | SR | R/W    | Comment             |
|---------|-----|--------|--------------|------------|--------------|-------|-------|------------|-------------|----|--------|---------------------|
| 00FF00  | D7  | BSMD1  | R/W registe  | r          |              |       |       | -          | ı           | 0  | R/W    |                     |
| (MCU)   | D6  | BSMD0  | Bus mode (   | CPU mod    | e) control   |       |       | Expanded   | Single      | 0  | R/W    |                     |
|         |     |        |              |            |              |       |       | 512K       | chip        |    |        |                     |
|         | D5  | CEMD1  | R/W registe  | r          |              |       |       | _          | -           | 1  | R/W    |                     |
|         | D4  | CEMD0  | R/W registe  | r          |              |       |       | _          | -           | 1  | R/W    |                     |
|         | D3  | CE3    | CE3 (R33)    | ]          | 1 4 4 5      | 11 /  | S' 11 | CE3 enable | CE3 disable | 0  | R/W    | In the Single chip  |
|         | D2  | CE2    | CE2 (R32)    | 1 -        | al output Er |       |       | CE2 enable | CE2 disable | 0  | R/W    | mode, these setting |
|         | D1  | CE1    | CE1 (R31)    | 1          | CE signal    | _     |       | CE1 enable | CE1 disable | 0  | R/W    | are fixed at DC     |
|         | D0  | CE0    | CE0 (R30)_   | Disable:   | DC (R3x)     | outpu | t     | CE0 enable | CE0 disable | 0  | R/W    | output.             |
| 00FF01  | D7  | SPP7   | Stack pointe | er page ad | dress        | (M    | SB)   | 1          | 0           | 0  | R/W    |                     |
|         | D6  | SPP6   |              |            |              |       |       | 1          | 0           | 0  | R/W    | /                   |
|         | D5  | SPP5   | < SP page a  | llocatable | address >    |       |       | 1          | 0           | 0  | R/W    |                     |
|         | D4  | SPP4   | Single chip  | p mode: o  | only 0 page  |       |       | 1          | 0           | 0  | R/W    |                     |
|         | D3  | SPP3   | • 512K mod   | le: (      | )–27H page   | •     |       | 1          | 0           | 0  | R/W    |                     |
|         | D2  | SPP2   |              |            |              |       |       | 1          | 0           | 0  | R/W    |                     |
|         | D1  | SPP1   |              |            |              |       |       | 1          | 0           | 0  | R/W    |                     |
|         | D0  | SPP0   |              |            |              | (LS   | SB)   | 1          | 0           | 0  | R/W    |                     |
| 00FF02  | D7  | EBR    | Bus release  | enable re  | gister       |       | K11   | BREQ       | Input port  | 0  | R/W    | /                   |
|         | יט  | LDK    | (K11 and R   | 51 termin  | al specifica | tion) | R51   | BACK       | Output port | O  | IX/ VV | /                   |
|         |     |        | Wait contro  | l register |              | Nun   | nber  |            |             |    |        | /                   |
|         | D6  | WT2    | WT2          | WT1        | WT0          | of s  | tate  |            |             |    |        | /                   |
|         |     |        | 1            | 1          | 1            | 1     |       |            |             |    |        | / /                 |
|         |     |        | 1            | 1<br>0     | 0            | 1     |       |            |             |    |        | / /                 |
|         | D5  | WT1    | 1            | 0          | 0            | 1     |       | -          | -           | 0  | R/W    | / /                 |
|         |     |        | 0            | 1          | 1            | 6     |       |            |             |    |        |                     |
|         |     |        | 0            | 1          | 0            | 2     |       |            |             |    |        | /                   |
|         | D4  | WT0    | 0            | 0          | 1            | 2     | 2     |            |             |    |        |                     |
|         |     |        | 0            | 0          | 0            | No    | wait  |            |             |    |        |                     |
|         | D3  | CLKCHG | CPU operat   | ing clock  | switch       |       |       | OSC3       | OSC1        | 0  | R/W    | /                   |
|         | D2  | oscc   | OSC3 oscill  | lation On/ | Off control  |       |       | On         | Off         | 0  | R/W    | /                   |
|         | D1  | VDC1   | R/W registe  | r          |              |       |       | -          | -           | 0  | R/W    | /                   |
|         | D0  | VDC0   | R/W registe  | r          |              |       |       | -          | -           | 0  | R/W    | /                   |

Note: All the interrupts including NMI are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

Table 5.1.1(b) I/O Memory map (00FF00H–00FF02H, MPU mode)

| Address | Bit      | Name  |              | Fur        | nction                  |                | 1          | 0           | SR | R/W   | Comment  |
|---------|----------|-------|--------------|------------|-------------------------|----------------|------------|-------------|----|-------|----------|
| 00FF00  | D7       | BSMD1 | R/W registe  | r          |                         |                | -          | -           | 0  | R/W   |          |
| (MPU)   | D6       | BSMD0 | Bus mode (   | CPU mod    | e) control              |                | Expanded   | Expanded    | 1  | R/W   | /        |
|         |          |       |              |            |                         |                | 512K       | 512K        |    |       | / /      |
|         | D5       | CEMD1 | R/W registe  | r          |                         |                | -          | -           | 1  | R/W   | /        |
|         | D4       | CEMD0 | R/W registe  | r          |                         |                | -          | ı           | 1  | R/W   | /        |
|         | D3       | CE3   | CE3 (R33)    |            | .1                      |                | CE3 enable | CE3 disable | 0  | R/W   |          |
|         | D2       | CE2   | CE2 (R32)    | 1          | ii output E<br>CE signa | inable/Disable | CE2 enable | CE2 disable | 0  | R/W   | /        |
|         | D1       | CE1   | CE1 (R31)    |            | DC (R3x                 | _              | CE1 enable | CE1 disable | 0  | R/W   | /        |
|         | D0       | CE0   | CE0 (R30)_   | Disable.   | DC (K3)                 | () Output      | CE0 enable | CE0 disable | 1  | R/W   |          |
| 00FF01  | D7       | SPP7  | Stack pointe | er page ad | dress                   | (MSB)          | 1          | 0           | 0  | R/W   |          |
|         | D6       | SPP6  |              |            |                         |                | 1          | 0           | 0  | R/W   | /        |
|         | D5       | SPP5  | < SP page a  | llocatable | address >               | ,              | 1          | 0           | 0  | R/W   | /        |
|         | D4       | SPP4  | • Single chi | p mode: o  | only 0 pag              | e              | 1          | 0           | 0  | R/W   |          |
|         | D3       | SPP3  | • 512K mod   | le: (      | )–27H pag               | ge             | 1          | 0           | 0  | R/W   | / /      |
|         | D2       | SPP2  |              |            |                         |                | 1          | 0           | 0  | R/W   | /        |
|         | D1       | SPP1  |              |            |                         |                | 1          | 0           | 0  | R/W   | /        |
|         | D0       | SPP0  |              |            |                         | (LSB)          | 1          | 0           | 0  | R/W   |          |
| 00FF02  | D7       | EBR   | Bus release  | enable re  | gister                  | K11            | BREQ       | Input port  | 0  | R/W   | /        |
|         | <u> </u> | LDIX  | (K11 and R   | 51 termin  | al specific             | ation)   R51   | BACK       | Output port | 0  | 10 11 | /        |
|         |          |       | Wait contro  | l register |                         | Number         |            |             |    |       | /        |
|         | D6       | WT2   | WT2          | WT1        | WT0                     | of state       |            |             |    |       | /        |
|         |          |       | 1            | 1          | 1                       | 14             |            |             |    |       | /        |
|         |          |       | 1            | 1<br>0     | 0                       | 12<br>10       |            |             |    |       | / /      |
|         | D5       | WT1   | 1            | 0          | 0                       | 8              | _          | -           | 0  | R/W   | / /      |
|         |          |       | 0            | 1          | 1                       | 6              |            |             |    |       | / /      |
|         |          |       | 0            | 1          | 0                       | 4              |            |             |    |       | / /      |
|         | D4       | WT0   | 0            | 0          | 1<br>0                  | 2              |            |             |    |       |          |
|         |          |       |              |            |                         | No wait        |            |             |    |       | /        |
|         | _        |       | CPU operat   |            |                         |                | OSC3       | OSC1        | 0  | R/W   | /        |
|         |          | oscc  | OSC3 oscill  |            | Off contro              | ol             | On         | Off         | 0  | R/W   | /        |
|         | D1       | VDC1  | R/W registe  |            |                         |                | -          | -           | 0  | R/W   | <i> </i> |
|         | D0       | VDC0  | R/W registe  | r          |                         |                | -          | -           | 0  | R/W   | /        |

Note: All the interrupts including \( \overline{NMI} \) are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

Table 5.1.1(c) I/O Memory map (00FF10H-00FF13H)

| Address | Bit | Name   | Function                                       | 1              | 0              | SR    | R/W | Comment              |
|---------|-----|--------|------------------------------------------------|----------------|----------------|-------|-----|----------------------|
| 00FF10  | D7  | 1      | -                                              | -              | -              | _     | -   | Constantry "0" when  |
|         | D6  | _      | _                                              | -              | -              | _     | _   | being read           |
|         | D5  | _      | _                                              | -              | -              | _     | _   | being read           |
|         | D4  | LCCLK  | CL output control for expanded LCD driver      | On             | Off            | 0     | R/W |                      |
|         | D3  | LCFRM  | FR output control for expanded LCD driver      | On             | Off            | 0     | R/W |                      |
|         | D2  | DTFNT  | R/W register                                   | _              | -              | 0     | R/W |                      |
|         | D1  | LDUTY  | R/W register                                   | _              | -              | 0     | R/W |                      |
|         | D0  | SGOUT  | R/W register                                   | _              | -              | 0     | R/W |                      |
| 00FF11  | D7  | _      | _                                              | _              | -              | -     | -   | "0" when being read  |
|         | D6  | DSPAR  | LCD display memory area selection              | Display area 1 | Display area 0 | 0     | R/W |                      |
|         | D5  | LCDC1  | LCD display control                            | -              | -              | 0     | R/W |                      |
|         |     |        | LCDC1 LCDC0 LCD display                        |                |                |       |     | These bits are reset |
|         |     |        | 1 1 All LCDs lit                               |                |                |       |     | to (0, 0) when       |
|         | D4  | LCDC0  | 1 0 All LCDs out                               | -              | -              | 0     | R/W | SLP instruction      |
|         |     |        | 0 1 Normal display                             |                |                |       |     | is executed.         |
|         |     |        | 0 0 Drive off                                  |                |                |       |     |                      |
|         | D3  | LC3    | LCD contrast adjustment                        | _              | _              | 0     | R/W |                      |
|         | D2  | LC2    | LC3 LC2 LC1 LC0 Contrast                       | _              | _              | 0     | R/W |                      |
|         |     | LC1    | 1 1 1 1 Dark<br>1 1 1 0 :                      |                |                |       |     |                      |
|         |     |        | : : : : :                                      |                |                | 0     | R/W |                      |
|         |     | LC0    | 0 0 0 0 Light                                  | -              | -              | 0     | R/W |                      |
| 00FF12  | D7  | _      | _                                              | -              | -              | _     | _   | Constantry "0" when  |
|         | D6  | _      | _                                              | -              | -              | _     | _   | being read           |
|         | D5  | SVDSP  | SVD auto-sampling control                      | On             | Off            | 0     | R/W | These registers are  |
|         |     |        |                                                |                |                |       |     | reset to "0" when    |
|         | D4  | SVDON  | SVD continuous sampling control/status R       | Busy           | Ready          | 1→0*1 | R/W | SLP instruction      |
|         |     |        | ¦ W                                            | On             | Off            | 0     |     | is executed.         |
|         |     | SVD3   | SVD detection level                            |                |                | X     | R   | *2                   |
|         |     | SVD2   | SVD3 SVD2 SVD1 SVD0 Detection level 1 Level 15 |                |                | X     | R   |                      |
|         |     | SVD1   | 1 1 1 0 Level 14                               |                |                | X     | R   |                      |
|         |     | SVD0   | 0 0 0 0 Level 0                                | -              | -              | X     | R   |                      |
| 00FF13  | D7  | _      | _                                              | -              | -              | _     | _   |                      |
|         | D6  | _      | _                                              | -              | -              | -     | -   | Constantly "0" when  |
|         | D5  | _      | _                                              | -              | -              | _     | _   | being read           |
|         | D4  | _      | _                                              | -              | -              | _     |     |                      |
|         | D3  | CMP10N | Comparator 1 On/Off control                    | On             | Off            | 0     | R/W |                      |
|         | D2  | CMP0ON | Comparator 0 On/Off control                    | On             | Off            | 0     | R/W |                      |
|         | D1  | CMP1DT | Comparator 1 data                              | +>-            | +<-            | 0     | R   |                      |
|         | D0  | CMP0DT | Comparator 0 data                              | +>-            | +<-            | 0     | R   |                      |

<sup>\*1</sup> After initial reset, this status is set "1" until conclusion of hardware first sampling.

<sup>\*2</sup> Initial values are set according to the supply voltage detected at first sampling by hardware. Until conclusion of first sampling, SVD0–SVD3 data are undefined.

Table 5.1.1(d) I/O Memory map (00FF20H-00FF25H)

| Address | Bit      | Name                    | Function                                                                                                                                              | 1                     |             | 0                             | SR | R/W   | Comment             |
|---------|----------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------|-------------|-------------------------------|----|-------|---------------------|
| 00FF20  |          | PK01<br>PK00            | K00–K07 interrupt priority register                                                                                                                   | PK01                  | PK0         | 0                             | 0  | R/W   |                     |
|         |          | PSIF1<br>PSIF0          | Serial interface interrupt priority register                                                                                                          | PSIF1<br>PSW1<br>PTM1 | PSIF<br>PSW | 0 Priority                    | 0  | R/W   |                     |
|         | D3       | PSW1<br>PSW0            | Stopwatch timer interrupt priority register                                                                                                           | 1                     | 1 0         | Level 3<br>Level 2            | 0  | R/W   |                     |
|         | D1       | PTM1                    | Clock timer interrupt priority register                                                                                                               | 0                     | 0           | Level 1<br>Level 0            | 0  | R/W   |                     |
| 00FF21  | D0<br>D7 | PTM0<br>-               | _                                                                                                                                                     | _                     |             | _                             | _  | _     | /                   |
|         | D6       | _                       | _                                                                                                                                                     | -                     |             | _                             | _  | _     | Constantly "0" when |
|         | D5       | _                       | _                                                                                                                                                     | _                     |             | _                             | _  | _     | being read          |
|         | D4       | _                       | _                                                                                                                                                     | _                     |             | _                             | _  | _     |                     |
|         | D3       | PPT1<br>PPT0            | Programmable timer interrupt priority register                                                                                                        | PPT1<br>PK11          | PPT<br>PK1  | 0 level                       | 0  | R/W   |                     |
|         | D1       | PK11<br>PK10            | K10 and K11 interrupt priority register                                                                                                               | 1 0                   | 0           | Level 3<br>Level 2<br>Level 1 | 0  | R/W   |                     |
| 00FF22  | D7       | 1 10                    |                                                                                                                                                       | 0                     | 0           | Level 0                       |    |       | O  1 1 -i 1         |
| 007722  |          | -<br>-                  | - 100 H : 4 11 : 4                                                                                                                                    | _                     |             | -                             | _  | _     | "0" when being read |
|         | D5       | ESW100<br>ESW10<br>ESW1 | Stopwatch timer 100 Hz interrupt enable register<br>Stopwatch timer 10 Hz interrupt enable register<br>Stopwatch timer 1 Hz interrupt enable register | T4                    |             | Y., t.,                       |    |       |                     |
|         | D3       | ETM1M                   | Clock timer 1/60 Hz interrupt enable register                                                                                                         | Interr                | -           | Interrupt                     | 0  | R/W   |                     |
|         | D2       | ETM8                    | Clock timer 8 Hz interrupt enable register                                                                                                            | enab                  | le          | disable                       |    |       |                     |
|         | D1       | ETM2                    | Clock timer 2 Hz interrupt enable register                                                                                                            |                       |             |                               |    |       |                     |
|         | D0       | ETM1                    | Clock timer 1 Hz interrupt enable register                                                                                                            |                       |             |                               |    |       |                     |
| 00FF23  | D7       | EPT1                    | Programmable timer 1 interrupt enable register                                                                                                        |                       |             |                               |    |       | /                   |
|         | D6       | EPT0                    | Programmable timer 0 interrupt enable register                                                                                                        |                       |             |                               |    |       |                     |
|         |          | EK1                     | K10 and K11 interrupt enable register                                                                                                                 |                       |             |                               |    |       |                     |
|         |          | EK0H                    | K04–K07 interrupt enable register                                                                                                                     | Interr                | upt         | Interrupt                     | 0  | R/W   |                     |
|         |          | EK0L                    | K00–K03 interrupt enable register                                                                                                                     | enab                  | le          | disable                       |    |       |                     |
|         |          | ESERR                   | Serial I/F (error) interrupt enable register                                                                                                          |                       |             |                               |    |       |                     |
|         | D1       | ESREC                   | Serial I/F (receiving) interrupt enable register                                                                                                      |                       |             |                               |    |       |                     |
|         | D0       | ESTRA                   | Serial I/F (transmitting) interrupt enable register                                                                                                   |                       |             |                               |    |       |                     |
| 00FF24  | D7       | _                       | _                                                                                                                                                     | -                     |             | -                             | -  | -     | "0" when being read |
|         | D6       | FSW100                  | Stopwatch timer 100 Hz interrupt factor flag                                                                                                          | (R)                   |             | (R)                           |    |       | <u> </u>            |
|         | D5       | FSW10                   | Stopwatch timer 10 Hz interrupt factor flag                                                                                                           | Interr                | upt         | No interrupt                  |    |       | /                   |
|         | D4       | FSW1                    | Stopwatch timer 1 Hz interrupt factor flag                                                                                                            | factor                | is          | factor is                     |    |       | /                   |
|         |          | FTM1M                   | Clock timer 1/60 Hz interrupt factor flag                                                                                                             | genera                | ted         | generated                     | 0  | R/W   |                     |
|         |          | FTM8                    | Clock timer 8 Hz interrupt factor flag                                                                                                                | (W)                   | ١           | (W)                           |    |       | /                   |
|         | D1       | FTM2                    | Clock timer 2 Hz interrupt factor flag                                                                                                                |                       |             | , ,                           |    |       | /                   |
|         | D0       | FTM1                    | Clock timer 1 Hz interrupt factor flag                                                                                                                | Rese                  | -i          | No operation                  |    |       |                     |
| 00FF25  |          | FPT1                    | Programmable timer 1 interrupt factor flag                                                                                                            | (R)                   |             | (R)                           |    |       |                     |
|         |          | FPT0                    | Programmable timer 0 interrupt factor flag                                                                                                            | Interr                | upt         | No interrupt                  |    |       | /                   |
|         | D5       | FK1                     | K10 and K11 interrupt factor flag                                                                                                                     | factor                | is          | factor is                     |    |       | /                   |
|         | D4       | FK0H                    | K04–K07 interrupt factor flag                                                                                                                         | genera                | ted         | generated                     | 0  | D/337 | /                   |
|         | D3       | FK0L                    | K00–K03 interrupt factor flag                                                                                                                         |                       |             |                               | 0  | R/W   | /                   |
|         | D2       | FSERR                   | Serial I/F (error) interrupt factor flag                                                                                                              | (W)                   | )           | (W)                           |    |       | /                   |
|         | D1       | FSREC                   | Serial I/F (receiving) interrupt factor flag                                                                                                          | Rese                  | et          | No operation                  |    |       | /                   |
|         | D0       | FSTRA                   | Serial I/F (transmitting) interrupt factor flag                                                                                                       |                       |             |                               |    |       | /                   |
|         |          |                         |                                                                                                                                                       |                       |             |                               |    |       |                     |

Table 5.1.1(e) I/O Memory map (00FF30H-00FF33H)

| Address | Bit | Name       | Fur                     | nction                   | 1                            | 0                            | SR | R/W    | Comment             |
|---------|-----|------------|-------------------------|--------------------------|------------------------------|------------------------------|----|--------|---------------------|
| 00FF30  | D7  | _          | _                       |                          | -                            | _                            | _  | _      | Constantry "0" when |
|         | D6  | _          | _                       |                          | -                            | -                            | _  | -      | being read          |
|         | D5  | _          | _                       |                          | -                            | -                            | _  | _      |                     |
|         | D4  |            | 8/16-bit mode selection |                          | 16-bit x 1                   | 8-bit x 2                    | 0  | R/W    |                     |
|         | D3  | CHSEL      | TOUT output channel     | selection                | Timer 1                      | Timer 0                      | 0  | R/W    |                     |
|         | D2  | PTOUT      | TOUT output control     |                          | On                           | Off                          | 0  | R/W    |                     |
|         | D1  | CKSEL1     | Prescaler 1 source clo  |                          | fosc3                        | foscı                        | 0  | R/W    |                     |
| 205524  | D0  |            | Prescaler 0 source clo  |                          | fosc3                        | foscı                        | 0  | R/W    |                     |
| 00FF31  | D7  | EVCNT      | Timer 0 counter mode    |                          | Event counter                | Timer                        | 0  | R/W    | - /                 |
|         | D6  | FCSEL      | Timer 0                 | In timer mode            | Pulse width                  | Normal                       | 0  | R/W    | /                   |
|         |     |            | function selection      | In event counter mode    | measurement<br>With          | mode<br><br>Without          |    |        | / /                 |
|         |     |            |                         | in event counter mode    |                              | noise rejector               |    |        | / /                 |
|         | D5  | PLPOL      | Timer 0                 | Down count timing        | Rising edge                  | Falling edge                 | 0  | R/W    | /                   |
|         | 50  | 02         | pulse polarity          | in event counter mode    | of K10 input                 | of K10 input                 |    | 10 ''  | /                   |
|         |     |            | selection               | In pulse width           | High level                   | Low level                    |    |        |                     |
|         |     |            |                         | measurement mode         | measurement<br>for K10 input | measurement<br>for K10 input |    |        |                     |
|         | D4  | PSC01      | Timer 0 prescaler divi  | iding ratio selection    | -                            | -                            | 0  | R/W    |                     |
|         |     |            | PSC01 PSC00             | Prescaler dividing ratio |                              |                              |    |        |                     |
|         |     |            | 1 1                     | Source clock / 64        |                              |                              |    |        |                     |
|         | D3  | PSC00      | 1 0                     | Source clock / 16        | _                            | _                            | 0  | R/W    |                     |
|         |     |            | 0 1                     | Source clock / 4         |                              |                              |    |        |                     |
|         |     |            | 0 0                     | Source clock / 1         |                              |                              |    |        | ]/                  |
|         | D2  | CONT0      | Timer 0 continuous/or   | ne-shot mode selection   | Continuous                   | One-shot                     | 0  | R/W    | V                   |
|         | D1  | PSET0      | Timer 0 preset          |                          | Preset                       | No operation                 | _  | W      | "0" when being read |
|         | D0  | PRUN0      | Timer 0 Run/Stop cor    | ntrol                    | Run                          | Stop                         | 0  | R/W    |                     |
| 00FF32  | D7  | _          | _                       |                          | -                            | -                            | _  | _      | Constantry "0" when |
|         | D6  | _          | _                       |                          | -                            | -                            | _  | _      | being read          |
|         | D5  | -<br>DCC44 |                         | 11 1                     | -                            | -                            | -  | - D/XV |                     |
|         | D4  | PSC11      | Timer 1 prescaler divi  | Prescaler dividing ratio | _                            | _                            | 0  | R/W    |                     |
|         |     |            | PSC11 PSC10<br>1 1      | Source clock / 64        |                              |                              |    |        |                     |
|         | DЗ  | PSC10      | 1 0                     | Source clock / 16        |                              |                              | 0  | R/W    |                     |
|         | 00  | 0010       | 0 1                     | Source clock / 4         |                              |                              |    | 10, 11 |                     |
|         |     |            | 0 0                     | Source clock / 1         |                              |                              |    |        |                     |
|         | D2  | CONT1      | Timer 1 continuous/or   | ne-shot mode selection   | Continuous                   | One-shot                     | 0  | R/W    | 1/                  |
|         | D1  | PSET1      | Timer 1 preset          |                          | Preset                       | No operation                 | _  | w      | "0" when being read |
|         |     | PRUN1      | Timer 1 Run/Stop cor    | ntrol                    | Run                          | Stop                         | 0  | R/W    |                     |
| 00FF33  | D7  | RLD07      | Timer 0 reload data D   | 7 (MSB)                  |                              |                              |    |        |                     |
|         | D6  | RLD06      | Timer 0 reload data D   | 6                        |                              |                              |    |        | /                   |
|         | D5  | RLD05      | Timer 0 reload data D   | 5                        |                              |                              |    |        | /                   |
|         | D4  | RLD04      | Timer 0 reload data D   | 4                        | U;∼h                         | I em                         | 1  | R/W    | /                   |
|         | D3  | RLD03      | Timer 0 reload data D   | 3                        | High                         | Low                          | 1  | IN/ W  | /                   |
|         |     | RLD02      | Timer 0 reload data D   | 2                        |                              |                              |    |        | /                   |
|         |     | RLD01      | Timer 0 reload data D   | 1                        |                              |                              |    |        | /                   |
|         | D0  | RLD00      | Timer 0 reload data D   | 0 (LSB)                  |                              |                              |    |        | V                   |

Table 5.1.1(f) I/O Memory map (00FF34H-00FF36H)

| Address | Bit | Name  | Function                      | 1     | 0   | SR | R/W | Comment |
|---------|-----|-------|-------------------------------|-------|-----|----|-----|---------|
| 00FF34  | D7  | RLD17 | Timer 1 reload data D7 (MSB)  |       |     |    |     | /       |
|         | D6  | RLD16 | Timer 1 reload data D6        |       |     |    |     |         |
|         | D5  | RLD15 | Timer 1 reload data D5        |       |     |    |     |         |
|         | D4  | RLD14 | Timer 1 reload data D4        | TT:-1 | T   | 1  | R/W |         |
|         | D3  | RLD13 | Timer 1 reload data D3        | High  | Low | 1  | K/W |         |
|         | D2  | RLD12 | Timer 1 reload data D2        |       |     |    |     |         |
|         | D1  | RLD11 | Timer 1 reload data D1        |       |     |    |     |         |
|         | D0  | RLD10 | Timer 1 reload data D0 (LSB)  |       |     |    |     |         |
| 00FF35  | D7  | PTD07 | Timer 0 counter data D7 (MSB) |       |     |    |     |         |
|         | D6  | PTD06 | Timer 0 counter data D6       |       |     |    |     |         |
|         | D5  | PTD05 | Timer 0 counter data D5       |       |     |    |     |         |
|         | D4  | PTD04 | Timer 0 counter data D4       | High  | Low | 1  | R   |         |
|         | D3  | PTD03 | Timer 0 counter data D3       | High  | Low | 1  | K   |         |
|         | D2  | PTD02 | Timer 0 counter data D2       |       |     |    |     |         |
|         | D1  | PTD01 | Timer 0 counter data D1       |       |     |    |     |         |
|         | D0  | PTD00 | Timer 0 counter data D0 (LSB) |       |     |    |     |         |
| 00FF36  | D7  | PTD17 | Timer 1 counter data D7 (MSB) |       |     |    |     |         |
|         | D6  | PTD16 | Timer 1 counter data D6       |       |     |    |     |         |
|         | D5  | PTD15 | Timer 1 counter data D5       |       |     |    |     |         |
|         | D4  | PTD14 | Timer 1 counter data D4       | TT:-1 | Low | 1  | R   |         |
|         | D3  | PTD13 | Timer 1 counter data D3       | High  | Low | 1  | K   |         |
|         | D2  | PTD12 | Timer 1 counter data D2       |       |     |    |     |         |
|         | D1  | PTD11 | Timer 1 counter data D1       |       |     |    |     | /       |
|         | D0  | PTD10 | Timer 1 counter data D0 (LSB) |       |     |    |     |         |

Table 5.1.1(g) I/O Memory map (00FF40H-00FF41H)

| Address | Bit | Name   |                                                                           | Function         | ı                                                | 1     | 0            | SR | R/W | Comment             |
|---------|-----|--------|---------------------------------------------------------------------------|------------------|--------------------------------------------------|-------|--------------|----|-----|---------------------|
| 00FF40  | D7  | _      | _                                                                         |                  |                                                  | -     | -            | _  | _   | "0" when being read |
|         | D6  | FOUT2  | FOUT frequency                                                            | selection        |                                                  | -     | -            | 0  | R/W |                     |
|         |     |        | $ \begin{array}{c c} FOUT2 & FOUT1 \\ \hline 0 & 0 \\ 0 & 0 \end{array} $ | FOUT0<br>0       | Frequency<br>fosc1 / 1<br>fosc1 / 2              |       |              |    |     |                     |
|         | D5  | FOUT1  | 0 1<br>0 1                                                                | 0                | fosc1 / 4<br>fosc1 / 8                           | _     | _            | 0  | R/W |                     |
|         | D4  | FOUT0  | 1 0<br>1 0<br>1 1<br>1 1                                                  | 0<br>1<br>0<br>1 | fosc3 / 1<br>fosc3 / 2<br>fosc3 / 4<br>fosc3 / 8 |       | _            | 0  | R/W |                     |
|         | D3  | FOUTON | FOUT output con                                                           | itrol            |                                                  | On    | Off          | 0  | R/W | /                   |
|         | D2  | WDRST  | Watchdog timer r                                                          | eset             |                                                  | Reset | No operation | _  | W   | Constantly "0" when |
|         | D1  | TMRST  | Clock timer reset                                                         |                  |                                                  | Reset | No operation | _  | W   | being read          |
|         | D0  | TMRUN  | Clock timer Run/                                                          | Stop contr       | ol                                               | Run   | Stop         | 0  | R/W |                     |
| 00FF41  | D7  | TMD7   | Clock timer data                                                          | 1 Hz             |                                                  |       |              |    |     |                     |
|         | D6  | TMD6   | Clock timer data                                                          | 2 Hz             |                                                  |       |              |    |     | / <b> </b>          |
|         | D5  | TMD5   | Clock timer data                                                          | 4 Hz             |                                                  |       |              |    |     | / /                 |
|         | D4  | TMD4   | Clock timer data                                                          | 8 Hz             |                                                  | High  | Low          | 0  | R   | / / <b> </b>        |
|         | D3  | TMD3   | Clock timer data                                                          | 16 Hz            |                                                  | nigii | Low          | U  | K   | / /                 |
|         | D2  | TMD2   | Clock timer data                                                          | 32 Hz            |                                                  |       |              |    |     | /                   |
|         | D1  | TMD1   | Clock timer data                                                          | 64 Hz            |                                                  |       |              |    |     | /                   |
|         | D0  | TMD0   | Clock timer data                                                          | 128 Hz           |                                                  |       |              |    |     |                     |

Table 5.1.1(h) I/O Memory map (00FF42H-00FF45H)

| Address | Bit | Name   | Function                                                         |                | 1             | 0            | SR  | R/W     | Comment              |
|---------|-----|--------|------------------------------------------------------------------|----------------|---------------|--------------|-----|---------|----------------------|
| 00FF42  | D7  | _      | _                                                                |                | -             | -            | _   | _       |                      |
|         | D6  | _      | _                                                                |                | -             | -            | _   | _       |                      |
|         | D5  | _      | _                                                                |                | -             | _            | _   | _       |                      |
|         | D4  | _      | _                                                                |                | _             | _            | -   | _       | Constantly "0" when  |
|         | D3  | _      | _                                                                |                | _             | _            | -   | _       | being read           |
|         | D2  | _      | _                                                                |                | -             | _            | _   | _       |                      |
|         | D1  | SWRST  | Stopwatch timer reset                                            |                | Reset         | No operation | _   | W       |                      |
|         |     |        | Stopwatch timer Run/Stop control                                 |                | Run           | Stop         | 0   | R/W     |                      |
| 00FF43  |     | SWD7   | Stopwatch timer data                                             |                |               | •            |     |         | /                    |
|         | D6  | SWD6   | •                                                                |                |               |              |     |         |                      |
|         |     | SWD5   | BCD (1/10 sec)                                                   |                |               |              |     |         |                      |
|         |     | SWD4   |                                                                  |                |               |              |     |         |                      |
|         |     | SWD3   | Stopwatch timer data                                             |                | -             | -            | 0   | R       |                      |
|         |     | SWD2   | jotop waten inner data                                           |                |               |              |     |         |                      |
|         |     | SWD1   | BCD (1/100 sec)                                                  |                |               |              |     |         |                      |
|         |     | SWD0   | (1/100 see)                                                      |                |               |              |     |         |                      |
| 00FF44  | D7  | _      | _                                                                |                | _             | _            | _   | _       | Constantry "0" when  |
| 001111  |     | BZSTP  | One-shot buzzer forcibly stop                                    |                | Forcibly stop | No operation |     | W       | being read           |
|         |     | BZSHT  | One-shot buzzer trigger/status                                   | R              | Busy          | Ready        | 0   | R/W     | being read           |
|         | D3  | DZOIII | One-shot buzzer trigger/status                                   | W              | Trigger       | No operation | U   | 10, 11  |                      |
|         |     | SHTPW  | One-shot buzzer duration width selection                         |                | 125 msec      | 31.25 msec   | 0   | R/W     |                      |
|         |     | ENRTM  | Envelope attenuation time                                        | 1              | 1 sec         | 0.5 sec      | 0   | R/W     |                      |
|         |     | ENRST  | Envelope attenuation time  Envelope reset                        |                |               |              | - 0 | W       | "O" rybon boing good |
|         |     | ENON   | <u> </u>                                                         |                | Reset         | No operation | 0   | R/W     | "0" when being read  |
|         |     | BZON   | Envelope On/Off control                                          |                | On            | Off          |     |         | *1                   |
| 005545  |     | BZON   | Buzzer output control                                            |                | On            | Off          | 0   | R/W     |                      |
| 00FF45  | D7  | -      | <u> </u>                                                         |                | -             | _            | _   | - D /XX | "0" when being read  |
|         | D6  | DUTY2  | Buzzer signal duty ratio selection DUTY2–1 Buzzer frequency (Hz) |                | _             | _            | 0   | R/W     | /                    |
|         |     |        | 2 1 0 fosci/8 fosci/10 fosci/12 fos                              |                |               |              |     |         | /                    |
|         |     |        |                                                                  | SC1/28<br>2/28 |               |              |     |         |                      |
|         | D5  | DUTY1  |                                                                  | 1/28           | _             | _            | 0   | R/W     |                      |
|         |     |        |                                                                  | 0/28           |               |              |     |         |                      |
|         |     |        |                                                                  | 9/28<br>3/28   |               |              |     |         |                      |
|         | D4  | DUTY0  |                                                                  | 7/28           | -             | -            | 0   | R/W     |                      |
|         |     |        | 1 1 0 2/16 2/20 6/24 6                                           | 5/28           |               |              |     |         | /                    |
|         |     |        | 1 1 1 1/16 1/20 5/24 5                                           | 5/28           |               |              |     |         | /                    |
|         | D3  | -      | _                                                                |                | -             | -            | _   | _       | "0" when being read  |
|         | D2  | BZFQ2  | Buzzer frequency selection                                       |                | -             | -            | 0   | R/W     | /                    |
|         |     |        | BZFQ2 BZFQ1 BZFQ0 Frequency (Hz                                  | z)_            |               |              |     |         | /                    |
|         |     |        | 0 0 0 fosc1/8                                                    |                |               |              |     |         | /                    |
|         | D1  | BZFQ1  | 0 0 1 fosci/10                                                   |                | -             | -            | 0   | R/W     |                      |
|         |     |        | 0 1 0 fosc1/12<br>0 1 1 fosc1/14                                 |                |               |              |     |         | /                    |
|         |     |        | 1 0 0 fosci/16                                                   |                |               |              |     |         |                      |
|         | D0  | BZFQ0  | 1 0 1 fosci/20                                                   |                | -             | -            | 0   | R/W     | /                    |
|         |     |        | 1 1 0 fosc1/24                                                   |                |               |              |     |         | /                    |
|         |     |        | 1 1 1 fosc1/28                                                   |                |               |              |     |         | /                    |

<sup>\*1</sup> Reset to "0" during one-shot output.

Table 5.1.1(i) I/O Memory map (00FF48H-00FF4AH)

| Address | Bit        | Name    | Function                                                 | 1           | 0            | SR | R/W    | Comment               |
|---------|------------|---------|----------------------------------------------------------|-------------|--------------|----|--------|-----------------------|
| 00FF48  | D7         | _       | _                                                        | -           | -            | _  | -      | "0" when being read   |
|         | D6         | EPR     | Parity enable register                                   | With parity | Non parity   | 0  | R/W    | Only for              |
|         | D5         | PMD     | Parity mode selection                                    | Odd         | Even         | 0  | R/W    | asynchronous mode     |
|         | D4         | SCS1    | Clock source selection                                   | -           | -            | 0  | R/W    | In the clock synchro- |
|         |            |         | SCS1 SCS0 Clock source                                   |             |              |    |        | nous slave mode,      |
|         |            |         | 1 1 Programmable timer                                   |             |              |    |        | external clock is     |
|         | D3         | SCS0    | 1 0 fosc1 / 1                                            | -           | -            | 0  | R/W    | selected.             |
|         |            |         | 0 1 fosc1 / 2                                            |             |              |    |        |                       |
|         |            |         | 0 0 fosc1 / 4                                            |             |              |    |        |                       |
|         | D2         | SMD1    | Serial I/F mode selection                                | -           | -            | 0  | R/W    |                       |
|         |            |         | SMD1 SMD0 Mode                                           |             |              |    |        |                       |
|         |            |         | 1 1 Asynchronous 8-bit                                   |             |              |    |        |                       |
|         | D1         | SMD0    | 1 0 Asynchronous 7-bit                                   | -           | -            | 0  | R/W    |                       |
|         |            |         | 0 1 Clock synchronous slave                              |             |              |    |        |                       |
|         |            |         | 0 0 Clock synchronous master                             |             |              |    |        |                       |
|         |            | ESIF    | Serial I/F enable register                               | Serial I/F  | I/O port     | 0  | R/W    |                       |
| 00FF49  | D7         | _       | _                                                        | -           | -            |    | _      | "0" when being read   |
|         | D6         | FER     | Framing error flag                                       | Error       | No error     | 0  | R/W    | Only for              |
|         |            |         | W                                                        | Reset (0)   | No operation |    |        | asynchronous mode     |
|         | D5         | PER     | Parity error flag                                        | Error       | No error     | 0  | R/W    |                       |
|         |            |         | W                                                        | Reset (0)   | No operation |    |        |                       |
|         | D4         | OER     | Overrun error flag                                       | Error       | No error     | 0  | R/W    |                       |
|         |            | D)/TD 0 | W                                                        | Reset (0)   | No operation |    |        |                       |
|         | D3         | RXTRG   | Receive trigger/status                                   | Run         | Stop         | 0  | R/W    |                       |
|         | <b>D</b> 0 | DVEN    | W                                                        | Trigger     | No operation |    | D /III | - /                   |
|         |            | RXEN    | Receive enable                                           | Enable      | Disable      | 0  | R/W    | . /                   |
|         | D1         | TXTRG   | Transmit trigger/status R W                              | Run         | Stop         | 0  | R/W    |                       |
|         | DO         | TXEN    | Transmit enable                                          | Trigger     | No operation | 0  | R/W    | /                     |
| 00FF4A  |            | TRXD7   |                                                          | Enable      | Disable      | 0  | K/W    |                       |
| UUFF4A  |            | TRXD6   | Transmit/Receive data D7 (MSB)  Transmit/Receive data D6 |             |              |    |        | /                     |
|         |            | TRXD5   | Transmit/Receive data D5                                 |             |              |    |        |                       |
|         |            | TRXD4   | Transmit/Receive data D3                                 | 1           |              |    |        | /                     |
|         |            | TRXD3   | Transmit/Receive data D3                                 | High        | Low          | X  | R/W    |                       |
|         |            | TRXD3   | Transmit/Receive data D2                                 | 1           |              |    |        | /                     |
|         |            | TRXD1   | Transmit/Receive data D1                                 | 1           |              |    |        | /                     |
|         |            | TRXD0   | Transmit/Receive data D0 (LSB)                           | 1           |              |    |        | /                     |
|         | 20         |         | Transmit receive data Do (LDD)                           |             |              |    |        | V                     |

Table 5.1.1(j) I/O Memory map (00FF50H-00FF55H)

| Address | Bit | Name         | Function                          | 1            | 0         | SR | R/W      | Comment             |
|---------|-----|--------------|-----------------------------------|--------------|-----------|----|----------|---------------------|
| 00FF50  | D7  | SIK07        | K07 interrupt selection register  |              |           |    |          | /                   |
|         | D6  | SIK06        | K06 interrupt selection register  |              |           |    |          | /                   |
|         | D5  | SIK05        | K05 interrupt selection register  |              |           |    |          | /                   |
|         |     | SIK04        | K04 interrupt selection register  | Interrupt    | Interrupt |    |          |                     |
|         |     | SIK03        | K03 interrupt selection register  | enable       | disable   | 0  | R/W      | /                   |
|         |     | SIK02        | K02 interrupt selection register  |              |           |    |          |                     |
|         |     | SIK01        | K01 interrupt selection register  |              |           |    |          |                     |
|         |     | SIK00        | K00 interrupt selection register  |              |           |    |          |                     |
| 00FF51  | D7  | _            | _                                 | _            | _         | _  | _        |                     |
|         | D6  | _            | _                                 | _            | _         | _  | <u> </u> |                     |
|         | D5  | _            | _                                 | _            | _         | _  | _        | Constantly "0" when |
|         | D4  | _            | _                                 | _            | _         | _  | <u> </u> | being read          |
|         | D3  | _            | _                                 | _            | _         | _  | -        | being read          |
|         | D2  | _            | _                                 | _            | _         | _  | <u> </u> |                     |
|         |     | SIK11        | K11 interrupt selection register  | Interrupt    | Interrupt |    | R/W      |                     |
|         |     | SIK10        | K10 interrupt selection register  | enable       | disable   | 0  | 10 11    |                     |
| 00FF52  |     | KCP07        | K07 interrupt comparison register | Chabic       | uisabic   |    |          | /                   |
| 001132  |     | KCP06        | K06 interrupt comparison register |              |           |    |          |                     |
|         |     | KCP05        | K05 interrupt comparison register | Interrupt    | Interrupt |    |          |                     |
|         |     | KCP04        | K04 interrupt comparison register | generated    | generated |    |          |                     |
|         |     | KCP03        | K03 interrupt comparison register | at falling   | at rising | 1  | R/W      |                     |
|         |     | KCP02        | K02 interrupt comparison register | edge         | edge      |    |          |                     |
|         |     | KCP01        | K01 interrupt comparison register | euge         | euge      |    |          |                     |
|         |     | KCP00        | K00 interrupt comparison register |              |           |    |          | /                   |
| 00FF53  | D7  | _            | Koo interrupt comparison register |              |           |    |          | <u> </u>            |
| 001133  | D6  |              |                                   | _            | _         | _  |          |                     |
|         | D5  | _            |                                   | _            | _         |    |          | Constantly "0" when |
|         | D3  |              |                                   |              |           | _  | _        | being read          |
|         | D3  |              |                                   | _            | _         | _  |          | being read          |
|         | D2  |              |                                   | _            | _         | _  | -        |                     |
|         |     | KCP11        | K11 interrupt comparison register | -<br>Falling | Rising    | _  | -        |                     |
|         |     | KCP10        | K10 interrupt comparison register | _            | · -       | 1  | R/W      |                     |
| 00FF54  |     | K07D         | K07 input port data               | edge         | edge      |    |          |                     |
| 001134  |     | K06D         | K06 input port data               |              |           |    |          |                     |
|         |     | K05D         | K05 input port data               |              |           |    |          |                     |
|         |     | K03D<br>K04D | K04 input port data               | High larval  | Low level |    |          | /                   |
|         |     | K03D         | K03 input port data               | High level   |           | -  | R        |                     |
|         |     | K02D         | K02 input port data               | input        | input     |    |          |                     |
|         |     | K02D<br>K01D | K01 input port data               |              |           |    |          |                     |
|         |     | K00D         | K00 input port data               |              |           |    |          |                     |
| 00FF55  |     | KUUD         | Koo input port data               |              |           |    |          | <u> </u>            |
| 00FF55  | D7  | _            |                                   | -            | _         | _  | -        | -                   |
|         | D6  | _            | _                                 | _            | _         | _  | -        |                     |
|         | D5  | _            | -                                 | _            | _         | _  | -        | Constantly "0" when |
|         | D4  | _            | <del> -</del>                     | -            | _         | _  | -        | being read          |
|         | D3  |              | <del> -</del>                     | -            | -         | _  | -        |                     |
|         | D2  | -<br>K445    | -<br>                             | -            | -         |    | -        |                     |
|         |     | K11D         | K11 input port data               | High level   | Low level | _  | R        |                     |
|         | ט0  | K10D         | K10 input port data               | input        | input     |    |          |                     |

Table 5.1.1(k) I/O Memory map (00FF60H-00FF63H)

| Address | Bit | Name  | Function                 | 1       | 0        | SR | R/W   | Comment |
|---------|-----|-------|--------------------------|---------|----------|----|-------|---------|
| 00FF60  | D7  | IOC07 | P07 I/O control register |         |          |    |       |         |
|         | D6  | IOC06 | P06 I/O control register |         |          |    |       | /       |
|         | D5  | IOC05 | P05 I/O control register |         |          |    |       |         |
|         | D4  | IOC04 | P04 I/O control register | 0       | T4       | 0  | R/W   |         |
|         | D3  | IOC03 | P03 I/O control register | Output  | Input    | 0  | K/W   |         |
|         | D2  | IOC02 | P02 I/O control register |         |          |    |       |         |
|         | D1  | IOC01 | P01 I/O control register |         |          |    |       |         |
|         | D0  | IOC00 | P00 I/O control register |         |          |    |       |         |
| 00FF61  | D7  | IOC17 | P17 I/O control register |         |          |    |       |         |
|         | D6  | IOC16 | P16 I/O control register |         |          |    |       |         |
|         | D5  | IOC15 | P15 I/O control register |         |          |    |       |         |
|         | D4  | IOC14 | P14 I/O control register | 0       | <b>,</b> |    | R/W   |         |
|         | D3  | IOC13 | P13 I/O control register | Output  | Input    | 0  | K/W   |         |
|         | D2  | IOC12 | P12 I/O control register |         |          |    |       |         |
|         | D1  | IOC11 | P11 I/O control register |         |          |    |       |         |
|         | D0  | IOC10 | P10 I/O control register |         |          |    |       |         |
| 00FF62  | D7  | P07D  | P07 I/O port data        |         |          |    |       |         |
|         | D6  | P06D  | P06 I/O port data        |         |          |    |       | /       |
|         | D5  | P05D  | P05 I/O port data        |         |          |    |       |         |
|         | D4  | P04D  | P04 I/O port data        | TY: -1. | Y        | 1  | R/W   |         |
|         | D3  | P03D  | P03 I/O port data        | High    | Low      | 1  | K/W   |         |
|         | D2  | P02D  | P02 I/O port data        |         |          |    |       |         |
|         | D1  | P01D  | P01 I/O port data        |         |          |    |       |         |
|         | D0  | P00D  | P00 I/O port data        |         |          |    |       |         |
| 00FF63  | D7  | P17D  | P17 I/O port data        |         |          |    |       |         |
|         | D6  | P16D  | P16 I/O port data        |         |          |    |       |         |
|         | D5  | P15D  | P15 I/O port data        |         |          |    |       |         |
|         | D4  | P14D  | P14 I/O port data        | *** 1   | · ·      | ١. | D /XX |         |
|         | D3  | P13D  | P13 I/O port data        | High    | Low      | 1  | R/W   | /       |
|         | D2  | P12D  | P12 I/O port data        |         |          |    |       |         |
|         | D1  | P11D  | P11 I/O port data        |         |          |    |       |         |
|         | D0  | P10D  | P10 I/O port data        |         |          |    |       |         |

Table 5.1.1(1) I/O Memory map (00FF70H-00FF75H)

| Address | Bit | Name   | Function                       | 1         | 0         | SR | R/W    | Comment |
|---------|-----|--------|--------------------------------|-----------|-----------|----|--------|---------|
| 00FF70  | D7  | HZR51  | R51 high impedance control     | High      | Comple-   |    | D /III | /       |
|         | D6  | HZR50  | R50 high impedance control     | impedance | mentary   | 0  | R/W    |         |
|         | D5  | HZR4H  | R44–R47 high impedance control | High      | Comple-   |    |        |         |
|         | D4  | HZR4L  | R40–R43 high impedance control | impedance | mentary   | 0  | R/W    |         |
|         |     | HZR1H  | R14–R17 high impedance control |           |           |    |        | /       |
|         |     | HZR1L  | R10–R13 high impedance control | High      | Comple-   |    |        |         |
|         |     | HZR0H  | R04–R07 high impedance control | impedance | mentary   | 0  | R/W    |         |
|         |     | HZR0L  | R00–R03 high impedance control | impedance | incital y |    |        | /       |
| 00FF71  |     | HZR27  | R27 high impedance control     |           |           |    |        | /       |
| 001171  |     | HZR26  | R26 high impedance control     |           |           |    |        | /       |
|         |     | HZR25  | R25 high impedance control     |           |           |    |        |         |
|         |     | HZR24  | R24 high impedance control     | High      | Comple-   |    |        |         |
|         |     | HZR23  | R23 high impedance control     | -         |           | 0  | R/W    |         |
|         |     | HZR22  | <b> </b>                       | impedance | mentary   |    |        |         |
|         |     | HZR21  | R22 high impedance control     |           |           |    |        |         |
|         |     |        | R21 high impedance control     |           |           |    |        |         |
| 005570  |     | HZR20  | R20 high impedance control     |           |           |    |        | /       |
| 00FF72  |     | HZR37  | R37 high impedance control     |           |           |    |        | /       |
|         |     | HZR36  | R36 high impedance control     |           |           |    |        | /       |
|         |     | HZR35  | R35 high impedance control     |           |           |    |        |         |
|         |     | HZR34  | R34 high impedance control     | High      | Comple-   | 0  | R/W    |         |
|         |     | HZR33  | R33 high impedance control     | impedance | mentary   |    |        |         |
|         |     | HZR32  | R32 high impedance control     |           |           |    |        |         |
|         |     | HZR31  | R31 high impedance control     |           |           |    |        |         |
|         |     | HZR30  | R30 high impedance control     |           |           |    |        | /       |
| 00FF73  |     | R07D   | R07 output port data           |           |           |    |        | /       |
|         |     | R06D   | R06 output port data           |           |           |    |        |         |
|         |     | R05D   | R05 output port data           |           |           |    |        |         |
|         | D4  | R04D   | R04 output port data           | High      | Low       | 1  | R/W    |         |
|         | D3  | R03D   | R03 output port data           | ingii     | Low       | 1  | 10 "   |         |
|         | D2  | R02D   | R02 output port data           |           |           |    |        |         |
|         |     | R01D   | R01 output port data           |           |           |    |        |         |
|         | D0  | R00D   | R00 output port data           |           |           |    |        | /       |
| 00FF74  | D7  | R17D   | R17 output port data           |           |           |    |        | /       |
|         | D6  | R16D   | R16 output port data           |           |           |    |        |         |
|         | D5  | R15D   | R15 output port data           |           |           |    |        | / /     |
|         | D4  | R14D   | R14 output port data           | TE -1.    | T         | 1  | D /XX7 | /       |
|         | D3  | R13D   | R13 output port data           | High      | Low       | 1  | R/W    | /       |
|         | D2  | R12D   | R12 output port data           |           |           |    |        | /       |
|         | D1  | R11D   | R11 output port data           |           |           |    |        | /       |
|         | D0  | R10D   | R10 output port data           | 1         |           |    |        | /       |
| 00FF75  | D7  | R27D   | R27 output port data           |           |           |    |        | /       |
|         |     | R26D   | R26 output port data           |           |           |    |        | /       |
|         |     | R25D   | R25 output port data           |           |           |    |        | / /     |
|         |     | R24D   | R24 output port data           |           |           |    |        | /       |
|         |     | R23D   | R23 output port data           | High      | Low       | 1  | R/W    | /       |
|         |     | R22D   | R22 output port data           |           |           |    |        | /       |
|         |     | R21D   | R21 output port data           |           |           |    |        | /       |
|         |     | R20D   | R20 output port data           |           |           |    |        | /       |
|         | 20  | . 1200 | 1120 output port dutti         | L         | l .       |    |        | V       |

Table 5.1.1(m) I/O Memory map (00FF76H-00FF78H)

| Address | Bit | Name | Function             | 1      | 0   | SR | R/W   | Comment |
|---------|-----|------|----------------------|--------|-----|----|-------|---------|
| 00FF76  | D7  | R37D | R37 output port data |        |     |    |       |         |
|         | D6  | R36D | R36 output port data |        |     |    |       | /       |
|         | D5  | R35D | R35 output port data |        |     |    |       |         |
|         | D4  | R34D | R34 output port data | High   | Low | 1  | R/W   |         |
|         | D3  | R33D | R33 output port data | підіі  | Low | 1  | IN/ W |         |
|         | D2  | R32D | R32 output port data |        |     |    |       |         |
|         | D1  | R31D | R31 output port data |        |     |    |       |         |
|         | D0  | R30D | R30 output port data |        |     |    |       |         |
| 00FF77  | D7  | R47D | R47 output port data |        |     |    |       |         |
|         | D6  | R46D | R46 output port data |        |     |    |       |         |
|         | D5  | R45D | R45 output port data |        |     |    |       |         |
|         | D4  | R44D | R44 output port data | High   | Low | 1  | R/W   |         |
|         | D3  | R43D | R43 output port data | riigii | Low | 1  | IX/ W |         |
|         | D2  | R42D | R42 output port data |        |     |    |       |         |
|         | D1  | R41D | R41 output port data |        |     |    |       |         |
|         | D0  | R40D | R40 output port data |        |     |    |       |         |
| 00FF78  | D7  | _    | _                    | -      | -   | _  | _     |         |
|         | D6  | _    | _                    | _      | -   | _  | _     |         |
|         | D5  | _    | _                    | -      | -   | _  | _     |         |
|         | D4  | _    | _                    | -      | -   | _  | _     |         |
|         | D3  | _    | _                    | -      | -   | _  | _     |         |
|         | D2  | _    | _                    | -      | -   | _  | _     |         |
|         | D1  | R51D | R51 output port data | High   | Low | 1  | R/W   |         |
|         | D0  | R50D | R50 output port data | High   | Low | 0  | R/W   | /       |

# 5.2 System Controller and Bus Control

The system controller is a management unit which sets such items as the bus mode in accordance with memory system configuration factors.

For the purposes of controlling the system, the following settings can be performed in software:

- (1) Bus mode (CPU mode) settings
- (2) Chip enable (CE) signal output settings
- (3) WAIT state settings for external memory
- (4) Bus authority release request / acknowledge signal (BREQ/BACK) settings
- (5) Page address setting of the stack pointer

Below is a description of the how these settings are to be made.

#### 5.2.1 Bus mode settings

The E0C88365 has two bus modes as explained in Section 3.5.2, "Bus mode". They should be set by software.

As shown in Table 5.2.1.1, bus mode settings are performed on the basis of the preset values written to the register BSMD0.

Table 5.2.1.1 Bus mode settings

| Setting value<br>BSMD0 | Bus mode               | Configuration of external memory      |
|------------------------|------------------------|---------------------------------------|
| 1                      | Expanded 512K mode     | ROM+RAM>64K bytes (Program>64K bytes) |
| 0                      | Single chip mode (MCU) | None                                  |

<sup>\*</sup> The single chip mode setting is only possible when this IC is used in the MCU mode. The single chip mode setting is incompatible with the MPU mode, since this mode does not utilize internal ROM. When using MPU mode, the bus mode is set to the expanded 512K mode at initial reset.

The function of I/O terminals is set as shown in Table 5.2.1.2 in accordance with mode selection.

Table 5.2.1.2 I/O terminal settings

| Torminal | Bus             | s mode             |  |  |  |
|----------|-----------------|--------------------|--|--|--|
| Terminal | Single chip     | Expanded 512K mode |  |  |  |
| R00      | Output port R00 | Address bus A0     |  |  |  |
| R01      | Output port R01 | Address bus A1     |  |  |  |
| R02      | Output port R02 | Address bus A2     |  |  |  |
| R03      | Output port R03 | Address bus A3     |  |  |  |
| R04      | Output port R04 | Address bus A4     |  |  |  |
| R05      | Output port R05 | Address bus A5     |  |  |  |
| R06      | Output port R06 | Address bus A6     |  |  |  |
| R07      | Output port R07 | Address bus A7     |  |  |  |
| R10      | Output port R10 | Address bus A8     |  |  |  |
| R11      | Output port R11 | Address bus A9     |  |  |  |
| R12      | Output port R12 | Address bus A10    |  |  |  |
| R13      | Output port R13 | Address bus A11    |  |  |  |
| R14      | Output port R14 | Address bus A12    |  |  |  |
| R15      | Output port R15 | Address bus A13    |  |  |  |
| R16      | Output port R16 | Address bus A14    |  |  |  |
| R17      | Output port R17 | Address bus A15    |  |  |  |
| R20      | Output port R20 | Address bus A16    |  |  |  |
| R21      | Output port R21 | Address bus A17    |  |  |  |
| R22      | Output port R22 | Address bus A18    |  |  |  |
| R23      | Output port R23 | RD signal          |  |  |  |
| R24      | Output port R24 | WR signal          |  |  |  |
| P00      | I/O port P00    | Data bus D0        |  |  |  |
| P01      | I/O port P01    | Data bus D1        |  |  |  |
| P02      | I/O port P02    | Data bus D2        |  |  |  |
| P03      | I/O port P03    | Data bus D3        |  |  |  |
| P04      | I/O port P04    | Data bus D4        |  |  |  |
| P05      | I/O port P05    | Data bus D5        |  |  |  |
| P06      | I/O port P06    | Data bus D6        |  |  |  |
| P07      | I/O port P07    | Data bus D7        |  |  |  |

At initial reset, the bus mode is set as explained below.

#### In MCU mode:

At initial reset, the E0C88365 is set in single chip mode.

Accordingly, in MCU mode, even if a memory has been externally expanded, the system is activated by the program written to internal ROM.

In systems with externally expanded memory, perform the applicable bus mode settings during the initialization routine originating in internal ROM.

#### In MPU mode:

At initial reset, the E0C88365 is set in expanded 512K mode.

In MPU mode, the system starts up with the program written in the external ROM. (The internal ROM cannot be used.)

## 5.2.2 Address decoder ( $\overline{CE}$ output) settings

As explained in Section 3.6.4, the E0C88365 is equipped with address decoders that can output a maximum of four chip enable signals  $(\overline{\text{CE0}}-\overline{\text{CE3}})$  to external devices.

The output terminals and output circuits for  $\overline{\text{CE0}}$ – $\overline{\text{CE3}}$  are shared with output ports R30–R33. At initial reset, they are set as output port terminals. For this reason, when operating in a mode other than single chip mode, the ports to be used as  $\overline{\text{CE}}$  signal output terminals must be set as such. This setting is performed through software which writes "1" to registers CE0–CE3 corresponding the  $\overline{\text{CE}}$  signals to be used.

Table 5.2.2.1 shows the address range assigned to the four chip enable  $(\overline{CE})$  signals.

The arrangement of memory space for external devices does not necessarily have to be continuous from a subordinate address and any of the chip enable signals can be used to assign areas in memory. However, in the MPU mode, program memory must be assigned to  $\overline{\text{CE0}}$ .

These signals are only output when the appointed external memory area is accessed and are not output when internal memory is accessed.

Table 5.2.2.1 Address settings of  $\overline{CE0}$ – $\overline{CE3}$ 

#### (1) Expanded 512K mode

| CE signal | Address range   |                                  |  |  |  |
|-----------|-----------------|----------------------------------|--|--|--|
| CE signal | MCU mode        | MPU mode                         |  |  |  |
| CE0       | 200000H-27FFFH  | 000000H-00DFFFH, 010000H-07FFFFH |  |  |  |
| CE1       | 080000H-0FFFFH  | 080000H-0FFFFH                   |  |  |  |
| CE2       | 100000H-17FFFFH | 100000H-17FFFFH                  |  |  |  |
| CE3       | 180000H-1FFFFH  | 180000H-1FFFFH                   |  |  |  |

#### 5.2.3 WAIT state settings

In order to insure accessing of external low speed devices during high speed operations, the E0C88365 is equipped with a WAIT function which prolongs access time.

The number of wait states inserted can be selected from a choice of eight as shown in Table 5.2.3.1 by means of registers WT0–WT2.

Table 5.2.3.1 Setting the number of WAIT states

| WT2 | WT1 | WT0 | Number of inserted states |
|-----|-----|-----|---------------------------|
| 1   | 1   | 1   | 14                        |
| 1   | 1   | 0   | 12                        |
| 1   | 0   | 1   | 10                        |
| 1   | 0   | 0   | 8                         |
| 0   | 1   | 1   | 6                         |
| 0   | 1   | 0   | 4                         |
| 0   | 0   | 1   | 2                         |
| 0   | 0   | 0   | No wait                   |

<sup>\*</sup> A state is 1/2 cycles of the clock in length.

WAIT states set in software are inserted between bus cycle states T3–T4.

Note, however, that WAIT states cannot be inserted when an internal register and internal memory are being accessed and when operating with the OSC1 oscillation circuit (see "5.4 Oscillation Circuit"). Consequently, WAIT state settings in single chip mode are meaningless.

With regard to WAIT insertion timing, see Section 3.6.5, "WAIT control".

# 5.2.4 Setting the bus authority release request signal

With systems performing DMA transfer, the bus authority release request signal ( $\overline{BREQ}$ ) input terminal and acknowledge signal ( $\overline{BACK}$ ) output terminal have to be set.

The  $\overline{BREQ}$  input terminal is shared with input port terminal K11 and the  $\overline{BACK}$  output terminal with output port terminal R51. At initial reset, these terminal facilities are set as input port terminal and output port terminal, respectively. The terminals can be altered to function as  $\overline{BREQ}/\overline{BACK}$  terminals by writing a "1" to register EBR.

For details on bus authority release, see "3.6.6 Bus authority release state" and "E0C88 Core CPU Manual".

# 5.2.5 Stack page setting

Although the stack area used to evacuate registers during subroutine calls can be arbitrarily moved to any area in data RAM using the stack pointer SP, its page address is set in registers SPP0–SPP7 in I/O memory.

At initial reset, SPP0–SPP7 are set to "00H" (page 0).

Since the internal RAM is arranged on page 0 (00EC00H–00F7FFH), the stack area in single chip mode is inevitably located in page 0.

In order to place the stack area at the final address in internal RAM, the stack pointer SP is placed at an initial setting of "F800H". (SP is pre-decremented.)

In the expanded 512K mode, to place the stack in external expanded RAM, set a corresponding page to SPP0–SPP7. The page addresses to which SPP0–SPP7 can be set are 00H–27H and must be within a RAM area.

\* A page is each recurrent 64K division of data memory beginning at address zero.

# 5.2.6 Control of system controller

Table 5.2.6.1 shows the control bits for the system controller.

Table 5.2.6.1(a) System controller control bits (MCU mode)

| Address | Bit | Name   |                                            | Fun      | ction         |        |      | 1          | 0           | SR  | R/W | Comment             |
|---------|-----|--------|--------------------------------------------|----------|---------------|--------|------|------------|-------------|-----|-----|---------------------|
| 00FF00  | D7  | BSMD1  | R/W register                               |          |               |        |      | -          | -           | 0   | R/W |                     |
| (MCU)   | D6  | BSMD0  | Bus mode (CPU mode) control                |          |               |        |      | Expanded   | Single      | 0   | R/W |                     |
|         |     |        |                                            |          |               |        | 512K | chip       |             |     |     |                     |
|         | D5  | CEMD1  | R/W register                               |          |               |        |      | -          | _           | 1   | R/W |                     |
|         | D4  | CEMD0  | R/W register                               |          |               |        |      | -          | -           | 1   | R/W |                     |
|         | D3  | CE3    | CE3 (R33)                                  | <u></u>  | 1 F           | 11 /D  |      | CE3 enable | CE3 disable | 0   | R/W | In the Single chip  |
|         | D2  | CE2    | ICE2 (R32)                                 | -        | l output En   |        |      | CE2 enable | CE2 disable | 0   | R/W | mode, these setting |
|         | D1  | CE1    | ICET (R31)                                 |          | CE signal     | •      |      | CE1 enable | CE1 disable | 0   | R/W | are fixed at DC     |
|         | D0  | CE0    | $\overline{\text{CE0}}$ (R30) $^{\square}$ | isable:  | DC (R3x)      | output |      | CE0 enable | CE0 disable | 0   | R/W | output.             |
| 00FF01  | D7  | SPP7   | Stack pointer p                            | page ado | dress         | (MS    | SB)  | 1          | 0           | 0   | R/W |                     |
|         | D6  | SPP6   |                                            |          |               |        |      | 1          | 0           | 0   | R/W | /                   |
|         | D5  | SPP5   | < SP page allo                             | catable  | address >     |        |      | 1          | 0           | 0   | R/W |                     |
|         | D4  | SPP4   | Single chip n                              | node: o  | nly 0 page    |        |      | 1          | 0           | 0   | R/W |                     |
|         | D3  | SPP3   | • 512K mode:                               | 0-       | –27H page     |        |      | 1          | 0           | 0   | R/W |                     |
|         | D2  | SPP2   |                                            |          |               |        |      | 1          | 0           | 0   | R/W |                     |
|         | D1  | SPP1   |                                            |          |               |        | 1    | 0          | 0           | R/W |     |                     |
|         | D0  | SPP0   | (LSB)                                      |          |               |        |      | 1          | 0           | 0   | R/W | /                   |
| 00FF02  | D7  | EBR    | Bus release en                             | able reg | gister        |        | K11  | BREQ       | Input port  | 0   | R/W | /                   |
|         | וט  | EDK    | (K11 and R51                               | termina  | ıl specificat | ion)   | R51  | BACK       | Output port | U   | K/W | /                   |
|         |     |        | Wait control re                            | egister  |               | Num    | ber  |            |             |     |     | /                   |
|         | D6  | WT2    | WT2 V                                      | WT1      | WT0           | of st  | ate  |            |             |     |     | / /                 |
|         |     |        | 1                                          | 1        | 1             | 14     | 1    |            |             |     |     | /                   |
|         |     |        | 1<br>1                                     | 1        | 0             | 12     |      |            |             |     |     |                     |
|         | D5  | WT1    | 1                                          | 0        | 1<br>0        | 10     |      | -          | -           | 0   | R/W |                     |
|         |     |        | 0                                          | 1        | 1             | 8<br>6 |      |            |             |     |     |                     |
|         |     |        | 0                                          | 1        | 0             | 4      |      |            |             |     |     |                     |
|         | D4  | WT0    | 0                                          | 2        |               |        |      |            |             |     |     |                     |
|         |     |        | 0 0 0 No wait                              |          |               |        |      |            |             |     |     |                     |
|         | D3  | CLKCHG | CPU operating clock switch                 |          |               |        |      | OSC3       | OSC1        | 0   | R/W | ] /                 |
|         | D2  | oscc   | OSC3 oscillation On/Off control            |          |               |        |      | On         | Off         | 0   | R/W | ] /                 |
|         | D1  | VDC1   | R/W register                               |          |               |        |      | -          | _           | 0   | R/W | ]/                  |
|         | D0  | VDC0   | R/W register                               |          |               |        |      | -          | -           | 0   | R/W | V                   |

Note: All the interrupts including \( \overline{NMI} \) are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

Table 5.2.6.1(b) System controller control bits (MPU mode)

| Address | Bit | Name  | Function                                                            | 1          | 0           | SR | R/W    | Comment      |
|---------|-----|-------|---------------------------------------------------------------------|------------|-------------|----|--------|--------------|
| 00FF00  | D7  | BSMD1 | R/W register                                                        | -          | -           | 0  | R/W    |              |
| (MPU)   | D6  | BSMD0 | Bus mode (CPU mode) control                                         | Expanded   | Expanded    | 1  | R/W    | /            |
|         |     |       |                                                                     | 512K       | 512K        |    |        | /            |
|         | D5  | CEMD1 | R/W register                                                        | -          | -           | 1  | R/W    | / /          |
|         | D4  | CEMD0 | R/W register                                                        | -          | -           | 1  | R/W    | / /          |
|         | D3  | CE3   | CE3 (R33)                                                           | CE3 enable | CE3 disable | 0  | R/W    | / /          |
|         | D2  | CE2   | $\overline{CE2}$ (R32) $\overline{CE}$ signal output Enable/Disable | CE2 enable | CE2 disable | 0  | R/W    | /            |
|         | D1  | CE1   | Enable: CE signal output                                            | CE1 enable | CE1 disable | 0  | R/W    | /            |
|         | D0  | CE0   | $\overline{\text{CEO}}$ (R30) Disable: DC (R3x) output              | CE0 enable | CE0 disable | 1  | R/W    |              |
| 00FF01  | D7  | SPP7  | Stack pointer page address (MSB)                                    | 1          | 0           | 0  | R/W    |              |
|         | D6  | SPP6  |                                                                     | 1          | 0           | 0  | R/W    | /            |
|         | D5  | SPP5  | < SP page allocatable address >                                     | 1          | 0           | 0  | R/W    | / /          |
|         | D4  | SPP4  | • Single chip mode: only 0 page                                     | 1          | 0           | 0  | R/W    | / / <b> </b> |
|         | D3  | SPP3  | • 512K mode: 0–27H page                                             | 1          | 0           | 0  | R/W    | / /          |
|         | D2  | SPP2  |                                                                     | 1          | 0           | 0  | R/W    | /            |
|         | D1  | SPP1  |                                                                     | 1          | 0           | 0  | R/W    | /            |
|         | D0  | SPP0  | (LSB)                                                               | 1          | 0           | 0  | R/W    |              |
| 00FF02  | חק  | EBR   | Bus release enable register K11                                     | BREQ       | Input port  | 0  | R/W    | /            |
|         | ٥,  | LDIX  | (K11 and R51 terminal specification) R51                            | BACK       | Output port |    | 10, 11 | /            |
|         |     |       | Wait control register Number                                        |            |             |    |        | /            |
|         | D6  | WT2   | <u>WT2</u> <u>WT1</u> <u>WT0</u> <u>of state</u>                    |            |             |    |        | / <b> </b>   |
|         |     |       | 1 1 1 14                                                            |            |             |    |        | / <b> </b>   |
|         |     |       | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                |            |             |    |        | / /          |
|         | D5  | WT1   | $\begin{array}{cccccccccccccccccccccccccccccccccccc$                | _          | _           | 0  | R/W    | / <b> </b>   |
|         |     |       | 0 1 1 6                                                             |            |             |    |        | / /          |
|         |     |       | 0 1 0 4                                                             |            |             |    |        | / <b> </b>   |
|         | D4  | WT0   | $\begin{bmatrix} 0 & 0 & 1 & 2 \\ 0 & 0 & 0 & 1 \end{bmatrix}$      |            |             |    |        | / /          |
|         |     |       | 0 0 0 No wait                                                       |            |             |    |        | /            |
|         |     |       | CPU operating clock switch                                          | OSC3       | OSC1        | 0  | R/W    | <i> </i>     |
|         | D2  |       | OSC3 oscillation On/Off control                                     | On         | Off         | 0  | R/W    | <i> </i>     |
|         |     | VDC1  | R/W register                                                        | -          | -           | 0  | R/W    | / <b> </b>   |
|         | D0  | VDC0  | R/W register                                                        | _          | -           | 0  | R/W    | /            |

Note: All the interrupts including \( \overline{NMI} \) are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

#### BSMD0: 00FF00H•D6

Bus modes are set as shown in Table 5.2.6.2.

Table 5.2.6.2 Bus mode settings

| Setting values<br>BSMD0 | Bus mode           |
|-------------------------|--------------------|
| 1                       | Expanded 512K mode |
| 0                       | Expanded 512K mode |

The single chip mode setting is only possible when this IC is used in the MCU mode. The single chip mode setting is incompatible with the MPU mode, since this mode does not utilize internal ROM. When using in the MPU mode, at initial reset, the E0C88365 is set in expanded 512K mode.

## CE0-CE3: 00FF00H•D0-D3

Sets the  $\overline{\text{CE}}$  output terminals being used.

When "1" is written:  $\overline{CE}$  output enable When "0" is written:  $\overline{CE}$  output disable

Reading: Valid

CE output is enabled when a "1" is written to registers CE0–CE3 which correspond to the CE output being used. A "0" written to any of the registers disables CE signal output from that terminal and it reverts to its alternate function as an output port terminal (R30–R33).

At initial reset, register CE0 is set to "0" in the MCU mode and in the MPU mode, "1" is set in the register. Registers CE1–CE3 are always set to "0" regardless of the MCU/MPU mode setting.

Note: To avoid a malfunction from an interrupt generated before the bus configuration is initialized, all interrupts including NMI are masked until you write an optional value into address "00FF00H".

#### SPP0-SPP7: 00FF01H

Sets the page address of stack area. In single chip mode, set page address to "00H".

In expanded 512K mode, it can be set to any value within the range "00H"–"27H".

Since a carry and borrow from/to the stack pointer SP is not reflected in register SPP, the upper limit on continuous use of the stack area is 64K bytes. At initial reset, this register is set to "00H" (page 0).

Note: To avoid a malfunction from an interrupt generated before the bus configuration is initialized, all interrupts including NMI are disabled, until you write an optional value into "00FF01H" address. Furthermore, to avoid generating an interrupt while the stack area is being set, all interrupts including NMI are disabled in one instruction execution period after writing to address "00FF01H".

#### WT0-WT2: 00FF02H•D4-D6

How WAIT state settings are performed. The number of WAIT states to be inserted based on register settings is as shown in Table 5.2.6.4.

Table 5.2.6.4 Setting WAIT states

| WT2 | WT1 | WT0 | No. of inserted states |
|-----|-----|-----|------------------------|
| 1   | 1   | 1   | 14                     |
| 1   | 1   | 0   | 12                     |
| 1   | 0   | 1   | 10                     |
| 1   | 0   | 0   | 8                      |
| 0   | 1   | 1   | 6                      |
| 0   | 1   | 0   | 4                      |
| 0   | 0   | 1   | 2                      |
| 0   | 0   | 0   | No wait                |

<sup>\*</sup> A state is 1/2 cycles of the clock in length.

At initial reset, this register is set to "0" (NO WAIT).

#### EBR: 00FF02H•D7

Sets the  $\overline{BREO}/\overline{BACK}$  terminals function.

When "1" is written:  $\overline{BREQ}/\overline{BACK}$  enabled When "0" is written:  $\overline{BREQ}/\overline{BACK}$  disabled

Reading: Valid

How  $\overline{BREQ}$  and  $\overline{BACK}$  terminal functions are set. Writing "1" to EBR enables  $\overline{BREQ}/\overline{BACK}$  input/output. Writing "0" sets the  $\overline{BREQ}$  terminal as input port terminal K11 and the  $\overline{BACK}$  terminal as output port terminal R51.

At initial reset, EBR is set to "0" ( $\overline{BREQ}/\overline{BACK}$  disabled).

## 5.2.7 Programming notes

- (1) All the interrupts including \$\overline{NMI}\$ are masked, until you write the optional value into both the "00FF00H" and "00FF01H" addresses. Consequently, even if you do not change the content of this address (You use the initial value, as is.), you should still be sure to perform the writing operation using the initialization routine.
- (2) When setting stack fields, including page addresses as well, you should write them in the order of the register SPP ("00FF01H") and the stack pointer SP.

Example: When setting the "178000H" address

LD EP, #00H

LD HL, #0FF01H

LD [HL], #17H During this period the interrupts (including

LD SP, #8000H  $\supseteq$   $\frac{1000}{\text{NMI}}$ ) are masked.

# 5.3 Watchdog Timer

# 5.3.1 Configuration of watchdog timer

The E0C88365 is equipped with a watchdog timer driven by OSC1 as source oscillation. The watchdog timer must be reset periodically in software, and if reset of more than 3–4 seconds does not take place, a non-maskable interrupt signal is generated and output to the CPU.

Figure 5.3.1.1 is a block diagram of the watchdog timer.



Fig. 5.3.1.1 Block diagram of watchdog timer

By running watchdog timer reset during the main routine of the program, it is possible to detect program runaway as if watchdog timer processing had not been applied. Normally, this routine is integrated at points that are regularly being processed.

The watchdog timer continues to operate during HALT and when a HALT state is continuous for longer than 3–4 seconds, the CPU shifts to exception processing.

During SLEEP, the watchdog timer is stopped.

## 5.3.2 Interrupt function

In cases where the watchdog timer is not periodically reset in software, the watchdog timer outputs an interrupt signal to the CPU's  $\overline{\text{NMI}}$  (level 4) input. Unmaskable and taking priority over other interrupts, this interrupt triggers the generation of exception processing. See the "E0C88 Core CPU Manual" for more details on  $\overline{\text{NMI}}$  exception processing.

This exception processing vector is set at 000004H.

# 5.3.3 Control of watchdog timer

Table 5.3.3.1 shows the control bits for the watchdog timer.

#### WDRST: 00FF40H•D2

Resets the watchdog timer.

When "1" is written: Watchdog timer is reset
When "0" is written: No operation
Reading: Constantly "0"

By writing "1" to WDRST, the watchdog timer is reset, after which it is immediately restarted. Writing "0" will mean no operation. Since WDRST is for writing only, it is constantly set to "0" during readout.

# 5.3.4 Programming note

The watchdog timer must reset within 3-second cycles by software.

| Address | Bit | Name   |                          |                          | Function                 | 1                      | 1     | 0            | SR | R/W | Comment             |
|---------|-----|--------|--------------------------|--------------------------|--------------------------|------------------------|-------|--------------|----|-----|---------------------|
| 00FF40  | D7  | _      | _                        |                          |                          |                        | -     | -            | _  | _   | "0" when being read |
|         | D6  | FOUT2  | FOUT fr                  | equency                  | selection                |                        | -     | -            | 0  | R/W |                     |
|         |     |        | $\frac{\text{FOUT2}}{0}$ | $\frac{\text{FOUT1}}{0}$ | $\frac{\text{FOUT0}}{0}$ | Frequency fosc1 / 1    |       |              |    |     |                     |
|         | D5  | FOUT1  | 0<br>0                   | 0<br>1                   | 1<br>0                   | fosc1 / 2<br>fosc1 / 4 | _     | -            | 0  | R/W |                     |
|         |     |        | 0<br>1                   | 1<br>0                   | 1<br>0                   | fosc1 / 8<br>fosc3 / 1 |       |              |    |     |                     |
|         | D4  | FOUT0  | 1<br>1                   | 0<br>1                   | 1<br>0                   | fosc3 / 2<br>fosc3 / 4 | -     | _            | 0  | R/W |                     |
|         |     |        | 1                        | 1                        | 1                        | fosc3 / 8              |       |              |    |     |                     |
|         | D3  | FOUTON | FOUT or                  | ıtput con                | trol                     |                        | On    | Off          | 0  | R/W | 1/                  |
|         | D2  | WDRST  | Watchdo                  | g timer r                | eset                     |                        | Reset | No operation | _  | W   | Constantly "0" when |
|         | D1  | TMRST  | Clock tin                | ner reset                |                          |                        | Reset | No operation | _  | W   | being read          |
|         | D0  | TMRUN  | Clock tin                | ner Run/S                | Stop cont                | rol                    | Run   | Stop         | 0  | R/W |                     |

Table 5.3.3.1 Watchdog timer control bits

# 5.4 Oscillation Circuit

# 5.4.1 Configuration of oscillation circuits

The E0C88365 is twin clock system with two internal oscillation circuits (OSC1 and OSC3).

The OSC1 oscillation circuit generates the 32.768 kHz (Typ.)/38.4 kHz (Typ.)/76.8 kHz (Typ.)/96 kHz (Typ.)/153.6 kHz (Typ.) (one of the frequencies selected by mask option) main clock and the OSC3 oscillation circuit generates the sub-clock when the CPU and some peripheral circuits (output port and programmable timer) are in high speed operation. Figure 5.4.1.1 shows the configuration of the oscillation circuit.



Fig. 5.4.1.1 Configuration of oscillation circuits

At initial reset, OSC1 oscillation circuit is selected for the CPU operating clock and OSC3 oscillation circuit is in a stopped state. ON/OFF switching of the OSC3 oscillation circuit and switching of the system clock between OSC1 and OSC3 are controlled in software. OSC3 circuit is utilized when high speed operation of the CPU and some peripheral circuits become necessary. Otherwise, OSC1 should be used to generate the operating clock and OSC3 circuit placed in a stopped state in order to reduce current consumption.

#### 5.4.2 Mask option

| OSC1 oscillation circuit                                |
|---------------------------------------------------------|
| ☐ Crystal oscillation circuit                           |
| ☐ External clock input                                  |
| ☐ Crystal oscillation circuit (gate capacitor built-in) |
| OSC3 oscillation circuit                                |
| ☐ CR oscillation circuit                                |

In terms of the oscillation circuit types for OSC1, either crystal oscillation, crystal oscillation (gate capacitor built-in) or external clock input can be selected with the mask option.

The OSC3 oscillation circuit is fixed at CR oscillation.



The division ratio in the frequency divider is changed according to the fOSC1 frequency. Therefore, it is necessary to select the frequency to be used by mask option.

#### 5.4.3 OSC1 oscillation circuit

The OSC1 oscillation circuit generates the 32.768 kHz (Typ.)/38.4 kHz (Typ.)/76.8 kHz (Typ.)/96 kHz (Typ.)/153.6 kHz (Typ.) (one of the frequencies selected by mask option) system clock which is utilized during low speed operation (low power mode) of the CPU and peripheral circuits. Furthermore, even when OSC3 is utilized as the system clock, OSC1 continues to generate the source clock for the clock timer, stopwatch timer and serial interface.

This oscillation circuit stops when the SLP instruction is executed. However, in case the SVD circuit is executing an SLP instruction, oscillation is stopped in synchronization with the completion of sampling.

In terms of the oscillation circuit types, either crystal oscillation, crystal oscillation (gate capacitor built-in) or external clock input can be selected with the mask option.

Figure 5.4.3.1 shows the configuration of the OSC1 oscillation circuit.



#### (1) Crystal oscillation circuit



#### (2) External clock input



(3) Crystal oscillation circuit (gate capacitor built-in)

Fig. 5.4.3.1 OSC1 oscillation circuit

When crystal oscillation is selected, a crystal oscillation circuit can be easily formed by connecting a crystal oscillator X'tal1 between the OSC1 and OSC2 terminals along with a capacitor CG1 (5–25pF)\*1 between the OSC1 terminal and Vss. In addition, the gate capacitor CG1 (5 pF) can be built into the circuit by the mask option. When external input is selected, release the OSC2 terminal and input the rectangular wave clock into the OSC1 terminal.

\*1 CG1 = 5–20 pF (including board capacitance) when fosc1 is 153.6 kHz.

#### 5.4.4 OSC3 oscillation circuit

The OSC3 oscillation circuit generates the system clock when the CPU and some peripheral circuits (output port and programmable timer) are in high speed operation.

This oscillation circuit stops when the SLP instruction is executed, or the OSCC register is set to "0". The oscillation circuit is fixed at CR oscillation. Figure 5.4.4.1 shows the configuration of the OSC3 oscillation circuit.



Fig. 5.4.4.1 OSC3 oscillation circuit

The CR oscillation circuit is formed merely by connecting a resistor (RCR3) between OSC3 and OSC4 terminals.

# 5.4.5 Switching the CPU clocks

You can use either OSC1 or OSC3 as the system clock for the CPU and you can switch over by means of software.

You can save power by turning the OSC3 oscillation circuit off while the CPU is operating in OSC1. When you must operate on OSC3, you can change to high speed operation by turning the OSC3 oscillation circuit ON and switching over the system clock. In this case, since 1 msec is necessary for the oscillation to stabilize after turning the OSC3 oscillation circuit ON, you should switch over the clock after stabilization time has elapsed.

When switching over from the OSC3 to the OSC1, turn the OSC3 oscillation circuit OFF immediately following the clock changeover.

That is all for basic switching of the clock. Figure 5.4.5.1 indicates the status transition diagram for the clock changeover.

## **Program Execution Status**



### Standby Status

\*2 The return destination from the standby status becomes the program execution status prior to shifting to the standby status.

Fig. 5.4.5.1 Status transition diagram for the clock changeover

# 5.4.6 Control of oscillation circuit

Table 5.4.6.1 shows the control bits for the oscillation circuits.

Table 5.4.6.1 Oscillation circuit control bits

| Address | Bit | Name                      |                                       | Fur                                     | nction                                   |                           |            | 1            | 0                      | SR  | R/W | Comment |
|---------|-----|---------------------------|---------------------------------------|-----------------------------------------|------------------------------------------|---------------------------|------------|--------------|------------------------|-----|-----|---------|
| 00FF02  | D7  | EBR                       | Bus release (K11 and R                | ,                                       |                                          | ntion)                    | K11<br>R51 | BREQ<br>BACK | Input port Output port | 0   | R/W |         |
|         | D5  | WT2<br><br>WT1<br><br>WT0 | Wait contro  WT2  1  1  1  0  0  0  0 | WT1  1  0  0  1  1  0  0  0  1  0  0  0 | WT0  1 0 1 0 1 0 1 0 1 0 0 0 0 0 0 0 0 0 | of s  1  1  1  8  6  2  2 | 5<br>1     | -            | -                      | 0   | R/W |         |
|         | D3  | CLKCHG                    | CPU operating clock switch            |                                         |                                          |                           | OSC3       | OSC1         | 0                      | R/W | /   |         |
|         | D2  | OSCC                      | OSC3 oscillation On/Off control       |                                         |                                          | On                        | Off        | 0            | R/W                    | /   |     |         |
|         | D1  | VDC1                      | R/W register                          |                                         |                                          | -                         | -          | 0            | R/W                    | /   |     |         |
|         | D0  | VDC0                      | R/W registe                           | er                                      |                                          |                           |            | _            | _                      | 0   | R/W | /       |

#### OSCC: 00FF02H•D2

Controls the ON and OFF settings of the OSC3 oscillation circuit.

When "1" is written: OSC3 oscillation ON When "0" is written: OSC3 oscillation OFF

Reading: Valid

When the CPU and some peripheral circuits (output port and programmable timer) are to be operated at high speed, OSCC is to be set to "1". At all other times, it should be set to "0" in order to reduce current consumption.

At initial reset, OSCC is set to "0" (OSC3 oscillation OFF).

#### CLKCHG: 00FF02H•D3

Selects the operating clock for the CPU.

When "1" is written: OSC3 clock When "0" is written: OSC1 clock Reading: Valid

When the operating clock for the CPU is switched to OSC3, CLKCHG should be set to "1" and when the clock is switched to OSC1, CLKCHG should be set to "0".

At initial reset, CLKCHG is set to "0" (OSC1 clock).

# 5.4.7 Programming notes

- When the high speed CPU operation is not necessary, you should operate the peripheral circuits according to the setting outline indicate below.
  - CPU operating clock OSC1
  - OSC3 oscillation circuit
     OFF (When the OSC3 clock is not necessary
     for some peripheral circuits.)
- (2) Since 1 msec is necessary for the oscillation to stabilize after turning the OSC3 oscillation circuit ON. Consequently, you should switch the CPU operating clock (OSC1 → OSC3) after allowing for a sufficient waiting time once the OSC3 oscillation goes ON.
- (3) When switching the clock from OSC3 to OSC1, be sure to switch OSC3 oscillation OFF with separate instructions. Using a single instruction to process simultaneously can cause a malfunction of the CPU.

# 5.5 Input Ports (K ports)

# 5.5.1 Configuration of input ports

The E0C88365 is equipped with 10 input port bits (K00–K07, K10 and K11) all of which are usable as general purpose input port terminals with interrupt function.

The K00 to K05 terminals have a noise reject function to eliminate noise such as chattering on external inputs. (See Figure 5.5.1.1 (a)). Therefore, the input pulse width must be longer than 7.82 msec for both LOW and HIGH signals.

K10 terminal doubles as the external clock (EVIN) input terminal of the programmable timer (event counter) with input port functions sharing the input signal as is. (See "5.11 Programmable Timer")

The K11 terminal is shared with the bus authority release request signal ( $\overline{BREQ}$ ) input terminal. Function assignment of this terminal can be selected in software. When this terminal is selected for  $\overline{BREQ}$  signal, K11 cannot be used as an input port. (See "5.2 System Controller and Bus Control") In the explanation below, it is assumed that K11 is set as an input port.

Each input port is equipped with a pull-up resistor. The mask option can be used to select either "With resistor" or "Gate direct" for each input port. Figure 5.5.1.1 shows the structure of the input port.





Fig. 5.5.1.1 Structure of input ports

Each input port terminal is directly connected via a three-state buffer to the data bus. Furthermore, the input signal state at the instant of input port readout is read in that form as data.

## 5.5.2 Mask option

| Input port pull-up resisto        | ors           |
|-----------------------------------|---------------|
| K00 □ With resistor               | ☐ Gate direct |
| K01 □ With resistor               | ☐ Gate direct |
| K02 □ With resistor               | ☐ Gate direct |
| K03 □ With resistor               | ☐ Gate direct |
| K04 □ With resistor               | ☐ Gate direct |
| K05 □ With resistor               | ☐ Gate direct |
| K06 □ With resistor               | ☐ Gate direct |
| K07 □ With resistor               | ☐ Gate direct |
| $K10 \dots \square$ With resistor | ☐ Gate direct |
| K11 □ With resistor               | ☐ Gate direct |

Input ports K00–K07, K10 and K11 are all equipped with pull-up resistors. The mask option can be used to select 'With resistor' or 'Gate direct' for each port (bit).

The 'With resistor' option is rendered suitable for purposes such as push switch or key matrix input. When changing the input terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an input port. In particular, special attention should be paid to key scan for key matrix formation. Make this wait time the amount of time or more calculated by the following expression.

# Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

Rin: Pull up resistance Max. value Cin: Terminal capacitance Max. value

When 'Gate direct' is selected, the pull-up resistor is detached and the port is rendered suitable for purposes such as slide switch input and interfacing with other LSIs.

In this case, take care that a floating state does not occur in input.

For unused input ports, select the default setting of "With resistor".

# 5.5.3 Interrupt function and input comparison register

Input port K00-K07, K10 and K11 are all equipped with an interrupt function. These input ports are divided into three groupings: K00-K03 (K0L), K04-K07 (K0H) and K10-K11 (K1). Furthermore, the interrupt generation condition for each series of terminals can be set by software.

When the interrupt generation condition set for each series of terminals is met, the interrupt factor flag FK0L, FK0H or FK1 corresponding to the applicable series is set at "1" and an interrupt is generated.

K00 ○

Address

Address

K01

K02

K06

K07

Interrupt selection register SIK10

Address

K11

Input port KOOD

Input comparsion register KCP00

Interrupt selection register SIK00

Interrupt can be prohibited by setting the interrupt enable registers EK0L, EK0H and EK1 for the corresponding interrupt factor flags.

Furthermore, the priority level for input interrupt can be set at the desired level (0–3) using the interrupt priority registers PK00-PK01 and PK10-PK11 corresponding to each of two groups K0x (K00-K07) and K1x (K10-K11).

For details on the interrupt control registers for the above and on operations subsequent to interrupt generation, see "5.16 Interrupt and Standby Status".

The exception processing vectors for each interrupt

factor are set as follows: K10 and K11 input interrupt: 00000AH K04–K07 input interrupt: 00000CH K00–K03 input interrupt: 00000EH Figure 5.5.3.1 shows the configuration of the input interrupt circuit. Interrupt factor flag FK0L Address Interrupt enable register EK0L

Address

Address

K03 Interrupt Interrupt priority Interrupt priority level judgemen request register circuit K04 ○ PK00, PK01 Input port Address K04D Input comparsion

register KCP04 Address Interrupt factor flag FK0H Interrupt selection register SIK04 Address Address Interrupt enable K05 register EK0H



Address Interrupt priority Interrupt enable Interrupt level judgemen register EK1 request Address Interrupt priority register

PK10, PK11

Address

Fig. 5.5.3.1 Configuration of input interrupt circuit

The interrupt selection registers SIK00–SIK03, SIK04–SIK07 and SIK10–SIK11 and input comparison registers KCP00–KCP03, KCP04–KCP07 and KCP10–KCP11 for each port are used to set the interrupt generation condition described above.

Input port interrupt can be permitted or prohibited by the setting of the interrupt selection register SIK. In contrast to the interrupt enable register EK which masks the interrupt factor for each series of terminals, the interrupt selection register SIK is masks the bit units.

The input comparison register KCP selects whether the interrupt for each input port will be generated on the rising edge or the falling edge of input.

When the data content of the input terminals in which interrupt has been permitted by the interrupt selection register SIK and the data content of the input comparison register KCP change from a conformity state to a non-conformity state, the interrupt factor flag FK should be set to "1" and an interrupt is generated.

Figure 5.5.3.2 shows an example of interrupt generation in the series of terminals K0L (K00–K03).

Because interrupt has been prohibited for K00 by the interrupt selection register SIK00, with the settings as shown in (2), an interrupt will not be generated.

Since K03 is "0" in the next settings (3) in the figure, the non-conformity between the input terminal data K01–K03 where interrupt is permitted and the data from the input comparison registers KCP01–KCP03 generates an interrupt.

In line with the explanation above, since the change in the contents of input data and input comparison registers KCP from a conformity state to a nonconformity state introduces an interrupt generation condition, switching from one non-conformity state to another, as is the case in (4) in the figure, will not generate an interrupt. Consequently, in order to be able to generate a second interrupt, either the input terminal must be returned to a state where its content is once again in conformity with that of the input comparison register KCP, or the input comparison register KCP must be reset. Input terminals for which interrupt is prohibited will not influence an interrupt generation condition.

Interrupt is generated in exactly the same way in the other two series of terminals K0H (K04–K07) and K1 (K10 and K11).



With the settings shown above, interrupt of K0L (K00–K03) is generated under the condition shown below.



Note) Since the K00 to K05 terminals have a noise reject function, the interrupt generation delays the time passing through the noise rejecter.

Fig. 5.5.3.2 Interrupt generation example in K0L (K00–K03)

# 5.5.4 Control of input ports

Table 5.5.4.1 shows the input port control bits.

Table 5.5.4.1(a) Input port control bits

| Address | Bit | Name  | Function                          | 1          | 0         | SR       | R/W      | Comment             |
|---------|-----|-------|-----------------------------------|------------|-----------|----------|----------|---------------------|
| 00FF50  | D7  | SIK07 | K07 interrupt selection register  |            |           |          |          |                     |
|         | D6  | SIK06 | K06 interrupt selection register  |            |           |          |          |                     |
|         | D5  | SIK05 | K05 interrupt selection register  |            |           |          |          | /                   |
|         | D4  | SIK04 | K04 interrupt selection register  | Interrupt  | Interrupt |          | D AX     | /                   |
|         | D3  | SIK03 | K03 interrupt selection register  | enable     | disable   | 0        | R/W      | /                   |
|         | D2  | SIK02 | K02 interrupt selection register  |            |           |          |          |                     |
|         | D1  | SIK01 | K01 interrupt selection register  |            |           |          |          |                     |
|         | D0  | SIK00 | K00 interrupt selection register  |            |           |          |          | /                   |
| 00FF51  | D7  | _     | _                                 | _          | -         | _        | _        |                     |
|         | D6  | _     | _                                 | -          | -         | -        | _        |                     |
|         | D5  | _     | _                                 | -          | -         | _        | _        | Constantly "0" when |
|         | D4  | _     | _                                 | _          | -         | _        | -        | being read          |
|         | D3  | _     | _                                 | -          | -         | _        | -        |                     |
|         | D2  | _     | _                                 | _          | -         | _        | _        |                     |
|         | D1  | SIK11 | K11 interrupt selection register  | Interrupt  | Interrupt |          |          |                     |
|         | D0  | SIK10 | K10 interrupt selection register  | enable     | disable   | 0        | R/W      |                     |
| 00FF52  | D7  | KCP07 | K07 interrupt comparison register |            |           |          |          | /                   |
|         | D6  | KCP06 | K06 interrupt comparison register |            |           |          |          |                     |
|         | D5  | KCP05 | K05 interrupt comparison register | Interrupt  | Interrupt |          |          |                     |
|         | D4  | KCP04 | K04 interrupt comparison register | generated  | generated |          |          | /                   |
|         | D3  | KCP03 | K03 interrupt comparison register | at falling | at rising | 1        | R/W      |                     |
|         |     | KCP02 | K02 interrupt comparison register | edge       | edge      |          |          |                     |
|         |     | KCP01 | K01 interrupt comparison register |            |           |          |          |                     |
|         | D0  | KCP00 | K00 interrupt comparison register |            |           |          |          |                     |
| 00FF53  | D7  | _     | _                                 | -          | -         | _        | _        |                     |
|         | D6  | _     | _                                 | _          | -         | _        | _        |                     |
|         | D5  | _     | _                                 | -          | -         | _        | _        | Constantly "0" when |
|         | D4  | _     | _                                 | _          | -         | _        | _        | being read          |
|         | D3  | _     | _                                 | _          | -         | _        | _        |                     |
|         | D2  | _     | _                                 | -          | -         | _        | _        |                     |
|         | D1  | KCP11 | K11 interrupt comparison register | Falling    | Rising    | _        |          |                     |
|         | D0  | KCP10 | K10 interrupt comparison register | edge       | edge      | 1        | R/W      |                     |
| 00FF54  | D7  | K07D  | K07 input port data               | -          |           |          |          | /                   |
|         | D6  | K06D  | K06 input port data               |            |           | _        |          |                     |
|         | D5  | K05D  | K05 input port data               |            |           |          |          |                     |
|         | D4  | K04D  | K04 input port data               | High level | Low level |          | _        |                     |
|         | D3  | K03D  | K03 input port data               | input      | input     | 0        | R        |                     |
|         | D2  | K02D  | K02 input port data               | •          |           |          |          |                     |
|         |     | K01D  | K01 input port data               |            |           |          |          |                     |
|         | D0  | K00D  | K00 input port data               |            |           |          |          | /                   |
| 00FF55  | D7  | _     | _                                 | _          | -         | _        | _        |                     |
|         | D6  | _     | _                                 | _          | _         | _        | <u> </u> | 1                   |
|         | D5  | _     | _                                 | _          | -         |          | _        | Constantly "0" when |
|         | D4  | _     | _                                 | _          | _         | _        | _        | being read          |
|         | D3  | _     | _                                 | _          | _         | _        | _        |                     |
|         | D2  |       | _                                 | _          | _         | _        | <u> </u> | 1                   |
|         |     | K11D  | K11 input port data               | High level | Low level |          |          |                     |
|         |     | K10D  | K10 input port data               | input      | input     |          | R        |                     |
|         |     |       | par port data                     | put        | put       | <u> </u> |          |                     |

Table 5.5.4.1(b) Input port control bits

| Address | Bit           | Name  | Function                                            | 1                                 |               | 0                  | SR             | R/W    | Comment             |
|---------|---------------|-------|-----------------------------------------------------|-----------------------------------|---------------|--------------------|----------------|--------|---------------------|
| 00FF20  | D7            | PK01  | K00–K07 interrupt priority register                 |                                   |               |                    | 0              | R/W    | /                   |
|         | D6            | PK00  | K00-K07 interrupt priority register                 |                                   | PK01 PK00     |                    |                | IX/ VV |                     |
|         | D5            | PSIF1 | Serial interface interrupt priority register        | PSIF1 PSIF0<br>PSW1 PSW0 Priority |               | 0                  | $0 \mid_{R/W}$ |        |                     |
|         |               | PSIF0 | Scriai interface interrupt priority register        | PTM1                              | M1 PTM0 level |                    |                | IV W   |                     |
|         |               | PSW1  | Stopwatch timer interrupt priority register         | 1                                 | 1             | Level 3<br>Level 2 | 0              | R/W    |                     |
|         |               | PSW0  | stop water timer interrupt priority register        | 0                                 | 1             | Level 1            |                | 10 11  | /                   |
|         |               | PTM1  | Clock timer interrupt priority register             | 0                                 | 0             | Level 0            | 0              | R/W    |                     |
|         | _             | PTM0  | crook time: micriapt priority register              |                                   |               |                    |                | 10     | /                   |
| 00FF21  | D7            | _     | _                                                   | -                                 |               | -                  | _              | -      |                     |
|         | D6            | _     | _                                                   | -                                 |               | -                  | _              | -      | Constantly "0" when |
|         | D5            | _     | _                                                   | -                                 |               | -                  | _              | -      | being read          |
|         | D4            | _     | _                                                   | _                                 |               | -                  | _              | _      |                     |
|         |               | PPT1  | Programmable timer interrupt priority register      | PPT1<br>PK11                      | PPT<br>PK1    |                    | 0              | R/W    |                     |
|         | _             | PPT0  | Trogrammato unior mierrapi priority rograter        | 1                                 | 1             | Level 3            |                | 10     |                     |
|         |               | PK11  | K10 and K11 interrupt priority register             | 1 0                               | 0<br>1        | Level 2<br>Level 1 | 0              | R/W    |                     |
|         | _             | PK10  | 11 , 0                                              | 0                                 | 0             | Level 0            |                | 10     |                     |
| 00FF23  |               | EPT1  | Programmable timer 1 interrupt enable register      |                                   |               |                    |                |        | /                   |
|         | _             | EPT0  | Programmable timer 0 interrupt enable register      |                                   |               |                    |                |        |                     |
|         |               | EK1   | K10 and K11 interrupt enable register               |                                   |               |                    |                |        |                     |
|         |               | EK0H  | K04–K07 interrupt enable register                   | Interr                            | upt           | Interrupt          | 0              | R/W    |                     |
|         | $\overline{}$ | EK0L  | K00–K03 interrupt enable register                   | enat                              | ole           | disable            |                | 10 "   |                     |
|         |               | ESERR | Serial I/F (error) interrupt enable register        |                                   |               |                    |                |        |                     |
|         |               | ESREC | Serial I/F (receiving) interrupt enable register    |                                   |               |                    |                |        |                     |
|         | _             | ESTRA | Serial I/F (transmitting) interrupt enable register |                                   |               |                    |                |        | /                   |
| 00FF25  |               | FPT1  | Programmable timer 1 interrupt factor flag          | (R                                | )             | (R)                |                |        | /                   |
|         | D6            | FPT0  | Programmable timer 0 interrupt factor flag          | Interr                            | upt           | No interrupt       |                |        | /                   |
|         |               | FK1   | K10 and K11 interrupt factor flag                   | facto                             | r is          | factor is          |                |        | /                   |
|         | D4            | FK0H  | K04–K07 interrupt factor flag                       | gener                             | ated          | generated          | 0              | R/W    | /                   |
|         | D3            | FK0L  | K00–K03 interrupt factor flag                       |                                   |               |                    |                | 10, 44 | /                   |
|         | D2            | FSERR | Serial I/F (error) interrupt factor flag            | (W                                | )             | (W)                |                |        | /                   |
|         | D1            | FSREC | Serial I/F (receiving) interrupt factor flag        | Res                               | et            | No operation       |                |        |                     |
|         | D0            | FSTRA | Serial I/F (transmitting) interrupt factor flag     |                                   |               |                    |                |        | V                   |

# K00D-K07D: 00FF54H K10D, K11D: 00FF55H•D0, D1

Input data of input port terminal Kxx can be read out.

When "1" is read: HIGH level When "0" is read: LOW level Writing: Invalid

The terminal voltage of each of the input port K00–K07, K10 and K11 can be directly read out as either a "1" for HIGH (VDD) level or a "0" for LOW (Vss) level.

This bit is exclusively for readout and are not usable for write operations.

## SIK00-SIK07: 00FF50H SIK10, SIK11: 00FF51H•D0, D1

Sets the interrupt generation condition (interrupt permission/prohibition) for input port terminals K00–K07, K10 and K11.

When "1" is written: Interrupt permitted When "0" is written: Interrupt prohibited

Reading: Valid

SIKxx is the interrupt selection register which correspond to the input port Kxx. A "1" setting permits interrupt in that input port and a "0" prohibits it. Changes of state in an input terminal in which interrupt is prohibited, will not influence interrupt generation.

At initial reset, this register is set to "0" (interrupt prohibited).

# KCP00-KCP07: 00FF52H KCP10, KCP11: 00FF53H•D0, D1

Sets the interrupt generation condition (interrupt generation timing) for input port terminals K00–K07, K10 and K11.

When "1" is written: Falling edge When "0" is written: Rising edge Reading: Valid

KCPxx is the input comparison register which correspond to the input port Kxx. Interrupt in those ports which have been set to "1" is generated on the falling edge of the input and in those set to "0" on the rising edge.

At initial reset, this register is set to "1" (falling edge).

## PK00, PK01: 00FF20H•D6, D7 PK10, PK11: 00FF21H•D0, D1

Sets the input interrupt priority level. The two bits PK00 and PK01 are the interrupt priority registers corresponding to the interrupts for K00–K07 (K0L and K0H). Corresponding to K10–K11 (K1), the two bits PK10 and PK11 perform the same function. Table 5.5.4.2 shows the interrupt priority level which can be set by this register.

Table 5.5.4.2 Interrupt priority level settings

| PK11 | PK10 | Interrupt priority level |  |  |  |  |
|------|------|--------------------------|--|--|--|--|
| PK01 | PK00 | Interrupt priority leve  |  |  |  |  |
| 1    | 1    | Level 3 (IRQ3)           |  |  |  |  |
| 1    | 0    | Level 2 (IRQ2)           |  |  |  |  |
| 0    | 1    | Level 1 (IRQ1)           |  |  |  |  |
| 0    | 0    | Level 0 (None)           |  |  |  |  |

At initial reset, this register is set to "0" (level 0).

## EKOL, EKOH, EK1: 00FF23H•D3, D4, D5

How interrupt generation to the CPU is permitted or prohibited.

When "1" is written: Interrupt permitted When "0" is written: Interrupt prohibited

Reading: Valid

The interrupt enable register EK0L corresponds to K00–K03, EK0H to K04–K07, and EK1 to K10–K11. Interrupt is permitted in those series of terminals set to "1" and prohibited in those set to "0". At initial reset, this register is set to "0" (interrupt prohibited).

#### FK0L, FK0H, FK1: 00FF25H•D3, D4, D5

Indicates the generation state for an input interrupt.

When "1" is read: Interrupt factor present When "0" is read: Interrupt factor not present

When "1" is written: Reset factor flag

When "0" is written: Invalid

The interrupt factor flag FK0L corresponds to K00–K03, FK0H to K04–K07, and FK1 to K10–K11 and they are set to "1" by the occurrence of an interrupt generation condition.

When set in this manner, if the corresponding interrupt enable register is set to "1" and the corresponding interrupt priority register is set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. Regardless of the interrupt enable register and interrupt priority register settings, the interrupt factor flag will be set to "1" by the occurrence of an interrupt generation condition.

To accept the subsequent interrupt after interrupt generation, re-setting of the interrupt flags (set interrupt flag to lower level than the level indicated by the interrupt priority registers, or execute the RETE instruction) and interrupt factor flag reset are necessary. The interrupt factor flag is reset to "0" by writing "1".

At initial reset, this flag is all reset to "0".

# 5.5.5 Programming note

When changing the input terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an input port. In particular, special attention should be paid to key scan for key matrix formation. Make this wait time the amount of time or more calculated by the following expression.

# Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

RIN: Pull up resistance Max. value CIN: Terminal capacitance Max. value

# 5.6 Output Ports (R ports)

# 5.6.1 Configuration of output ports

The E0C88365 is equipped with a 42-bit output port (R00–R07, R10–R17, R20–R27, R30–R37, R40–R47, R50, R51).

Depending on the bus mode setting, the configuration of the output ports may vary as shown in the table below.

Table 5.6.1.1 Configuration of output ports

| Table 5.6.1.1 Configuration of output ports |                 |                             |  |  |
|---------------------------------------------|-----------------|-----------------------------|--|--|
| Terminal                                    | Bus mode        |                             |  |  |
| reminal                                     | Single chip     | Expanded 512K               |  |  |
| R00                                         | Output port R00 | Address A0                  |  |  |
| R01                                         | Output port R01 | Address A1                  |  |  |
| R02                                         | Output port R02 | Address A2                  |  |  |
| R03                                         | Output port R03 | Address A3                  |  |  |
| R04                                         | Output port R04 | Address A4                  |  |  |
| R05                                         | Output port R05 | Address A5                  |  |  |
| R06                                         | Output port R06 | Address A6                  |  |  |
| R07                                         | Output port R07 | Address A7                  |  |  |
| R10                                         | Output port R10 | Address A8                  |  |  |
| R11                                         | Output port R11 | Address A9                  |  |  |
| R12                                         | Output port R12 | Address A10                 |  |  |
| R13                                         | Output port R13 | Address A11                 |  |  |
| R14                                         | Output port R14 | Address A12                 |  |  |
| R15                                         | Output port R15 | Address A13                 |  |  |
| R16                                         | Output port R16 | Address A14                 |  |  |
| R17                                         | Output port R17 | Address A15                 |  |  |
| R20                                         | Output port R20 | Address A16                 |  |  |
| R21                                         | Output port R21 | Address A17                 |  |  |
| R22                                         | Output port R22 | Address A18                 |  |  |
| R23                                         | Output port R23 | RD signal                   |  |  |
| R24                                         | Output port R24 | WR signal                   |  |  |
| R25                                         |                 | Output port R25             |  |  |
| R26                                         |                 | Output port R26             |  |  |
| R27                                         | (               | Output port R27             |  |  |
| R30                                         | Output port R30 | Output port R30/CE0 signal  |  |  |
| R31                                         | Output port R31 | Output port R31/CE1 signal  |  |  |
| R32                                         | Output port R32 | Output port R32/CE2 signal  |  |  |
| R33                                         | Output port R33 | Output port R33/CE3 signal  |  |  |
| R34                                         |                 | Output port R34             |  |  |
| R35                                         |                 | Output port R35             |  |  |
| R36                                         |                 | Output port R36             |  |  |
| R37                                         |                 | Output port R37             |  |  |
| R40                                         | '               | Output port R40             |  |  |
| R41                                         |                 | Output port R41             |  |  |
| R42                                         | Output port R42 |                             |  |  |
| R43                                         | Output port R43 |                             |  |  |
| R44                                         | '               | Output port R44             |  |  |
| R45                                         |                 | Output port R45             |  |  |
| R46                                         | '               | Output port R46             |  |  |
| R47                                         | Output port R47 |                             |  |  |
| R50                                         |                 | Output port R50             |  |  |
| R51                                         | Output port R51 | Output port R51/BACK signal |  |  |

Only the configuration of the output ports in single chip mode will be discussed here. With respect to bus control, see "5.2 System Controller and Bus Control".

Figure 5.6.1.1 shows the basic structure (excluding special output circuits) of the output ports.



(a) Nch open drain can be set for R40–R47 by the mask option.



(b) R00-R07, R10-R17, R20-R27, R30-R37, R50, R51

Fig. 5.6.1.1 Structure of output ports

In modes other than single chip mode, the data registers and high impedance control registers of the output ports used for bus function can be used as general purpose registers with read/write capabilities. This will not in any way affect bus signal output.

The output specification of each output port is as complementary output with high impedance control in software possible.

Besides normal DC output, output ports R25–R27, R34, and R50 have a special output function, which can be selected by software.

## 5.6.2 Mask option

| Output ports R40-R47 outp | out specifications |
|---------------------------|--------------------|
| R40   Complementary       | ☐ Nch open drain   |
| R41   Complementary       | ☐ Nch open drain   |
| R42   Complementary       | ☐ Nch open drain   |
| R43   Complementary       | ☐ Nch open drain   |
| R44   Complementary       | ☐ Nch open drain   |
| R45   Complementary       | ☐ Nch open drain   |
| R46   Complementary       | ☐ Nch open drain   |
| R47 □ Complementary       | ☐ Nch open drain   |

Output ports R40–R47 can be used to select output specification for each port (1 bit) by mask option.

The output specification can be selected for either complementary output or Nch open drain output.

Nch open drain output is rendered suitable for purposes as key matrix common output.

For unused input ports, select the default setting of "Complementary".

Note: When Nch open drain has been selected, voltage in excess of the supply voltage range must not applied to the output port terminal.

# 5.6.3 High impedance control

The output port can be high impedance controlled in software.

This makes it possible to share output signal lines with an other external device.

A high impedance control register is set for each series of output port terminals as shown below. Either complementary output and high impedance state can be selected with this register.

Table 5.6.3.1 Correspondence between output ports and high impedance control registers

| Register | Output port terminal |
|----------|----------------------|
| HZR0L    | R00-R03              |
| HZR0H    | R04-R07              |
| HZR1L    | R10-R13              |
| HZR1H    | R14–R17              |
| HZR20    | R20                  |
| HZR21    | R21                  |
| HZR22    | R22                  |
| HZR23    | R23                  |
| HZR24    | R24                  |
| HZR25    | R25                  |
| HZR26    | R26                  |
| HZR27    | R27                  |
| HZR30    | R30                  |
| HZR31    | R31                  |
| HZR32    | R32                  |
| HZR33    | R33                  |
| HZR34    | R34                  |
| HZR35    | R35                  |
| HZR36    | R36                  |
| HZR37    | R37                  |
| HZR4L    | R40-R43              |
| HZR4H    | R44-R47              |
| HZR50    | R50                  |
| HZR51    | R51                  |

When a high impedance control register HZRxx is set to "1", the corresponding output port terminal becomes high impedance state and when set to "0", it becomes complementary output.

## 5.6.4 DC output

As Figure 5.6.1.1 shows, when "1" is written to the output port data register, the output terminal switches to HIGH (VDD) level and when "0" is written it switches to LOW (Vss) level. When output is in a high impedance state, the data written to the data register is output from the terminal at the instant when output is switched to complementary.

## 5.6.5 Special output

Besides normal DC output, output ports R25–R27, R34 and R50 can also be assigned special output functions in software as shown in Table 5.6.5.1.

Table 5.6.5.1 Special output ports

| Output port | Special output |
|-------------|----------------|
| R25         | CL output      |
| R26         | FR output      |
| R27         | TOUT output    |
| R34         | FOUT output    |
| R50         | BZ output      |

#### ■ CL and FR output (R25 and R26)

In order for the E0C88365 to handle connection to an externally expanded LCD driver, output ports R25 and R26 can be used to output a CL signal (LCD synchronous signal) and FR signal (LCD frame signal), respectively.

The configuration of output ports R25 and R26 are shown in Figure 5.6.5.1.



Fig. 5.6.5.1 Configuration of R25 and R26

The output control for the CL signal is done by the register LCCLK. When you set "1" for the LCCLK, the CL signal is output from the output port terminal R25, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R25D.

The output control for the FR signal is done by the register LCFRM. When you set "1" for the LCFRM, the FR signal is output from the output port terminal R26, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R26D.

The frequencies of each signal are changed as shown in Table 5.6.5.2 according to the drive duty selection.

Table 5.6.5.2 Frequencies of CL and FR signals

| fosc1      | Drive duty | CL signal (Hz) | FR signal (Hz) |
|------------|------------|----------------|----------------|
| 32.768 kHz | 1/18       | 1,024          | 28.4           |
| 38.4 kHz   | 1/18       | 1,200          | 33.3           |
| 76.8 kHz   | 1/18       | 1,200          | 33.3           |
| 96.0 kHz   | 1/18       | 1,200          | 33.3           |
| 153.6 kHz  | 1/18       | 1,200          | 33.3           |

Since the signals are generated asynchronously from the registers LCCLK and LCFRM, when the signals are turned ON or OFF by the register settings, a hazard of a 1/2 cycle or less is generated. Figure 5.6.5.2 shows the output waveforms of the CL and FR signals.

| LCCLK/LCFRM 0   | 1 |
|-----------------|---|
| CL output (R25) |   |
| FR output (R26) |   |

Fig. 5.6.5.2 Output waveforms of CL and FR signals

#### **■** TOUT output (R27)

In order for the E0C88365 to provide clock signal to an external device, the output port terminal R27 can be used to output a TOUT signal (clock output by the programmable timer). The configuration of output port R27 is shown in Figure 5.6.5.3.



Fig. 5.6.5.3 Configuration of R27

The output control for the TOUT signal is done by the register PTOUT. When you set "1" for the PTOUT, the TOUT signal is output from the output port terminal R27, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R27D.

The TOUT signal is the programmable timer underflow divided by 1/2.

With respect to frequency control, see "5.11 Programmable Timer".

Since the TOUT signal is generated asynchronously from the register PTOUT, when the signal is turned ON or OFF by the register settings, a hazard of a 1/2 cycle or less is generated.

Figure 5.6.5.4 shows the output waveform of the TOUT signal.



Fig. 5.6.5.4 Output waveform of TOUT signal

#### **■** FOUT output (R34)

In order for the E0C88365 to provide clock signal to an external device, a FOUT signal (oscillation clock fosc1 or fosc3 dividing clock) can be output from the output port terminal R34.

Figure 5.6.5.5 shows the configuration of output port R34.



Fig. 5.6.5.5 Configuration of R34

The output control for the FOUT signal is done by the register FOUTON. When you set "1" for the FOUTON, the FOUT signal is output from the output port terminal R34, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R34D.

The frequency of the FOUT signal can be selected in software by setting the registers FOUT0–FOUT2. The frequency is selected any one from among eight settings as shown in Table 5.6.5.3.

Table 5.6.5.3 FOUT frequency setting

| FOUT2 | FOUT1 | FOUT0 | FOUT frequency |
|-------|-------|-------|----------------|
| 0     | 0     | 0     | foscı / 1      |
| 0     | 0     | 1     | fosc1 / 2      |
| 0     | 1     | 0     | foscı / 4      |
| 0     | 1     | 1     | fosc1 / 8      |
| 1     | 0     | 0     | fosc3 / 1      |
| 1     | 0     | 1     | fosc3 / 2      |
| 1     | 1     | 0     | fosc3 / 4      |
| 1     | 1     | 1     | fosc3 / 8      |

fosc1: OSC1 oscillation frequency fosc3: OSC3 oscillation frequency

When the FOUT frequency is made "fosc3/n", you must turn on the OSC3 oscillation circuit before outputting FOUT. A time interval of 1 msec, from the turning ON of the OSC3 oscillation circuit to until the oscillation stabilizes, is necessary, due to the oscillation element that is used. Consequently, if an abnormality occurs as the result of an unstable FOUT signal being output externally, you should allow an adequate waiting time after turning ON of the OSC3 oscillation, before turning outputting FOUT.

At initial reset, OSC3 oscillation circuit is set to OFF state.

Since the FOUT signal is generated asynchronously from the register FOUTON, when the signal is turned ON or OFF by the register settings, a hazard of a 1/2 cycle or less is generated.

Figure 5.6.5.6 shows the output waveform of the FOUT signal.



Fig. 5.6.5.6 Output waveform of FOUT signal

#### ■ BZ output (R50)

In order for the E0C88365 to drive an external buzzer, a BZ signal (sound generator output) can be output from the output port terminal R50. The configuration of the output port R50 is shown in Figure 5.6.5.7.



Fig. 5.6.5.7 Configuration of R50

The output control for the BZ signal is done by the registers BZON, BZSHT and BZSTP. When you set "1" for the BZON or BZSHT, the BZ signal is output from the output port terminal R50, when "0" is set for the BZON or "1" is set for the BZSTP, the LOW (Vss) level is output. At this time, "0" must always be set for the data register R50D.

The BZ signal which is output makes use of the output of the sound generator. With respect to control of frequency and envelope, see "5.13 Sound Generator".

Since the BZ signal is generated asynchronously from the registers BZON, BZSHT and BZSTP, when the signal is turned ON or OFF by the register settings, a hazard of a 1/2 cycle or less is generated. Figure 5.6.5.8 shows the output waveform of the BZ signal.



Fig. 5.6.5.8 Output waveform of BZ signal

# 5.6.6 Control of output ports

Table 5.6.6.1 shows the output port control bits.

Table 5.6.6.1(a) Output port control bits

| Address | Bit | Name  | Function                       | 1         | 0       | SR | R/W    | Comment    |
|---------|-----|-------|--------------------------------|-----------|---------|----|--------|------------|
| 00FF70  | D7  | HZR51 | R51 high impedance control     | High      | Comple- |    | D 733  | /          |
|         |     | HZR50 | R50 high impedance control     | impedance | mentary | 0  | R/W    | /          |
|         | D5  | HZR4H | R44–R47 high impedance control | High      | Comple- |    | D 733  | 1 /        |
|         | D4  | HZR4L | R40–R43 high impedance control | impedance | mentary | 0  | R/W    | /          |
|         | D3  | HZR1H | R14–R17 high impedance control |           | -       |    |        | 1 /        |
|         | D2  | HZR1L | R10–R13 high impedance control | High      | Comple- |    |        |            |
|         | D1  | HZR0H | R04–R07 high impedance control | impedance | mentary | 0  | R/W    |            |
|         | D0  | HZR0L | R00–R03 high impedance control | -         |         |    |        |            |
| 00FF71  | D7  | HZR27 | R27 high impedance control     |           |         |    |        | /          |
|         | D6  | HZR26 | R26 high impedance control     |           |         |    |        |            |
|         | D5  | HZR25 | R25 high impedance control     |           |         |    |        | /          |
|         | D4  | HZR24 | R24 high impedance control     | High      | Comple- |    | D /33/ |            |
|         | D3  | HZR23 | R23 high impedance control     | impedance | mentary | 0  | R/W    |            |
|         | D2  | HZR22 | R22 high impedance control     |           |         |    |        |            |
|         | D1  | HZR21 | R21 high impedance control     |           |         |    |        |            |
|         | D0  | HZR20 | R20 high impedance control     |           |         |    |        | <u>/</u> _ |
| 00FF72  | D7  | HZR37 | R37 high impedance control     |           |         |    |        | /          |
|         | D6  | HZR36 | R36 high impedance control     |           |         |    |        |            |
|         | D5  | HZR35 | R35 high impedance control     |           |         |    |        |            |
|         | D4  | HZR34 | R34 high impedance control     | High      | Comple- | 0  | R/W    |            |
|         | D3  | HZR33 | R33 high impedance control     | impedance | mentary | "  | IN/ W  |            |
|         | D2  | HZR32 | R32 high impedance control     |           |         |    |        |            |
|         | D1  | HZR31 | R31 high impedance control     |           |         |    |        |            |
|         | D0  | HZR30 | R30 high impedance control     |           |         |    |        |            |
| 00FF73  | D7  | R07D  | R07 output port data           |           |         |    |        | /          |
|         | D6  | R06D  | R06 output port data           |           |         |    |        |            |
|         | D5  | R05D  | R05 output port data           |           |         |    |        |            |
|         | D4  | R04D  | R04 output port data           | High      | Low     | 1  | R/W    |            |
|         | D3  | R03D  | R03 output port data           | Ingn      | Low     | 1  | 10,11  |            |
|         | D2  | R02D  | R02 output port data           |           |         |    |        |            |
|         | D1  | R01D  | R01 output port data           |           |         |    |        |            |
|         | D0  | R00D  | R00 output port data           |           |         |    |        | <u>/</u>   |
| 00FF74  | D7  | R17D  | R17 output port data           |           |         |    |        | /          |
|         | D6  |       | R16 output port data           |           |         |    |        | /          |
|         | D5  | R15D  | R15 output port data           |           |         |    |        | /          |
|         | D4  | R14D  | R14 output port data           | High      | Low     | 1  | R/W    |            |
|         |     | R13D  | R13 output port data           |           |         |    |        |            |
|         | D2  |       | R12 output port data           |           |         |    |        |            |
|         |     |       | R11 output port data           |           |         |    |        |            |
| 005555  |     |       | R10 output port data           |           |         |    |        | Y          |
| 00FF75  |     |       | R27 output port data           |           |         |    |        | /          |
|         |     | R26D  | R26 output port data           |           |         |    |        | /          |
|         |     | R25D  | R25 output port data           |           |         |    |        | /          |
|         |     | R24D  | R24 output port data           | High      | Low     | 1  | R/W    | /          |
|         |     | R23D  | R23 output port data           |           |         |    |        | /          |
|         |     | R22D  | R22 output port data           |           |         |    |        |            |
| ı       |     | R21D  | R21 output port data           |           |         |    |        |            |
|         | D0  | R20D  | R20 output port data           |           |         |    |        | V          |

Table 5.6.6.1(b) Output port control bits

| Address | Bit | Name      | Function                                  | 1             | 0            | SR | R/W    | Comment             |
|---------|-----|-----------|-------------------------------------------|---------------|--------------|----|--------|---------------------|
| 00FF76  | D7  | R37D      | R37 output port data                      |               |              |    |        | /                   |
|         | D6  | R36D      | R36 output port data                      |               |              |    |        | /                   |
|         | D5  | R35D      | R35 output port data                      |               |              |    |        | /                   |
|         | D4  | R34D      | R34 output port data                      | ***           |              |    | D /337 |                     |
|         | D3  | R33D      | R33 output port data                      | High          | Low          | 1  | R/W    |                     |
|         | D2  | R32D      | R32 output port data                      |               |              |    |        |                     |
|         | D1  | R31D      | R31 output port data                      |               |              |    |        |                     |
|         | D0  | R30D      | R30 output port data                      |               |              |    |        |                     |
| 00FF77  | D7  | R47D      | R47 output port data                      |               |              |    |        | /                   |
|         | D6  | R46D      | R46 output port data                      |               |              |    |        | /                   |
|         | D5  | R45D      | R45 output port data                      |               |              |    |        | /                   |
|         | D4  | R44D      | R44 output port data                      |               |              |    |        |                     |
|         |     | R43D      | R43 output port data                      | High          | Low          | 1  | R/W    | /                   |
|         |     | R42D      | R42 output port data                      |               |              |    |        |                     |
|         |     | R41D      | R41 output port data                      |               |              |    |        |                     |
|         |     | R40D      | R40 output port data                      |               |              |    |        | /                   |
| 00FF78  | D7  | _         |                                           | _             | _            |    |        | <u> </u>            |
| 001170  | D6  | _         |                                           | _             | _            |    |        |                     |
|         | D5  |           |                                           |               |              |    |        | Constantly "0" when |
|         | D3  |           |                                           | -             | -            | _  | _      | · ·                 |
|         | D3  |           |                                           | -             | -            | _  | _      | being read          |
|         |     | _         |                                           | -             | -            |    | _      |                     |
|         | D2  | _<br>DE1D | P51turnt u - ut data                      | - TT: 1       | _<br>_       | 1  | - D/W  |                     |
|         |     | R51D      | R51 output port data                      | High          | Low          | 1  | R/W    |                     |
| 005540  | D0  | R50D      | R50 output port data                      | High          | Low          | 0  | R/W    |                     |
| 00FF10  | D7  | _         |                                           | -             | _            |    | _      | Constantry "0" when |
|         | D6  | _         | _                                         | -             | _            |    | _      | being read          |
|         | D5  | -         | _                                         | -             | -            | _  | -      |                     |
|         |     | LCCLK     | CL output control for expanded LCD driver | On            | Off          | 0  | R/W    |                     |
|         |     | LCFRM     | FR output control for expanded LCD driver | On            | Off          | 0  | R/W    |                     |
|         |     | DTFNT     | R/W register                              | -             | -            | 0  | R/W    |                     |
|         |     | LDUTY     | R/W register                              | -             | -            | 0  | R/W    |                     |
|         | D0  | SGOUT     | R/W register                              | -             | -            | 0  | R/W    | /                   |
| 00FF30  | D7  | _         | _                                         | -             | -            |    | _      | Constantry "0" when |
|         | D6  | _         | _                                         | -             | -            | _  | _      | being read          |
|         | D5  | _         | _                                         | -             | -            | _  | _      |                     |
|         |     |           | 8/16-bit mode selection                   | 16-bit x 1    | 8-bit x 2    | 0  | R/W    |                     |
|         |     | CHSEL     | TOUT output channel selection             | Timer 1       | Timer 0      | 0  | R/W    |                     |
|         | D2  | PTOUT     | TOUT output control                       | On            | Off          | 0  | R/W    |                     |
|         | D1  | CKSEL1    | Prescaler 1 source clock selection        | fosc3         | foscı        | 0  | R/W    |                     |
|         | D0  | CKSEL0    | Prescaler 0 source clock selection        | fosc3         | foscı        | 0  | R/W    |                     |
| 00FF44  | D7  | -         | _                                         | -             | -            | -  | -      | Constantry "0" when |
|         | D6  | BZSTP     | One-shot buzzer forcibly stop             | Forcibly stop | No operation | -  | W      | being read          |
|         | D5  | BZSHT     | One-shot buzzer trigger/status R          | Busy          | Ready        | 0  | R/W    |                     |
|         |     |           | W                                         | Trigger       | No operation |    |        |                     |
|         | D4  | SHTPW     | One-shot buzzer duration width selection  | 125 msec      | 31.25 msec   | 0  | R/W    |                     |
|         | D3  | ENRTM     | Envelope attenuation time                 | 1 sec         | 0.5 sec      | 0  | R/W    |                     |
|         | D2  | ENRST     | Envelope reset                            | Reset         | No operation | _  | w      | "0" when being read |
|         |     | ENON      | Envelope On/Off control                   | On            | Off          | 0  | R/W    | *1                  |
|         |     |           | *                                         |               |              |    |        | _                   |

<sup>\*1</sup> Reset to "0" during one-shot output.

Address R/W Comment Bit Name **Function** 0 SR 1 00FF40 D7 "0" when being read 0 R/W D6 FOUT2 FOUT frequency selection FOUT2 FOUT1 FOUT0 Frequency 0 fosci / 1 0 0 0 fosc1/2 1 D5 FOUT1 0 R/W 0 1 0 fosc1/4 O fosci / 8 1 1 0 0 fosc3 / 1 D4 FOUT0 fosc3/2 0 R/W 0 1 0 fosc3/4 1 fosc3/8 1 1 1 D3 FOUTON FOUT output control R/W Off 0 On D2 WDRST Watchdog timer reset Reset No operation W Constantly "0" when D1 TMRST Clock timer reset W Reset No operation being read DO TMRUN Clock timer Run/Stop control Run Stop 0 R/W

Table 5.6.6.1(c) Output port control bits

#### High impedance control

HZR0L, HZR0H: 00FF70H•D0, D1 HZR1L, HZR1H: 00FF70H•D2, D3

HZR20-HZR27: 00FF71H HZR30-HZR37: 00FF72H

HZR4L, HZR4H: 00FF70H•D4, D5 HZR50, HZR51: 00FF70H•D6, D7

Sets the output terminals to a high impedance state.

When "1" is written: High impedance When "0" is written: Complementary

Reading: Valid

HZRxx is the high impedance control register which correspond as shown in Table 5.6.3.1 to the various output port terminals.

When "1" is set to the HZRxx register, the corresponding output port terminal becomes high impedance state and when "0" is set, it becomes complementary output.

At initial reset, this register is set to "0" (complimentary).

#### ■ DC output control

R00D-R07D: 00FF73H R10D-R17D: 00FF74H R20D-R27D: 00FF75H R30D-R37D: 00FF76H R40D-R47D: 00FF77H R50D, R51D: 00FF78H•D0, D1

Sets the data output from the output port terminal Rxx.

When "1" is written: HIGH level output When "0" is written: LOW level output

Reading: Valid

RxxD is the data register for each output port. When "1" is set, the corresponding output port terminal switches to HIGH (VDD) level, and when "0" is set, it switches to LOW (VSS) level. At initial reset, R50D is set to "0" (LOW level output), all other registers are set to "1" (HIGH level output).

The output data registers set for bus signal output can be used as general purpose registers with read/write capabilities which do not affect the output terminals.

#### ■ Special output control

#### LCCLK: 00FF10H•D4

Controls the CL (LCD synchronous) signal output.

When "1" is written: CL signal output When "0" is written: HIGH level (DC) output

Reading: Valid

LCCLK is the output control register for CL signal. When "1" is set, the CL signal is output from the output port terminal R25 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R25D.

At initial reset, LCCLK is set to "0" (HIGH level output).

# LCFRM: 00FF10H•D3

Controls the FR (LCD frame) signal output.

When "1" is written: FR signal output When "0" is written: HIGH level (DC) output

Reading: Valid

LCFRM is the output control register for FR signal. When "1" is set, the FR signal is output from the output port terminal R26 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R26D.

At initial reset, LCFRM is set to "0" (HIGH level output).

#### PTOUT: 00FF30H•D2

Controls the TOUT (programmable timer output clock) signal output.

When "1" is written: TOUT signal output When "0" is written: HIGH level (DC) output

Reading: Valid

PTOUT is the output control register for TOUT signal. When "1" is set, the TOUT signal is output from the output port terminal R27 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R27D. At initial reset, PTOUT is set to "0" (HIGH level output).

#### FOUTON: 00FF40H•D3

Controls the FOUT (fosc1/fosc3 dividing clock) signal output.

When "1" is written: FOUT signal output When "0" is written: HIGH level (DC) output

Reading: Valid

FOUTON is the output control register for FOUT signal. When "1" is set, the FOUT signal is output from the output port terminal R34 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R34D. At initial reset, FOUTON is set to "0" (HIGH level output).

## FOUT0, FOUT1, FOUT2: 00FF40H•D4, D5, D6

FOUT signal frequency is set as shown in Table 5.6.6.2.

Table 5.6.6.2 FOUT frequency settings

| FOUT2 | FOUT1 | FOUT0 | FOUT frequency        |
|-------|-------|-------|-----------------------|
| 0     | 0     | 0     | fosc1 / 1             |
| 0     | 0     | 1     | fosc1 / 2             |
| 0     | 1     | 0     | fosc <sub>1</sub> / 4 |
| 0     | 1     | 1     | fosc1 / 8             |
| 1     | 0     | 0     | fosc3 / 1             |
| 1     | 0     | 1     | fosc3 / 2             |
| 1     | 1     | 0     | fosc3 / 4             |
| 1     | 1     | 1     | fosc3 / 8             |

fosc1: OSC1 oscillation frequency fosc3: OSC3 oscillation frequency

At initial reset, this register is set to "0" (fosc1/1).

#### BZON: 00FF44H•D0

Controls the BZ (buzzer) signal output.

When "1" is written: BZ signal output When "0" is written: LOW level (DC) output

Reading: Valid

BZON is the output control register for BZ signal. When "1" is set, the BZ signal is output from the output port terminal R50 and when "0" is set, LOW (Vss) level is output. At this time, "0" must always be set for the data register R50D.

At initial reset, BZON is set to "0" (LOW level output).

#### BZSHT: 00FF45H•D5

Controls the one-shot buzzer output.

When "1" is written: Trigger When "0" is written: No operation

When "1" is read: Busy When "0" is read: Ready

Writing "1" into BZSHT causes the one-shot output circuit to operate and the BZ signal to be output. The buzzer output is automatically turned OFF after the time set by SHTPW has elapsed. At this time, "0" must always be set for the data register R50D.

The one-shot output is only valid when the normal buzzer output is OFF (BZON = "0") state. The trigger is invalid during ON (BZON = "1") state. When a re-trigger is assigned during a one-shot output, the one-shot output time set with SHTPW is measured again from that point. (time extension) The operation status of the one-shot output circuit can be confirmed by reading BZSHT, when the one-shot output is ON, BZSHT reads "1" and when the output is OFF, it reads "0".

At initial reset, BZSHT is set to "0" (Ready).

#### BZSTP: 00FF45H•D6

Forcibly stops the one-shot buzzer output.

When "1" is written: Forcibly stop
When "0" is written: No operation
Reading: Constantly "0"

By writing "1" into BZSTP, the one-shot buzzer output can be stopped prior to the elapsing of the time set with SHTPW.

Writing "0" is invalid and writing "1" except during one-shot output is also invalid.

When "1" is written to BZSHT and BZSTP simultaneously, BZSTP takes precedence and one-shot output becomes stop status.

Since BZSTP is for writing only, during readout it is constantly set to "0".

# 5.6.7 Programming notes

- (1) Since the special output signals (CL, FR, TOUT, FOUT and BZ) are generated asynchronously from the output control registers (LCCLK, LCFRM, PTOUT, FOUTON, BZON, BZSHT and BZSTP), when the signals is turned ON or OFF by the output control register settings, a hazard of a 1/2 cycle or less is generated.
- (2) When the FOUT frequency is made "fosc3/n", you must turn on the OSC3 oscillation circuit before outputting FOUT. A time interval of 1 msec, from the turning ON of the OSC3 oscillation circuit to until the oscillation stabilizes, is necessary, due to the oscillation element that is used. Consequently, if an abnormality occurs as the result of an unstable FOUT signal being output externally, you should allow an adequate waiting time after turning ON of the OSC3 oscillation, before turning outputting FOUT.

At initial reset, OSC3 oscillation circuit is set to OFF state.

(3) The SLP instruction has executed when the special output signals (TOUT, FOUT and BZ) are in the enable status, an unstable clock is output for the special output at the time of return from the SLEEP state. Consequently, when shifting to the SLEEP state, you should set the special output signal to the disable status prior to executing the SLP instruction.

# 5.7 I/O Ports (P ports)

# 5.7.1 Configuration of I/O ports

The E0C88365 is equipped with 16 bits of I/O ports (P00–P07, P10–P17). The configuration of these I/O ports will vary according to the bus mode as shown below.

Table 5.7.1.1 Configuration of I/O ports

| Terminal | Bus mode             |                           |  |  |  |
|----------|----------------------|---------------------------|--|--|--|
| Terminai | Single chip          | Expanded 64K Expanded 512 |  |  |  |
| P00      | I/O port P00         | Data bus D0               |  |  |  |
| P01      | I/O port P01         | Data bus D1               |  |  |  |
| P02      | I/O port P02         | Data bus D2               |  |  |  |
| P03      | I/O port P03         | Data bus D3               |  |  |  |
| P04      | I/O port P04         | Data bus D4               |  |  |  |
| P05      | I/O port P05         | Data bus D5               |  |  |  |
| P06      | I/O port P06         | Data bus D6               |  |  |  |
| P07      | I/O port P07         | Data bus D7               |  |  |  |
| P10      | I/C                  | port P10 (SIN)            |  |  |  |
| P11      | I/C                  | port P11 (SOUT)           |  |  |  |
| P12      | I/C                  | port P12 (SCLK)           |  |  |  |
| P13      | I/O port P13 (SRDY)  |                           |  |  |  |
| P14      | I/O port P14 (CMPP0) |                           |  |  |  |
| P15      | I/O port P15 (CMPM0) |                           |  |  |  |
| P16      | I/O port P16 (CMPP1) |                           |  |  |  |
| P17      | I/C                  | port P17 (CMPM1)          |  |  |  |

With respect to the data bus, see "5.2 System Controller and Bus Control".

Figure 5.7.1.1 shows the structure of an I/O port.



Fig. 5.7.1.1 Structure of I/O ports

(b) P10-P17

\*1: During output mode \*2: During input mode

I/O port can be set for input or output mode in one bit unit. These settings are performed by writing data to the I/O control registers.

I/O port terminals P10–P13 and P14–P17 are shared with serial interface input/output terminal and analog comparator input terminals, respectively. The function of each terminals is switchable in software. With respect to serial interface and analog comparator, see "5.8 Serial Interface" and "5.14 Analog Comparator", respectively.

The data registers and I/O control registers of I/O ports set for data bus and serial interface output terminals use are usable as general purpose registers with read/write capabilities which do not affect I/O activities of the terminal.

The same as above, the I/O control register of I/O port set for serial interface input terminal use is usable as general purpose register.

The P00 to P07 terminals have a built-in bus holder as shown in Figure 5.7.1.1 (a).

## 5.7.2 Mask option

| I/O port pull-up resistors |               |
|----------------------------|---------------|
| P10 With resistor          | ☐ Gate direct |
| P11   With resistor        | ☐ Gate direct |
| P12   With resistor        | ☐ Gate direct |
| P13   With resistor        | ☐ Gate direct |
| P14   With resistor        | ☐ Gate direct |
| P15 With resistor          | ☐ Gate direct |
| P16 With resistor          | ☐ Gate direct |
| P17   With resistor        | ☐ Gate direct |

I/O ports P10–P17 are equipped with a pull-up resistor which goes ON in the input mode. Whether this resistor is used or not can be selected for each port (one bit unit).

In cases where the 'With resistor' option is selected, the pull-up resistor goes ON when the port is in input mode.

When changing the port terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an I/O port. Make this wait time the amount of time or more calculated by the following expression.

# Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

RIN: Pull up resistance Max. value CIN: Terminal capacitance Max. value

When the analog comparator is used, select "Gate direct" for I/O ports (P14–P15 or P16–P17, or both) which then become input terminals.

For unused I/O ports, select the default setting of "With resistor".

# 5.7.3 I/O control registers and I/O mode

I/O ports P00–P07 and P10–P17 are set either to input or output modes by writing data to the I/O control registers IOC00–IOC07 and IOC10–IOC17 which correspond to each bit.

To set an I/O port to input mode, write "0" to the I/O control register.

The P00 to P07 terminals that are set to input mode, output VDD level or VSS level through the bus holder. The P10 to P17 terminals go to high impedance status.

Readout in input mode consists simply of a direct readout of the input terminal state: the data being "1" when the input terminal is at HIGH (VDD) level and "0" when it is at LOW (VSS) level.

When the "With resistor" option is selected using the mask option, the resistor is pulled up onto the port terminal in input mode.

Even in input mode, data can be written to the data registers without affecting the terminal state. To set an I/O port to output mode, write "1" to the I/O control register. An I/O port which is set to output mode functions as an output port. When port output data is "1", a HIGH (VDD) level is output and when it is "0", a LOW (Vss) level is output. Readout in output mode consists of the contents of the data register.

At initial reset, I/O control registers are set to "0" (I/O ports are set to input mode).

# 5.7.4 Control of I/O ports

Table 5.7.4.1 shows the I/O port control bits.

Table 5.7.4.1 I/O port control bits

| Address | Bit | Name  | Function                 | 1       | 0       | SR | R/W   | Comment |
|---------|-----|-------|--------------------------|---------|---------|----|-------|---------|
| 00FF60  | D7  | IOC07 | P07 I/O control register |         |         |    |       |         |
|         | D6  | IOC06 | P06 I/O control register |         |         |    |       | /       |
|         | D5  | IOC05 | P05 I/O control register |         |         |    |       |         |
|         | D4  | IOC04 | P04 I/O control register | Outmut  | Tamust. | 0  | R/W   |         |
|         | D3  | IOC03 | P03 I/O control register | Output  | Input   | 0  | IN/ W |         |
|         | D2  | IOC02 | P02 I/O control register |         |         |    |       |         |
|         | D1  | IOC01 | P01 I/O control register |         |         |    |       |         |
|         | D0  | IOC00 | P00 I/O control register |         |         |    |       |         |
| 00FF61  | D7  | IOC17 | P17 I/O control register |         |         |    |       |         |
|         | D6  | IOC16 | P16 I/O control register |         |         |    |       | /       |
|         | D5  | IOC15 | P15 I/O control register |         |         |    |       |         |
|         | D4  | IOC14 | P14 I/O control register | 0       | T       | 0  | R/W   |         |
|         | D3  | IOC13 | P13 I/O control register | Output  | Input   | 0  | K/W   |         |
|         | D2  | IOC12 | P12 I/O control register |         |         |    |       |         |
|         | D1  | IOC11 | P11 I/O control register |         |         |    |       |         |
|         | DO  | IOC10 | P10 I/O control register |         |         |    |       |         |
| 00FF62  | D7  | P07D  | P07 I/O port data        |         |         |    |       |         |
|         | D6  | P06D  | P06 I/O port data        |         |         |    |       | /       |
|         | D5  | P05D  | P05 I/O port data        |         |         |    |       |         |
|         | D4  | P04D  | P04 I/O port data        | TT: -1. | Y       | 1  | R/W   |         |
|         | D3  | P03D  | P03 I/O port data        | High    | Low     | 1  | K/W   |         |
|         | D2  | P02D  | P02 I/O port data        |         |         |    |       |         |
|         | D1  | P01D  | P01 I/O port data        |         |         |    |       |         |
|         | DO  | P00D  | P00 I/O port data        |         |         |    |       |         |
| 00FF63  | D7  | P17D  | P17 I/O port data        |         |         |    |       | /       |
|         | D6  | P16D  | P16 I/O port data        |         |         |    |       | /       |
|         | D5  | P15D  | P15 I/O port data        |         |         |    |       |         |
|         | D4  | P14D  | P14 I/O port data        | 77' 1   | _       | 1  | R/W   |         |
|         | D3  | P13D  | P13 I/O port data        | High    | Low     | 1  | K/W   |         |
|         | D2  | P12D  | P12 I/O port data        |         |         |    |       |         |
|         | D1  | P11D  | P11 I/O port data        |         |         |    |       |         |
|         | D0  | P10D  | P10 I/O port data        |         |         |    |       | /       |

*IOC00–IOC07: 00FF60H IOC10–IOC17: 00FF61H* 

Sets the I/O ports to input or output mode.

When "1" is written: Output mode When "0" is written: Input mode Reading: Valid

IOCxx is the I/O control register which correspond

to each I/O port in a bit unit.

Writing "1" to the IOCxx register will switch the corresponding I/O port Pxx to output mode, and writing "0" will switch it to input mode.

When the analog comparator is used, "0" must always be set for the I/O control registers (IOC14–IOC15 or IOC16–IOC17, or both) of I/O ports which will become input terminals.

At initial reset, this register is set to "0" (input

mode).

Note: The data registers of I/O ports set for the data bus and input terminal of serial interface can be used as general purpose registers with read/write capabilities which do not affect I/O activities of the terminals.

#### P00D-P07D, P10D-P17D: 00FF62H, 00FF63H

How I/O port terminal Pxx data readout and output data settings are performed.

# When writing data:

When "1" is written: HIGH level When "0" is written: LOW level

When the I/O port is set to output mode, the data written is output as is to the I/O port terminal. In terms of port data, when "1" is written, the port terminal goes to HIGH (VDD) level and when "0" is written to a LOW (VSS) level.

Even when the port is in input mode, data can still be written in.

#### When reading out data:

When "1" is read: HIGH level ("1") When "0" is read: LOW level ("0")

When an I/O port is in input mode, the voltage level being input to the port terminal is read out. When terminal voltage is HIGH (VDD), it is read as a "1", and when it is LOW (Vss), it is read as a "0". Furthermore, in output mode, the contents of the data register are read out.

At initial reset, this register is set to "1" (HIGH level).

Note: The data registers of I/O ports set for the data bus and output terminal of serial interface can be used as general purpose registers with read/write capabilities which do not affect I/O activities of the terminals.

#### 5.7.5 Programming notes

(1) When changing the port terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an I/O port. Make this wait time the amount of time or more calculated by the following expression.

# Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

RIN: Pull up resistance Max. value CIN: Terminal capacitance Max. value

(2) When the analog comparator is used, "0" must always be set for the I/O control registers (IOC14–IOC15 or IOC16–IOC17, or both) of I/O ports which will become input terminals.

# 5.8 Serial Interface

# 5.8.1 Configuration of serial interface

The E0C88365 incorporates a full duplex serial interface (when asynchronous system is selected) that allows the user to select either clock synchronous system or asynchronous system.

The data transfer method can be selected in software.

When the clock synchronous system is selected, 8-bit data transfer is possible.

When the asynchronous system is selected, either 7-bit or 8-bit data transfer is possible, and a parity check of received data and the addition of a parity bit for transmitting data can automatically be done by selecting in software.

Figure 5.8.1.1 shows the configuration of the serial interface.

Serial interface input/output terminals, SIN, SOUT, SCLK and SRDY are shared with I/O ports P10–P13. In order to utilize these terminals for the serial interface input/output terminals, proper settings have to be made with registers ESIF, SMD0 and SMD1. (At initial reset, these terminals are set as I/O port terminals.)

The direction of I/O port terminals set for serial interface input/output terminals are determined by the signal and transfer mode for each terminal. Furthermore, the settings for the corresponding I/O control registers for the I/O ports become invalid.

Table 5.8.1.1 Configuration of input/output terminals

| Terminal | When serial interface is selected |
|----------|-----------------------------------|
| P10      | SIN                               |
| P11      | SOUT                              |
| P12      | $\overline{\text{SCLK}}$          |
| P13      | $\overline{\text{SRDY}}$          |

<sup>\*</sup> The terminals used may vary depending on the transfer mode.

SIN and SOUT are serial data input and output terminals which function identically in clock synchronous system and asynchronous system. SCLK is exclusively for use with clock synchronous system and functions as a synchronous clock input/output terminal. SRDY is exclusively for use in clock synchronous slave mode and functions as a send-receive ready signal output terminal. When asynchronous system is selected, since SCLK and SRDY are superfluous, the I/O port terminals P12 and P13 can be used as I/O ports. In the same way, when clock synchronous master mode is selected, since SRDY is superfluous, the I/O port terminal P13 can be used as I/O port.



Fig. 5.8.1.1 Configuration of serial interface

## 5.8.2 Mask option

Since serial interface input/output terminals are shared with the I/O ports, serial interface terminal specifications have necessarily been selected with the mask option for I/O ports.



Each I/O port terminal is equipped with a pull-up resistor which goes ON in input mode. A selection can be made for each port (one bit unit) as to whether or not the resistor will be used. Specifications (whether the pull-up will be used or not) of P10 (SIN) and P12 (SCLK) which will become input terminals when using the serial interface are decided by settings the options for the I/O port.

When "Gate direct" is selected in the serial I/F mode, be sure that the input terminals do not go into a floating state.

| Serial I/O data logic |  |
|-----------------------|--|
| □ NON-INV             |  |
| □ INV                 |  |

The logic for the serial I/O data can be selected by mask option. When NON-INV is selected, serial data is input/output from/to the SIN and SOUT terminals without changes. When INV is selected, inverted serial data is input/output from/to the SIN and SOUT terminals. The following explanation is applied when NON-INV is selected.

# 5.8.3 Transfer modes

There are four transfer modes for the serial interface and mode selection is made by setting the two bits of the mode selection registers SMD0 and SMD1 as shown in the table below.

Table 5.8.3.1 Transfer modes

| SMD1 | SMD0 | Mode                     |
|------|------|--------------------------|
| 1    | 1    | Asynchronous 8-bit       |
| 1    | 0    | Asynchronous 7-bit       |
| 0    | 1    | Clock synchronous slave  |
| 0    | 0    | Clock synchronous master |

Table 5.8.3.2 Terminal settings corresponding to each transfer mode

| Mode                     | SIN   | SOUT   | SCLK   | SRDY   |
|--------------------------|-------|--------|--------|--------|
| Asynchronous 8-bit       | Input | Output | P12    | P13    |
| Asynchronous 7-bit       | Input | Output | P12    | P13    |
| Clock synchronous slave  | Input | Output | Input  | Output |
| Clock synchronous master | Input | Output | Output | P13    |

At initial reset, transfer mode is set to clock synchronous master mode.

#### ■ Clock synchronous master mode

In this mode, the internal clock is utilized as a synchronous clock for the built-in shift registers, and clock synchronous 8-bit serial transfers can be performed with this serial interface as the master. The synchronous clock is also output from the SCLK terminal which enables control of the external (slave side) serial I/O device. Since the SRDY terminal is not utilized in this mode, it can be used as an I/O port.

Figure 5.8.3.1(a) shows the connection example of input/output terminals in the clock synchronous master mode.

#### ■ Clock synchronous slave mode

In this mode, a synchronous clock from the external (master side) serial input/output device is utilized and clock synchronous 8-bit serial transfers can be performed with this serial interface as the slave. The synchronous clock is input to the SCLK terminal and is utilized by this interface as the synchronous clock.

Furthermore, the SRDY signal indicating the transmit-receive ready status is output from the SRDY terminal in accordance with the serial interface operating status.

In the slave mode, the settings for registers SCS0 and SCS1 used to select the clock source are invalid. Figure 5.8.3.1(b) shows the connection example of input/output terminals in the clock synchronous slave mode.

#### Asynchronous 7-bit mode

In this mode, asynchronous 7-bit transfer can be performed. Parity check during data reception and addition of parity bit (odd/even/none) during transmitting can be specified and data processed in 7 bits with or without parity. Since this mode employs the internal clock, the SCLK terminal is not used. Furthermore, since the SRDY terminal is not utilized either, both of these terminals can be used as I/O ports.

Figure 5.8.3.1(c) shows the connection example of input/output terminals in the asynchronous mode.

#### ■ Asynchronous 8-bit mode

In this mode, asynchronous 8-bit transfer can be performed. Parity check during data reception and addition of parity bit (odd/even/none) during transmitting can be specified and data processed in 8 bits with or without parity. Since this mode employs the internal clock, the SCLK terminal is not used. Furthermore, since the SRDY terminal is not utilized either, both of these terminals can be used as I/O ports.

Figure 5.8.3.1(c) shows the connection example of input/output terminals in the asynchronous mode.



Fig. 5.8.3.1 Connection examples of serial interface I/O terminals

#### 5.8.4 Clock source

There are four clock sources and selection is made by setting the two bits of the clock source selection register SCS0 and SCS1 as shown in table below.

Table 5.8.4.1 Clock source

| SCS1 | SCS0 | Clock source       |
|------|------|--------------------|
| 1    | 1    | Programmable timer |
| 1    | 0    | foscı / 1          |
| 0    | 1    | foscı / 2          |
| 0    | 0    | fosc1 / 4          |

This register setting is invalid in clock synchronous slave mode and the external clock input from the SCLK terminal is used.

When the "programmable timer" is selected, the programmable timer 1 underflow signal is divided by 1/2 and this signal used as the clock source. With respect to the transfer rate setting, see "5.11 Programmable Timer".

At initial reset, the synchronous clock is set to "fosc1/4".

Whichever clock is selected, the signal is further divided by 1/16 and then used as the synchronous clock

Furthermore, external clock input is used as is for SCLK in clock synchronous slave mode.



Fig. 5.8.4.1 Division of the synchronous clock

#### 5.8.5 Transmit-receive control

Below is a description of the registers which handle transmit-receive control. With respect to transmitreceive control procedures and operations, please refer to the following sections in which these are discussed on a mode by mode basis.

#### ■ Shift register and received data buffer

Exclusive shift registers for transmitting and receiving are installed in this serial interface. Consequently, duplex communication simultaneous transmit and receive is possible when the asynchronous system is selected.

Data being transmitted are written to TRXD0–TRXD7 and converted to serial through the shift register and is output from the SOUT terminal.

In the reception section, a received data buffer is installed separate from the shift register. Data being received are input to the SIN terminal and is converted to parallel through the shift register and written to the received data buffer. Since the received data buffer can be read even during serial input operation, the continuous data is received efficiently.

However, since buffer functions are not used in clock synchronous mode, be sure to read out data before the next data reception begins.

#### Transmit enable register and transmit control bit

For transmitting control, use the transmit enable register TXEN and transmit control bit TXTRG.

The transmit enable register TXEN is used to set the transmitting enable/disable status. When "1" is written to this register to set the transmitting enable status, clock input to the shift register is enabled and the system is ready to transmit data. In the clock synchronous mode, synchronous clock input/output from the  $\overline{SCLK}$  terminal is also enabled.

The transmit control bit TXTRG is used as the trigger to start transmitting data.

Data to be transmitted is written to the transmit data shift register, and when transmitting preparations a recomplete, "1" is written to TXTRG whereupon data transmitting begins.

When interrupt has been enabled, an interrupt is generated when the transmission is completed. If there is subsequent data to be transmitted it can be sent using this interrupt.

In addition, TXTRG can be read as the status. When set to "1", it indicates transmitting operation, and "0" indicates transmitting stop.

For details on timing, see the timing chart which gives the timing for each mode.

When not transmitting, set TXEN to "0" to disable transmitting status.

## ■ Receive enable register, receive control bit

For receiving control, use the receive enable register RXEN and receive control bit RXTRG.

Receive enable register RXEN is used to set receiving enable/disable status. When "1" is written into this register to set the receiving enable status, clock input to the shift register is enabled and the system is ready to receive data. In the clock synchronous mode, synchronous clock input/output from the SCLK terminal is also enabled.

With the above setting, receiving begins and serial data input from the SIN terminal goes to the shift register.

The operation of the receive control bit RXTRG is slightly different depending on whether a clock synchronous system or an asynchronous system is being used.

In the clock synchronous system, the receive control bit TXTRG is used as the trigger to start receiving data.

When received data has been read and the preparation for next data receiving is completed, write "1" into RXTRG to start receiving. (When "1" is written to RXTRG in slave mode, SRDY switches to "0".) In an asynchronous system, RXTRG is used to prepare for next data receiving. After reading the received data from the received data buffer, write "1" into RXTRG to signify that the received data buffer is empty. If "1" is not written into RXTRG, the overrun error flag OER will be set to "1" when the next receiving operation is completed. (An overrun error will be generated when receiving is completed between reading the received data and the writing of "1" to RXTRG.)

In addition, RXTRG can be read as the status. In either clock synchronous mode or asynchronous mode, when RXTRG is set to "1", it indicates receiving operation and when set to "0", it indicates that receiving has stopped.

For details on timing, see the timing chart which gives the timing for each mode.

When you do not receive, set RXEN to "0" to disable receiving status.

# 5.8.6 Operation of clock synchronous transfer

Clock synchronous transfer involves the transfer of 8-bit data by synchronizing it to eight clocks. The same synchronous clock is used by both the transmitting and receiving sides.

When the serial interface is used in the master mode, the clock signal selected using SCS0 and SCS1 is further divided by 1/16 and employed as the synchronous clock. This signal is then sent via the SCLK terminal to the slave side (external serial I/O device).

When used in the slave mode, the clock input to the SCLK terminal from the master side (external serial input/output device) is used as the synchronous clock.

In the clock synchronous mode, since one clock line (SCLK) is shared for both transmitting and receiving, transmitting and receiving cannot be performed simultaneously. (Half duplex only is possible in clock synchronous mode.)

Transfer data is fixed at 8 bits and both transmitting and receiving are conducted with the LSB (bit 0) coming first.



Fig. 5.8.6.1 Transfer data configuration using clock synchronous mode

Below is a description of initialization when performing clock synchronous transfer, transmit-receive control procedures and operations. With respect to serial interface interrupt, see "5.8.8 Interrupt function".

#### ■ Initialization of serial interface

When performing clock synchronous transfer, the following initial settings must be made.

(1) Setting of transmitting/receiving disable

To set the serial interface into a status in which
both transmitting and receiving are disabled, "0"
must be written to both the transmit enable
register TXEN and the receive enable register
RXEN. Fix these two registers to a disable status
until data transfer actually begins.

#### (2) Port selection

Because serial interface input/output ports SIN, SOUT, SCLK and SRDY are set as I/O port terminals P10–P13 at initial reset, "1" must be written to the serial interface enable register ESIF in order to set these terminals for serial interface use.

## (3) Setting of transfer mode

Select the clock synchronous mode by writing the data as indicated below to the two bits of the mode selection registers SMD0 and SMD1.

*Master mode:* SMD0 = "0", SMD1 = "0" *Slave mode:* SMD0 = "1", SMD1 = "0"

#### (4) Clock source selection

In the master mode, select the synchronous clock source by writing data to the two bits of the clock source selection registers SCS0 and SCS1. (See Table 5.8.4.1.)
This selection is not necessary in the slave mode.

Since all the registers mentioned in (2)–(4) are assigned to the same address, it's possible to set them all with one instruction. The parity enable register EPR is also assigned to this address, however, since parity is not necessary in the clock synchronous mode, parity check will not take place regardless of how they are set.

#### (5) Clock source control

When the master mode is selected and programmable timer for the clock source is selected, set transfer rate on the programmable timer side. (See "5.11 Programmable Timer".)

#### ■ Data transmit procedure

The control procedure and operation during transmitting is as follows.

- (1) Write "0" in the transmit enable register TXEN and the receive enable register RXEN to reset the serial interface.
- (2) Write "1" in the transmit enable register TXEN to set into the transmitting enable status.
- (3) Write the transmitting data into TRXD0– TRXD7.
- (4) In case of the master mode, confirm the receive ready status on the slave side (external serial input/output device), if necessary. Wait until it reaches the receive ready status.
- (5) Write "1" in the transmit control bit TXTRG and start transmitting.

In the master mode, this control causes the synchronous clock to change to enable and to be provided to the shift register for transmitting and output from the  $\overline{SCLK}$  terminal. In the slave mode, it waits for the synchronous clock to be input from the  $\overline{SCLK}$  terminal. The transmitting data of the shift register shifts one bit at a time at each falling edge of the synchronous clock and is output from the SOUT terminal. When the final bit (MSB) is output, the SOUT terminal is maintained at that level, until the next transmitting begins.

The transmitting complete interrupt factor flag FSTRA is set to "1" at the point where the data transmitting of the shift register is completed. When interrupt has been enabled, a transmitting complete interrupt is generated at this point.

Set the following transmitting data using this interrupt.

(6) Repeat steps (3) to (5) for the number of bytes of transmitting data, and then set the transmit disable status by writing "0" to the transmit enable register TXEN, when the transmitting is completed.



Fig. 5.8.6.2 Transmit procedure in clock synchronous mode

#### ■ Data receive procedure

The control procedure and operation during receiving is as follows.

- Write "0" in the receive enable register RXEN and transmit enable register TXEN to reset the serial interface.
- (2) Write "1" in the receive enable register RXEN to set into the receiving enable status.
- (3) In case of the master mode, confirm the transmit ready status on the slave side (external serial input/output device), if necessary. Wait until it reaches the transmit ready status.
- (4) Write "1" in the receive control bit RXTRG and start receiving.

In the master mode, this control causes the synchronous clock to change to enable and is provided to the shift register for receiving and output from the SCLK terminal.

In the slave mode, it waits for the synchronous clock to be input from the SCLK terminal. The received data input from the SIN terminal is successively incorporated into the shift register in synchronization with the rising edge of the synchronous clock.

At the point where the data of the 8th bit has been incorporated at the final (8th) rising edge of the synchronous clock, the content of the shift register is sent to the received data buffer and the receiving complete interrupt factor flag FSREC is set to "1". When interrupt has been enabled, a receiving complete interrupt is generated at this point.

- (5) Read the received data from TRXD0–TRXD7 using receiving complete interrupt.
- (6) Repeat steps (3) to (5) for the number of bytes of receiving data, and then set the receive disable status by writing "0" to the receive enable register RXEN, when the receiving is completed.



Fig. 5.8.6.3 Receiving procedure in clock synchronous mode

#### ■ Transmit/receive ready (SRDY) signal

When this serial interface is used in the clock synchronous slave mode (external clock input), an \$\overline{SRDY}\$ signal is output to indicate whether or not this serial interface can transmit/receive to the master side (external serial input/output device). This signal is output from the \$\overline{SRDY}\$ terminal and when this interface enters the transmit or receive enable (READY) status, it becomes "0" (LOW level) and becomes "1" (HIGH level) when there is a BUSY status, such as during transmit/receive operation.

The SRDY signal changes the "1" to "0," immediately after writing "1" into the transmit control bit TXTRG or the receive control bit RXTRG and returns from "0" to "1", at the point where the first synchronous clock has been input (falling edge).

When you have set in the master mode, control the transfer by inputting the same signal from the slave side using the input port or I/O port. At this time, since the  $\overline{SRDY}$  terminal is not set and instead P13 functions as the I/O port, you can apply this port for said control.

#### ■ Timing chart

The timing chart for the clock synchronous system transmission is shown in Figure 5.8.6.4.



Fig. 5.8.6.4 Timing chart (clock synchronous system transmission)

# 5.8.7 Operation of asynchronous transfer

Asynchronous transfer is a mode that transfers by adding a start bit and a stop bit to the front and the back of each piece of serial converted data. In this mode, there is no need to use a clock that is fully synchronized clock on the transmit side and the receive side, but rather transmission is done while adopting the synchronization at the start/stop bits that have attached before and after each piece of data. The RS-232C interface functions can be easily realized by selecting this transfer mode. This interface has separate transmit and receive shift registers and is designed to permit full duplex transmission to be done simultaneously for trans-

For transfer data in the asynchronous 7-bit mode, either 7 bits data (no parity) or 7 bits data + parity bit can be selected. In the asynchronous 8-bit mode, either 8 bits data (no parity) or 8 bits data + parity bit can be selected.

mitting and receiving.

Parity can be even or odd, and parity checking of received data and adding a party bit to transmitting data will be done automatically. Thereafter, it is not necessary to be conscious of parity itself in the program.

The start bit and stop bit are respectively fixed at one bit and data is transmitted and received by placing the LSB (bit 0) at the front.



Fig. 5.8.7.1 Transfer data configuration for asynchronous system

Here following, we will explain the control sequence and operation for initialization and transmitting /receiving in case of asynchronous data transfer. See "5.8.8 Interrupt function" for the serial interface interrupts.

#### ■ Initialization of serial interface

The below initialization must be done in cases of asynchronous system transfer.

# (1) Setting of transmitting/receiving disable To set the serial interface into a status in which both transmitting and receiving are disabled, "0" must be written to both the transmit enable register TXEN and the receive enable register RXEN. Fix these two registers to a disable status until data transfer actually begins.

# (2) Port selection

Because serial interface input/output terminals SIN and SOUT are set as I/O port terminals P10 and P11 at initial reset, "1" must be written to the serial interface enable register ESIF in order to set these terminals for serial interface use.  $\overline{SCLK}$  and  $\overline{SRDY}$  terminals set in the clock synchronous mode are not used in the asynchronous mode. These terminals function as I/O port terminals P12 and P13.

# (3) Setting of transfer mode

Select the asynchronous mode by writing the data as indicated below to the two bits of the mode selection registers SMD0 and SMD1.

**7-bit mode:** SMD0 = "0", SMD1 = "1" **8-bit mode:** SMD0 = "1", SMD1 = "1"

# (4) Parity bit selection

When checking and adding parity bits, write "1" into the parity enable register EPR to set to "with parity check". As a result of this setting, in the asynchronous 7-bit mode, it has a 7 bits data + parity bit configuration and in the asynchronous 8-bit mode it has an 8 bits data + parity bit configuration. In this case, parity checking for receiving and adding a party bit for transmitting is done automatically in hardware. Moreover, when "with parity check" has been selected, "odd" or "even" parity must be further selected in the parity mode selection register PMD. When "0" is written to the PMD register to select "without parity check" in the asynchronous 7-bit mode, data configuration is set to 7 bits data (no parity) and in the asynchronous 8-bit mode (no parity) it is set to 8 bits data (no parity) and parity checking and parity bit adding will not be done.

#### (5) Clock source selection

Select the clock source by writing data to the two bits of the clock source selection registers SCS0 and SCS1. (See Table 5.8.4.1.) Since all the registers mentioned in (2)–(5) are assigned to the same address, it's possible to set them all with one instruction.

(6) Clock source control

When the programmable timer is selected for the clock source, set transfer rate on the programmable timer side. (See "5.11 Programmable Timer".)

# ■ Data transmit procedure

The control procedure and operation during transmitting is as follows.

- (1) Write "0" in the transmit enable register TXEN to reset the serial interface.
- (2) Write "1" in the transmit enable register TXEN to set into the transmitting enable status.
- (3) Write the transmitting data into TRXD0–TRXD7. Also, when 7-bit data is selected, the TRXD7 data becomes invalid.
- (4) Write "1" in the transmit control bit TXTRG and start transmitting.

This control causes the shift clock to change to enable and a start bit (LOW) is output to the SOUT terminal in synchronize to its rising edge. The transmitting data set to the shift register is shifted one bit at a time at each rising edge of the clock thereafter and is output from the SOUT terminal. After the data output, it outputs a stop bit (HIGH) and HIGH level is maintained until the next start bit is output.

The transmitting complete interrupt factor flag FSTRA is set to "1" at the point where the data transmitting is completed. When interrupt has been enabled, a transmitting complete interrupt is generated at this point.

Set the following transmitting data using this

Set the following transmitting data using this interrupt.

(5) Repeat steps (3) to (4) for the number of bytes of transmitting data, and then set the transmit disable status by writing "0" to the transmit enable register TXEN, when the transmitting is completed.



Fig. 5.8.7.2 Transmit procedure in asynchronous mode

#### ■ Data receive procedure

The control procedure and operation during receiving is as follows.

- (1) Write "0" in the receive enable register RXEN to set the receiving disable status and to reset the respective PER, OER, FER flags that indicate parity, overrun and framing errors.
- (2) Write "1" in the receive enable register RXEN to set into the receiving enable status.
- (3) The shift clock will change to enable from the point where the start bit (LOW) has been input from the SIN terminal and the receive data will be synchronized to the rising edge following the second clock, and will thus be successively incorporated into the shift register. After data bits have been incorporated, the stop bit is checked and, if it is not HIGH, it becomes a framing error and the error interrupt factor flag FSERR is set to "1". When interrupt has been enabled, an error interrupt is generated at this point.

When receiving is completed, data in the shift register is transferred to the received data buffer and the receiving complete interrupt flag FSREC is set to "1". When interrupt has been enabled, a receiving complete interrupt is generated at this point. (When an overrun error is generated, the interrupt factor flag FSREC is not set to "1" and a receiving complete interrupt is not generated.)

If "with parity check" has been selected, a parity check is executed when data is transferred into the received data buffer from the shift register and if a parity error is detected, the error interrupt factor flag is set to "1". When the interrupt has been enabled, an error interrupt is generated at this point just as in the framing error mentioned above.

- (4) Read the received data from TRXD0–TRXD7 using receiving complete interrupt.
- (5) Write "1" to the receive control bit RXTRG to inform that the receive data has been read out. When the following data is received prior to writing "1" to RXTRG, it is recognized as an overrun error and the error interrupt factor flag is set to "1". When the interrupt has been enabled, an error interrupt is generated at this point just as in the framing error and parity error mentioned above.
- (6) Repeat steps (3) to (5) for the number of bytes of receiving data, and then set the receive disable status by writing "0" to the receive enable register RXEN, when the receiving is completed.



Fig. 5.8.7.3 Receiving procedure in asynchronous mode

#### ■ Receive error

During receiving the following three types of errors can be detected by an interrupt.

### (1) Parity error

When writing "1" to the EPR register to select "with parity check", a parity check (vertical parity check) is executed during receiving. After each data bit is sent a parity check bit is sent. The parity check bit is a "0" or a "1". Even parity checking will cause the sum of the parity bit and the other bits to be even. Odd parity causes the sum to be odd. This is checked on the receiving side.

The parity check is performed when data received in the shift register is transferred to the received data buffer. It checks whether the parity check bit is a "1" or a "0" (the sum of the bits including the parity bit) and the parity set in the PMD register match. When it does not match, it is recognized as an parity error and the parity error flag PER and the error interrupt factor flag FSERR is set to "1".

When interrupt has been enabled, an error

When interrupt has been enabled, an error interrupt is generated at this point.

The PER flag is reset to "0" by writing "1".

Even when this error has been generated, the received data corresponding to the error is transferred in the received data buffer and the receive operation also continues.

The received data at this point cannot assured because of the parity error.

# (2) Framing error

In asynchronous transfer, synchronization is adopted for each character at the start bit ("0") and the stop bit ("1"). When receiving has been done with the stop bit set at "0", the serial interface judges the synchronization to be off and a framing error is generated. When this error is generated, the framing error flag FER and the error interrupt factor flag FSERR are set to "1". When interrupt has been enabled, an error interrupt is generated at this point. The FER flag is reset to "0" by writing "1". Even when this error has been generated, the received data for it is loaded into the receive data buffer and the receive operation also continues. However, even when it does not become a framing error with the following data receipt, such data cannot be assured.

Even when this error has been generated, the received data corresponding to the error is transferred in the received data buffer and the receive operation also continues. However, even when it does not become a framing error with the following data receiving, such data cannot be assured.

#### (3) Overrun error

When the next data is received before "1" is written to RXTRG, an overrun error will be generated, because the previous receive data will be overwritten. When this error is generated, the overrun error flag OER and the error interrupt factor flag FSERR are set to "1". When interrupt has been enabled, an error interrupt is generated at this point. The OER flag is reset to "0" by writing "1" into it.

Even when this error has been generated, the received data corresponding to the error is transferred in the received data buffer and the receive operation also continues.

Furthermore, when the timing for writing "1" to RXTRG and the timing for the received data transfer to the received data buffer overlap, it will be recognized as an overrun error.

#### ■ Timing chart

Figure 5.8.7.4 show the asynchronous transfer timing chart.



Fig. 5.8.7.4 Timing chart (asynchronous transfer)

# 5.8.8 Interrupt function

This serial interface includes a function that generates the below indicated three types of interrupts.

- Transmitting complete interrupt
- Receiving complete interrupt
- Error interrupt

The interrupt factor flag FSxxx and the interrupt enable register ESxxx for the respective interrupt factors are provided and then the interrupt enable/disable can be selected by the software. In addition, a priority level of the serial interface interrupt for the CPU can be optionally set at levels 0 to 3 by the interrupt priority registers PSIF0 and PSIF1. For details on the above mentioned interrupt control register and the operation following generation of an interrupt, see "5.16 Interrupt and Standby Status".

Figure 5.8.8.1 shows the configuration of the serial interface interrupt circuit.

### ■ Transmitting complete interrupt

This interrupt factor is generated at the point where the sending of the data written into the shift register has been completed and sets the interrupt factor flag FSTRA to "1". When set in this manner, if the corresponding interrupt enable register ESTRA is set to "1" and the corresponding interrupt priority registers PSIF0 and PSIF1 are set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. When "0" has been written into the interrupt enable register ESTRA and interrupt has been disabled, an interrupt is not generated to the CPU. Even in this case, the interrupt factor flag FSTRA is set to "1". The interrupt factor flag FSTRA is reset to "0" by writing "1".

The following transmitting data can be set and the transmitting start (writing "1" to TXTRG) can be controlled by generation of this interrupt factor. The exception processing vector address for this interrupt factor is set at 000014H.



Fig. 5.8.8.1 Configuration of serial interface interrupt circuit

# ■ Receiving complete interrupt

This interrupt factor is generated at the point where receiving has been completed and the receive data incorporated into the shift register has been transferred into the received data buffer and it sets the interrupt factor flag FSREC to "1". When set in this manner, if the corresponding interrupt enable register ESREC is set to "1" and the corresponding interrupt priority registers PSIF0 and PSIF1 are set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. When "0" has been written into the interrupt enable register ESREC and interrupt has been disabled, an interrupt is not generated to the CPU. Even in this case, the interrupt factor flag FSREC is set to "1". The interrupt factor flag FSREC is reset to "0" by writing "1".

The generation of this interrupt factor permits the received data to be read.

Also, the interrupt factor flag is set to "1" when a parity error or framing error is generated.

The exception processing vector address for this interrupt factor is set at 000012H.

#### ■ Error interrupt

This interrupt factor is generated at the point where a parity error, framing error or overrun error is detected during receiving and it sets the interrupt factor flag FSERR to "1". When set in this manner, if the corresponding interrupt enable register ESERR is set to "1" and the corresponding interrupt priority registers PSIF0 and PSIF1 are set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. When "0" has been written in the interrupt enable register ESERR and interrupt has been disabled, an interrupt is not generated to the CPU. Even in this case, the interrupt factor flag FSERR is set to "1". The interrupt factor flag FSERR is reset to "0" by writing "1".

Since all three types of errors result in the same interrupt factor, you should identify the error that has been generated by the error flags PER (parity error), OER (overrun error) and FER (framing error).

The exception processing vector address for this interrupt factor is set at 000010H.

# 5.8.9 Control of serial interface

Table 5.8.9.1 show the serial interface control bits.

Table 5.8.9.1(a) Serial interface control bits

| Address | Bit                | Name  | Function                                     | 1                         | 0                  | SR | R/W | Comment                                          |
|---------|--------------------|-------|----------------------------------------------|---------------------------|--------------------|----|-----|--------------------------------------------------|
| 00FF48  | D7                 | _     | _                                            | -                         | -                  | _  | _   | "0" when being read                              |
|         | D6                 | EPR   | Parity enable register                       | With parity               | Non parity         | 0  | R/W | Only for                                         |
|         | D5                 | PMD   | Parity mode selection                        | Odd                       | Even               | 0  | R/W | asynchronous mode                                |
|         | D4                 | SCS1  | Clock source selection                       | _                         | -                  | 0  | R/W | In the clock synchro-                            |
|         |                    |       | SCS1 SCS0 Clock source                       |                           |                    |    |     | nous slave mode,                                 |
|         |                    |       | 1 1 Programmable timer                       |                           |                    |    |     | external clock is                                |
|         | D3                 | SCS0  | 1 0 fosc1 / 1                                | -                         | -                  | 0  | R/W | selected.                                        |
|         |                    |       | 0 1 fosc1 / 2                                |                           |                    |    |     |                                                  |
|         |                    |       | 0 0 fosc1 / 4                                |                           |                    |    |     |                                                  |
|         | D2                 | SMD1  | Serial I/F mode selection                    | -                         | -                  | 0  | R/W |                                                  |
|         |                    |       | SMD1 SMD0 Mode                               |                           |                    |    |     | /                                                |
|         |                    |       | 1 1 Asynchronous 8-bit                       |                           |                    |    |     |                                                  |
|         | D1                 | SMD0  | 1 0 Asynchronous 7-bit                       | -                         | -                  | 0  | R/W | / /                                              |
|         |                    |       | 0 1 Clock synchronous slave                  |                           |                    |    |     |                                                  |
|         |                    |       | 0 0 Clock synchronous master                 |                           |                    |    |     | /                                                |
|         | D0                 | ESIF  | Serial I/F enable register                   | Serial I/F                | I/O port           | 0  | R/W |                                                  |
| 00FF49  | D7                 | _     | _                                            | -                         | -                  | _  | _   | "0" when being read                              |
|         | D6                 | FER   | Framing error flag R                         | Error                     | No error           | 0  | R/W | Only for                                         |
|         |                    |       | W                                            | Reset (0)                 | No operation       |    |     | asynchronous mode                                |
|         | D5                 | PER   | Parity error flag R                          | Error                     | No error           | 0  | R/W |                                                  |
|         |                    |       | W                                            | Reset (0)                 | No operation       |    |     |                                                  |
|         | D4                 | OER   | Overrun error flag R                         | Error                     | No error           | 0  | R/W |                                                  |
|         |                    |       | W                                            | Reset (0)                 | No operation       |    |     |                                                  |
|         | D3                 | RXTRG | Receive trigger/status R                     | Run                       | Stop               | 0  | R/W |                                                  |
|         |                    |       | W                                            | Trigger                   | No operation       |    |     |                                                  |
|         | _                  | RXEN  | Receive enable                               | Enable                    | Disable            | 0  | R/W |                                                  |
|         | D1                 | TXTRG | Transmit trigger/status R                    | Run                       | Stop               | 0  | R/W |                                                  |
|         | W                  |       | Trigger                                      | No operation              |                    |    | /   |                                                  |
|         | _                  | TXEN  | Transmit enable                              | Enable                    | Disable            | 0  | R/W |                                                  |
| 00FF4A  |                    | TRXD7 | Transmit/Receive data D7 (MSB)               |                           |                    |    |     | /                                                |
|         |                    | TRXD6 | Transmit/Receive data D6                     |                           |                    |    |     |                                                  |
|         |                    | TRXD5 | Transmit/Receive data D5                     |                           |                    |    |     |                                                  |
|         |                    |       | Transmit/Receive data D4                     | High                      | Low                | X  | R/W |                                                  |
|         |                    | TRXD3 | Transmit/Receive data D3                     | _                         |                    |    |     |                                                  |
|         |                    | TRXD2 | Transmit/Receive data D2                     |                           |                    |    |     |                                                  |
|         |                    | TRXD1 | Transmit/Receive data D1                     |                           |                    |    |     |                                                  |
| 005500  |                    | TRXD0 | Transmit/Receive data D0 (LSB)               |                           |                    |    |     | <del>                                     </del> |
| 00FF20  |                    | PK01  | K00–K07 interrupt priority register          |                           |                    | 0  | R/W | /                                                |
|         | _                  | PK00  |                                              | PK01 PK0<br>PSIF1 PSIF    |                    |    |     | / /                                              |
|         |                    | PSIF1 | Serial interface interrupt priority register | PSW1 PSW                  | 70 Priority        | 0  | R/W | / <b> </b>                                       |
|         | _                  | PSIF0 |                                              | PTM1 PTM0 level 1 Level 3 |                    |    |     | /                                                |
|         | D3 PSW1<br>D2 PSW0 |       | Stopwatch timer interrupt priority register  | 1 0                       | Level 2            | 0  | R/W | / <b> </b>                                       |
|         |                    |       |                                              | 0 1 0                     | Level 1<br>Level 0 |    |     | / <b> </b>                                       |
|         |                    | PTM1  | Clock timer interrupt priority register      |                           | Level              | 0  | R/W | / <b> </b>                                       |
|         | טט                 | PTM0  |                                              |                           |                    |    |     | V                                                |

Function Address Bit Name 0 SR R/W Comment 00FF23 D7 EPT1 Programmable timer 1 interrupt enable register D6 EPT0 Programmable timer 0 interrupt enable register D5 EK1 K10 and K11 interrupt enable register D4 EK0H K04–K07 interrupt enable register Interrupt Interrupt R/W 0 D3 EK0L K00-K03 interrupt enable register enable disable D2 ESERR Serial I/F (error) interrupt enable register D1 ESREC Serial I/F (receiving) interrupt enable register D0 ESTRA Serial I/F (transmitting) interrupt enable register 00FF25 D7 FPT1 Programmable timer 1 interrupt factor flag (R) (R) D6 FPT0 Programmable timer 0 interrupt factor flag Interrupt No interrupt D5 FK1 K10 and K11 interrupt factor flag factor is factor is D4 FK0H K04-K07 interrupt factor flag generated generated R/W 0 D3 FK0L K00-K03 interrupt factor flag D2 FSERR Serial I/F (error) interrupt factor flag (W) (W) D1 FSREC Serial I/F (receiving) interrupt factor flag Reset No operation D0 FSTRA Serial I/F (transmitting) interrupt factor flag

Table 5.8.9.1(b) Serial interface control bits

#### ESIF: 00FF48H•D0

Sets the serial interface terminals (P10-P13).

When "1" is written: Serial input/output terminal When "0" is written: I/O port terminal

Reading: Valid

The ESIF is the serial interface enable register and P10–P13 terminals become serial input/output terminals (SIN, SOUT, SCLK, SRDY) when "1" is written, and they become I/O port terminals when "0" is written.

Also, see Table 5.8.3.2 for the terminal settings according to the transfer modes.

At initial reset, ESIF is set to "0" (I/O port).

### SMD0, SMD1: 00FF48H•D1, D2

Set the transfer modes according to Table 5.8.9.2.

Table 5.8.9.2 Transfer mode settings

| SMD1 | SMD0 | Mode                            |
|------|------|---------------------------------|
| 1    | 1    | Asynchronous system 8-bit       |
| 1    | 0    | Asynchronous system 7-bit       |
| 0    | 1    | Clock synchronous system slave  |
| 0    | 0    | Clock synchronous system master |

SMD0 and SMD1 can also read out. At initial reset, this register is set to "0" (clock synchronous master mode).

# SCS0, SCS1: 00FF48H•D3, D4

Select the clock source according to Table 5.8.9.3.

Table 5.8.9.3 Clock source selection

| SCS1 | SCS0 | Clock source       |
|------|------|--------------------|
| 1    | 1    | Programmable timer |
| 1    | 0    | fosc1 / 1          |
| 0    | 1    | fosc1 / 2          |
| 0    | 0    | fosc1 / 4          |

SCS0 and SCS1 can also be read out.

In the clock synchronous slave mode, setting of this register is invalid.

At initial reset, this register is set to "0" (fosc1/4).

# EPR: 00FF48H•D6

Selects the parity function.

When "1" is written: With parity When "0" is written: Non parity Reading: Valid

Selects whether or not to check parity of the received data and to add a parity bit to the transmitting data. When "1" is written to EPR, the most significant bit of the received data is considered to be the parity bit and a parity check is executed. A parity bit is added to the transmitting data. When "0" is written, neither checking is done nor is a parity bit added.

Parity is valid only in asynchronous mode and the EPR setting becomes invalid in the clock synchronous mode.

At initial reset, EPR is set to "0" (non parity).

# PMD: 00FF48H•D5

Selects odd parity/even parity.

When "1" is written: Odd parity When "0" is written: Even parity Reading: Valid

When "1" is written to PMD, odd parity is selected and even parity is selected when "0" is written. The parity check and addition of a parity bit is only valid when "1" has been written to EPR. When "0" has been written to EPR, the parity setting by PMD becomes invalid.

At initial reset, PMD is set to "0" (even parity).

### TXEN: 00FF49H•D0

Sets the serial interface to the transmitting enable status.

When "1" is written: Transmitting enable When "0" is written: Transmitting disable

Reading: Valid

When "1" is written to TXEN, the serial interface shifts to the transmitting enable status and shifts to the transmitting disable status when "0" is written. Set TXEN to "0" when making the initial settings of the serial interface and similar operations. At initial reset, TXEN is set to "0" (transmitting disable).

# TXTRG: 00FF49H•D1

Functions as the transmitting start trigger and the operation status indicator (transmitting/stop status).

When "1" is read: During transmitting When "0" is read: During stop

When "1" is written: Transmitting start

When "0" is written: Invalid

Starts the transmitting when "1" is written to TXTRG after writing the transmitting data. TXTRG can be read as the status. When set to "1", it indicates transmitting operation, and "0" indicates transmitting stop.

At initial reset, TXTRG is set to "0" (during stop).

#### RXEN: 00FF49H•D2

Sets the serial interface to the receiving enable status.

When "1" is written: Receiving enable When "0" is written: Receiving disable

Reading: Valid

When "1" is written to RXEN, the serial interface shifts to the receiving enable status and shifts to the receiving disable status when "0" is written. Set RXEN to "0" when making the initial settings of the serial interface and similar operations. At initial reset, RXEN is set to "0" (receiving disable).

### RXTRG: 00FF49H•D3

Functions as the receiving start trigger or preparation for the following data receiving and the operation status indicator (during receiving/during stop).

When "1" is read: During receiving When "0" is read: During stop

When "1" is written: Receiving start/following

data receiving preparation

When "0" is written: Invalid

RXTRG has a slightly different operation in the clock synchronous system and the asynchronous system.

The RXTRG in the clock synchronous system, is used as the trigger for the receiving start. Writes "1" into RXTRG to start receiving at the point where the receive data has been read and the following receive preparation has been done. (In the slave mode, SRDY becomes "0" at the point where "1" has been written into into the RXTRG.)

RSTRG is used in the asynchronous system for preparation of the following data receiving. Reads the received data located in the received data buffer and writes "1" into RXTRG to inform that the received data buffer has shifted to empty. When "1" has not been written to RXTRG, the overrun error flag OER is set to "1" at the point where the following receiving has been completed. (When the receiving has been completed between the operation to read the received data and the operation to write "1" into RXTRG, an overrun error occurs.)

In addition, RXTRG can be read as the status. In either clock synchronous mode or asynchronous mode, when RXTRG is set to "1", it indicates receiving operation and when set to "0", it indicates that receiving has stopped.

At initial reset, RXTRG is set to "0" (during stop).

### TRXD0-TRXD7: 00FF4AH

### **During transmitting**

Write the transmitting data into the transmit shift register.

When "1" is written: HIGH level When "0" is written: LOW level

Write the transmitting data prior to starting transmitting.

In the case of continuous transmitting, wait for the transmitting complete interrupt, then write the data.

The TRXD7 becomes invalid for the asynchronous 7-bit mode.

Converted serial data for which the bits set at "1" as HIGH (VDD) level and for which the bits set at "0" as LOW (Vss) level are output from the SOUT terminal.

### **During receiving**

Read the received data.

When "1" is read: HIGH level When "0" is read: LOW level

The data from the received data buffer can be read out

Since the sift register is provided separately from this buffer, reading can be done during the receive operation in the asynchronous mode. (The buffer function is not used in the clock synchronous mode.)

Read the data after waiting for the receiving complete interrupt.

When performing parity check in the asynchronous 7-bit mode, "0" is loaded into the 8th bit (TRXD7) that corresponds to the parity bit.

The serial data input from the SIN terminal is level converted, making the HIGH (VDD) level bit "1" and the LOW (VSS) level bit "0" and is then loaded into this buffer.

At initial reset, the buffer content is undefined.

### OER: 00FF49H•D4

Indicates the generation of an overrun error.

When "1" is read: Error
When "0" is read: No error
When "1" is written: Reset to "0"
When "0" is written: Invalid

OER is an error flag that indicates the generation of an overrun error and becomes "1" when an error has been generated.

An overrun error is generated when the receiving of data has been completed prior to the writing of "1" to RXTRG in the asynchronous mode.

OER is reset to "0" by writing "1".

At initial reset and when RXEN is "0", OER is set to "0" (no error).

### PER: 00FF49H•D5

Indicates the generation of a parity error.

When "1" is read: Error
When "0" is read: No error
When "1" is written: Reset to "0"
When "0" is written: Invalid

PER is an error flag that indicates the generation of a parity error and becomes "1" when an error has been generated.

When a parity check is performed in the asynchronous mode, if data that does not match the parity is received, a parity error is generated.

PER is reset to "0" by writing "1".

At initial reset and when RXEN is "0", PER is set to "0" (no error).

# FER: 00FF49H•D6

Indicates the generation of a framing error.

When "1" is read: Error
When "0" is read: No error
When "1" is written: Reset to "0"
When "0" is written: Invalid

FER is an error flag that indicates the generation of a framing error and becomes "1" when an error has been generated.

When the stop bit for the receiving of the asynchronous mode has become "0", a framing error is generated.

FER is reset to "0" by writing "1".

At initial reset and when RXEN is "0", FER is set to "0" (no error).

### PSIF0, PSIF1: 00FF20H•D4, D5

Sets the priority level of the serial interface interrupt.

The two bits PSIF0 and PSIF1 are the interrupt priority register corresponding to the serial interface interrupt. Table 5.8.9.4 shows the interrupt priority level which can be set by this register.

Table 5.8.9.4 Interrupt priority level settings

| PSIF1 | PSIF0 | Interrupt priority level    |
|-------|-------|-----------------------------|
| 1     | 1     | Level 3 (IRQ3)              |
| 1     | 0     | Level 2 ( <del>IRQ2</del> ) |
| 0     | 1     | Level 1 (IRQ1)              |
| 0     | 0     | Level 0 (None)              |

At initial reset, this register is set to "0" (level 0).

# ESTRA, ESREC, ESERR: 00FF23H•D0, D1, D2

Enables or disables the generation of an interrupt for the CPU.

When "1" is written: Interrupt enabled When "0" is written: Interrupt disabled Reading: Valid

ESTRA, ESREC and ESERR are interrupt enable registers that respectively correspond to the interrupt factors for transmitting complete, receiving complete and receiving error. Interrupts set to "1" are enabled and interrupts set to "0" are disabled. At initial reset, this register is set to "0" (interrupt disabled).

# FSTRA, FSREC, FSERR: 00FF25H•D0, D1, D2

Indicates the serial interface interrupt generation status.

When "1" is read: Interrupt factor present
When "0" is read: Interrupt factor not

present

When "1" is written: Resets factor flag

When "0" is written: Invalid

FSTRA, FSREC and FSERR are interrupt factor flags that respectively correspond to the interrupts for transmitting complete, receiving complete and receiving error and are set to "1" by generation of each factor.

Transmitting complete interrupt factor is generated at the point where the data transmitting of the shift register has been completed.

Receiving complete interrupt factor is generated at the point where the received data has been transferred into the received data buffer.

Receive error interrupt factor is generated when a parity error, framing error or overrun error has been detected during data receiving.

When set in this manner, if the corresponding interrupt enable register is set to "1" and the corresponding interrupt priority register is set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. Regardless of the interrupt enable register and interrupt priority register settings, the interrupt factor flag will be set to "1" by the occurrence of an interrupt generation condition.

To accept the subsequent interrupt after interrupt generation, re-setting of the interrupt flags (set interrupt flag to lower level than the level indicated by the interrupt priority registers, or execute the RETE instruction) and interrupt factor flag reset are necessary. The interrupt factor flag is reset to "0" by writing "1".

At initial reset, this flag is reset to "0".

# 5.8.10 Programming notes

- Be sure to initialize the serial interface mode in the transmitting/receiving disable status (TXEN = RXEN = "0").
- (2) Do not perform double trigger (writing "1") to TXTRG (RXTRG) when the serial interface is in the transmitting (receiving) operation. Furthermore, do not execute the SLP instruction. (When executing the SLP instruction, set TXEN = RXEN = "0".)
- (3) In the clock synchronous mode, since one clock line (SCLK) is shared for both transmitting and receiving, transmitting and receiving cannot be performed simultaneously. (Half duplex only is possible in clock synchronous mode.)

  Consequently, be sure not to write "1" to RXTRG (TXTRG) when TXTRG (RXTRG) is "1".
- (4) When a parity error or flaming error is generated during receiving in the asynchronous mode, the receiving error interrupt factor flag FSERR is set to "1" prior to the receiving complete interrupt factor flag FSREC for the time indicated in Table 5.8.10.1. Consequently, when an error is generated, you should reset the receiving complete interrupt factor flag FSREC to "0" by providing a wait time in error processing routines and similar routines. When an overrun error is generated, the receiving complete interrupt factor flag FSREC is not set to "1" and a receiving complete

Table 5.8.10.1 Time difference between FSERR and FSREC on error generation

interrupt is not generated.

|                    | O                            |
|--------------------|------------------------------|
| Clock source       | Time difference              |
| fosc1 / n          | 1/2 cycles of fosc1 / n      |
| Programmable timer | 1 cycle of timer 1 underflow |

# 5.9 Clock Timer

# 5.9.1 Configuration of clock timer

The E0C88365 has built in a clock timer that uses the OSC1 oscillation circuit as clock source. The clock timer is composed of an 8-bit binary counter that counts a 256 Hz signal from fOSC1 frequency divider and a 60 second counter. Each bit data (128 to 1 Hz) of the binary counter can be read by software. The second counter cannot be read. Normally, this clock timer is used for various timing functions such as clocks.

The configuration of the clock timer is shown in Figure 5.9.1.1.

# 5.9.2 Interrupt function

The clock timer can generate an interrupt by each of the  $8\,Hz$ ,  $2\,Hz$ ,  $12\,Hz$  and  $1/60\,Hz$  signals. The configuration of the clock timer interrupt circuit is shown in Figure 5.9.2.1.

Interrupts are generated by respectively setting the corresponding interrupt factor flags FTM8, FTM2, FTM1 and FTM1M at the falling edge of the 8 Hz, 2 Hz, 12 Hz and 1/60 Hz signals to "1". Interrupt can be prohibited by the setting the interrupt enable registers ETM8, ETM2, ETM1 and ETM1M corresponding to each interrupt factor flag. In addition, a priority level of the clock timer interrupt for the CPU can be optionally set at levels 0 to 3 by the interrupt priority registers PTM0 and PTM1.

For details on the above mentioned interrupt control register and the operation following generation of an interrupt, see "5.16 Interrupt and Standby Status".

The exception processing vector addresses for each interrupt factor are respectively set as shown below.

1/60 Hz interrupt: 00001CH 8 Hz interrupt: 00001EH 2 Hz interrupt: 000020H 1 Hz interrupt: 000022H

Figure 5.9.2.2 shows the timing chart for the clock timer.



Fig. 5.9.1.1 Configuration of clock timer



Fig. 5.9.2.1 Configuration of clock timer interrupt circuit



Fig. 5.9.2.2 Timing chart of clock timer

# 5.9.3 Control of clock timer

Table 5.9.3.1 shows the clock timer control bits.

Table 5.9.3.1 Clock timer control bits

| Address | Bit | Name          | Function                                                                                                       | 1                                              | 0                   | SR | R/W   | Comment             |  |
|---------|-----|---------------|----------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------------------|----|-------|---------------------|--|
| 00FF40  | D7  | _             | _                                                                                                              | -                                              | -                   | _  | _     | "0" when being read |  |
|         | D6  | FOUT2         | FOUT frequency selection                                                                                       | -                                              | -                   | 0  | R/W   | 7                   |  |
|         |     |               | $\frac{\text{FOUT2}}{0} \frac{\text{FOUT1}}{0} \frac{\text{FOUT0}}{0} \frac{\text{Frequency}}{\text{fosc1}/1}$ |                                                |                     |    |       |                     |  |
|         | D5  | FOUT1         | 0 0 1 fosc1/2                                                                                                  |                                                |                     | 0  | R/W   | /                   |  |
|         |     |               | 0 1 0 fosc1/4                                                                                                  |                                                |                     |    | 10 11 | / /                 |  |
|         |     |               | 0 1 1 fosc1/8<br>1 0 0 fosc3/1                                                                                 |                                                |                     |    |       | /                   |  |
|         | D4  | FOUT0         | 1 0 0 1 fosc3 / 2                                                                                              | -                                              | -                   | 0  | R/W   |                     |  |
|         |     |               | 1 1 0 fosc3 / 4                                                                                                |                                                |                     |    |       | /                   |  |
|         |     |               | 1 1 1 fosc3 / 8                                                                                                |                                                |                     |    |       | /                   |  |
|         | D3  | FOUTON        | FOUT output control                                                                                            | On                                             | Off                 | 0  | R/W   | /                   |  |
|         | D2  | WDRST         | Watchdog timer reset                                                                                           | Reset                                          | No operation        | _  | W     | Constantly "0" when |  |
|         | D1  | TMRST         | Clock timer reset                                                                                              | Reset                                          | No operation        | _  | W     | being read          |  |
|         | D0  | TMRUN         | Clock timer Run/Stop control                                                                                   | Run                                            | Stop                | 0  | R/W   |                     |  |
| 00FF41  | D7  | TMD7          | Clock timer data 1 Hz                                                                                          |                                                |                     |    |       |                     |  |
|         |     | TMD6          | Clock timer data 2 Hz                                                                                          |                                                |                     |    |       | /                   |  |
|         | D5  |               | Clock timer data 4 Hz                                                                                          |                                                |                     |    |       |                     |  |
|         | D4  | TMD4          | Clock timer data 8 Hz                                                                                          | High                                           | Low                 | 0  | R     | / /                 |  |
|         | D3  | TMD3          | Clock timer data 16 Hz                                                                                         | Ingn   2011                                    |                     |    |       | /                   |  |
|         | D2  | TMD2          | Clock timer data 32 Hz                                                                                         |                                                |                     |    |       | /                   |  |
|         | D1  | TMD1          | Clock timer data 64 Hz                                                                                         |                                                |                     |    |       | /                   |  |
| 205522  | D0  | TMD0          | Clock timer data 128 Hz                                                                                        |                                                |                     |    |       |                     |  |
| 00FF20  |     | PK01          | K00–K07 interrupt priority register                                                                            |                                                |                     | 0  | R/W   |                     |  |
|         |     | PK00<br>PSIF1 |                                                                                                                | PK01 PK00<br>PSIF1 PSIF0                       |                     |    |       | /                   |  |
|         |     | PSIF1         | Serial interface interrupt priority register                                                                   | PSW1 PSW                                       | PSW0 Priority       |    | R/W   |                     |  |
|         |     | PSW1          |                                                                                                                | PTM1 PTM<br>1 1                                | 10 level<br>Level 3 |    |       | /                   |  |
|         |     | PSW0          | Stopwatch timer interrupt priority register                                                                    | 1 0                                            | 0 Level 2           |    | R/W   |                     |  |
|         |     | PTM1          |                                                                                                                | $\begin{bmatrix} 0 & 1 \\ 0 & 0 \end{bmatrix}$ | Level 1<br>Level 0  |    |       | /                   |  |
|         |     | PTM0          | Clock timer interrupt priority register                                                                        |                                                |                     | 0  | R/W   | /                   |  |
| 00FF22  | D7  | _             | _                                                                                                              | _                                              | _                   | _  | _     | "0" when being read |  |
|         | D6  | ESW100        | Stopwatch timer 100 Hz interrupt enable register                                                               |                                                |                     |    |       |                     |  |
|         | D5  | ESW10         | Stopwatch timer 10 Hz interrupt enable register                                                                |                                                |                     |    |       |                     |  |
|         | D4  | ESW1          | Stopwatch timer 1 Hz interrupt enable register                                                                 |                                                |                     |    |       |                     |  |
|         | D3  | ETM1M         | Clock timer 1/60 Hz interrupt enable register                                                                  | Interrupt                                      | Interrupt           | 0  | R/W   |                     |  |
|         | D2  | ETM8          | Clock timer 8 Hz interrupt enable register                                                                     | enable                                         | disable             |    |       | /                   |  |
|         | D1  | ETM2          | Clock timer 2 Hz interrupt enable register                                                                     |                                                |                     |    |       | /                   |  |
|         | D0  | ETM1          | Clock timer 1 Hz interrupt enable register                                                                     |                                                |                     |    |       |                     |  |
| 00FF24  | D7  | _             | -                                                                                                              | -                                              | -                   | _  | _     | "0" when being read |  |
|         |     |               | Stopwatch timer 100 Hz interrupt factor flag                                                                   | (R)                                            | (R)                 |    |       |                     |  |
|         |     | FSW10         | Stopwatch timer 10 Hz interrupt factor flag                                                                    | Interrupt                                      | No interrupt        |    |       |                     |  |
|         |     | FSW1          | Stopwatch timer 1 Hz interrupt factor flag                                                                     | factor is                                      | factor is           |    |       |                     |  |
|         |     | FTM1M         | Clock timer 1/60 Hz interrupt factor flag                                                                      | generated                                      | generated           | 0  | R/W   | /                   |  |
|         |     | FTM8          | Clock timer 8 Hz interrupt factor flag                                                                         | (W)                                            | (W)                 |    |       | /                   |  |
|         |     | FTM2          | Clock timer 2 Hz interrupt factor flag                                                                         | Reset                                          | No operation        |    |       | /                   |  |
|         | טט  | FTM1          | Clock timer 1 Hz interrupt factor flag                                                                         |                                                |                     |    |       | V                   |  |

#### TMD0-TMD7: 00FF41H

The clock timer data can be read out. Each bit of TMD0–TMD7 and frequency correspondence are as follows:

TMD0: 128Hz TMD4: 8Hz TMD1: 64Hz TMD5: 4Hz TMD2: 32Hz TMD6: 2Hz TMD3: 16Hz TMD7: 1Hz

Since the TMD0–TMD7 is exclusively for reading, the write operation is invalid.

At initial reset, the timer data is set to "00H".

# TMRST: 00FF40H•D1

Resets the clock timer. The second counter is also reset.

When "1" is written: Clock timer reset When "0" is written: No operation Reading: Always "0"

The clock timer is reset by writing "1" to the TMRST.

When the clock timer is reset in the RUN status, it restarts immediately after resetting. In the case of the STOP status, the reset data "00H" is maintained. No operation results when "0" is written to the TMRST.

Since the TMRST is exclusively for writing, it always becomes "0" during reading.

### TMRUN: 00FF40H•D0

Controls RUN/STOP of the clock timer.

When "1" is written: RUN When "0" is written: STOP Reading: Valid

The clock timer starts up-counting by writing "1" to the TMRUN and stops by writing "0".

In the STOP status, the count data is maintained until it is reset or set in the next RUN status. Also, when the STOP status changes to the RUN status, the data that was maintained can be used for resuming the count.

At initial reset, the TMRUN is set to "0" (STOP).

# PTM0, PTM1: 00FF20H•D0, D1

Sets the priority level of the clock timer interrupt. The two bits PTM0 and PTM1 are the interrupt priority register corresponding to the clock timer interrupt. Table 5.9.3.2 shows the interrupt priority level which can be set by this register.

*Table 5.9.3.2 Interrupt priority level settings* 

| PTM1 | PTM0 | Interrupt priority level |
|------|------|--------------------------|
| 1    | 1    | Level 3 (IRQ3)           |
| 1    | 0    | Level 2 (IRQ2)           |
| 0    | 1    | Level 1 (IRQ1)           |
| 0    | 0    | Level 0 (None)           |

At initial reset, this register is set to "0" (level 0).

# ETM1, ETM2, ETM8, ETM1M: 00FF22H•D0-D3

Enables or disables the generation of an interrupt for the CPU.

When "1" is written: Interrupt enabled When "0" is written: Interrupt disabled Reading: Valid

The ETM1, ETM2, ETM8 and ETM1M are interrupt enable registers that respectively correspond to the interrupt factors for 1 Hz, 2 Hz, 8 Hz and 1/60 Hz. Interrupts set to "1" are enabled and interrupts set to "0" are disabled.

At initial reset, this register is set to "0" (interrupt disabled).

# FTM1, FTM2, FTM8, FTM1M: 00FF24H•D0–D3

Indicates the clock timer interrupt generation status.

When "1" is read: Interrupt factor present When "0" is read: Interrupt factor not present

When "1" is written: Resets factor flag

When "0" is written: Invalid

The FTM1, FTM2, FTM8 and FTM1M are interrupt factor flags that respectively correspond to the interrupts for 1 Hz, 2 Hz, 8 Hz and 1/60 Hz and are set to "1" at the falling edge of each signal. When set in this manner, if the corresponding interrupt enable register is set to "1" and the corresponding interrupt priority register is set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. Regardless of the interrupt enable register and interrupt priority register settings, the interrupt factor flag will be set to "1" by the occurrence of an interrupt generation condition.

To accept the subsequent interrupt after interrupt generation, re-setting of the interrupt flags (set interrupt flag to lower level than the level indicated by the interrupt priority registers, or execute the RETE instruction) and interrupt factor flag reset are necessary. The interrupt factor flag is reset to "0" by writing "1".

At initial reset, this flag is reset to "0".

# 5.9.4 Programming notes

(1) The clock timer is actually made to RUN/STOP in synchronization with the falling edge of the 256 Hz signal after writing to the TMRUN register. Consequently, when "0" is written to the TMRUN, the timer shifts to STOP status when the counter is incremented "1". The TMRUN maintains "1" for reading until the timer actually shifts to STOP status. Figure 5.9.4.1 shows the timing chart of the RUN/STOP control.



Fig. 5.9.4.1 Timing chart of RUN/STOP control

(2) The SLP instruction is executed when the clock timer is in the RUN status (TMRUN = "1"). The clock timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (TMRUN = "0") prior to executing the SLP instruction.

# 5.10 Stopwatch Timer

# 5.10.1 Configuration of stopwatch timer

The E0C88365 has a built-in 1/100 sec and 1/10 sec stopwatch timer. The stopwatch timer is composed of a 4-bit 2 stage BCD counter (1/100 sec units and 1/10 sec units) that makes the 256 Hz signal that divides the fosc1 the input clock and it can read the count data by software.

Figure 5.10.1.1 shows the configuration of the stopwatch timer.

The stopwatch timer can be used as a timer different from the clock timer and can easily realize stopwatch and other such functions by software.

# 5.10.2 Count up pattern

The stopwatch timer is respectively composed of the 4-bit BCD counters SWD0-SWD3 and SWD4-SWD7.

Figure 5.10.2.1 shows the count up pattern of the stopwatch timer.

The feedback dividing circuit generates an approximate 100 Hz signal at 2/256 sec and 3/256 sec intervals from a 256 Hz signal divided from fosc1.

The 1/100 sec counter (SWD0–SWD3) generates an approximate 10 Hz signal at 25/256 sec and 26/256 sec intervals by counting the approximate 100 Hz signal generated by the feedback dividing circuit in 2/256 sec and 3/256 sec intervals. The count-up is made approximately 1/100 sec counting by the 2/256 sec and 3/256 sec intervals.

The 1/10 sec counter (SWD4–SWD7) generates a 1 Hz signal by counting the approximate 10 Hz signal generated by the 1/100 sec counter at 25/256 sec and 26/256 sec intervals in 4:6 ratios.

The count-up is made approximately 1/10 sec counting by 25/256 sec and 26/256 sec intervals.



# 5.10.3 Interrupt function

The stopwatch timer can generate an interrupt by each of the 100 Hz (approximately 100 Hz), 10 Hz (approximately 10 Hz) and 1 Hz signals. Figure 5.10.3.1 shows the configuration of the stopwatch timer interrupt circuit

The corresponding factor flags FSW100, FSW10 and FSW1 are respectively set to "1" at the falling edge of the 100 Hz, 10Hz and 1Hz signal and an interrupt is generated. Interrupt can be prohibited by the setting of the interrupt enable registers ESW100, ESW10 and ESW1 corresponding to each interrupt factor flag.

In addition, a priority level of the stopwatch timer interrupt for the CPU can be optionally set at levels 0 to 3 by the interrupt priority registers PSW0 and PSW1.

For details on the above mentioned interrupt control registers and the operation following generation of an interrupt, see "5.16 Interrupt and Standby Status".

The exception processing vector addresses of each interrupt factor are respectively set as shown below.

 100 Hz interrupt:
 000016H

 10 Hz interrupt:
 000018H

 1 Hz interrupt:
 00001AH

Figure 5.10.3.2 shows the timing chart for the stopwatch timer.





Fig. 5.10.3.2 Stopwatch timer timing chart

# 5.10.4 Control of stopwatch timer

Table 5.10.4.1 shows the stopwatch timer control bits.

Table 5.10.4.1 Stopwatch timer control bits

| D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D5 ESW10 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Address | Bit | Name    | Function                                         | 1          | 0            | SR      | R/W | Comment             |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|---------|--------------------------------------------------|------------|--------------|---------|-----|---------------------|
| D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 00FF42  | D7  | _       | _                                                | -          | -            | ı       | -   |                     |
| D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | D6  | _       | _                                                | -          | -            | -       | -   |                     |
| D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | D5  | _       | _                                                | -          | -            | -       | -   | Constantly "O" when |
| D3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         | D4  | _       | _                                                | -          | _            | _       | _   | 1                   |
| D1   SWRST   Stopwatch timer reset   Reset   No operation   -   W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         | D3  | _       | _                                                | -          | _            |         | _   | being read          |
| DO   SWRUN   Stopwatch timer Run/Stop control   Run   Stop   O   R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         | D2  | _       | _                                                | -          | _            | _       | _   |                     |
| DOFF43                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         | D1  | SWRST   | Stopwatch timer reset                            | Reset      | No operation | 1       | W   |                     |
| D6   SWD6   D5   SWD5   BCD (1/10 sec)   D4   SWD4   D3   SWD3   Stopwatch timer data   D2   SWD2   D1   SWD1   BCD (1/100 sec)   D0   SWD0   D0   SWD0   D6   PK00   PK00   PSWD   PS   |         | D0  | SWRUN   | Stopwatch timer Run/Stop control                 | Run        | Stop         | 0       | R/W |                     |
| D5   SWD5   BCD (1/10 sec)   D4   SWD4   D3   SWD3   Stopwatch timer data   D2   SWD2   D1   SWD1   BCD (1/100 sec)   D0   SWD0   D5   PSIF1   D4   PSIF0   D7   PSIF1   D4   PSIF0   D7   PSWD   PS   | 00FF43  | D7  | SWD7    | Stopwatch timer data                             |            |              |         |     | /                   |
| D4 SWD4 D3 SWD3 D2 SWD2 D1 SWD1 D0 SWD0  OOFF20 D5 PSIF1 D4 PSIF0 D3 PSW1 D2 PSW0 D1 PTM1 D0 PTM0 D1 PTM1 D0 PTM0 D6 ESW100 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1 Hz interrupt enable register D1 ETM2 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 D1 ETM2 D1 ETM2 D1 ETM2 D1 ETM2 D1 ETM2 D1 ETM3 |         | D6  | SWD6    |                                                  |            |              |         |     |                     |
| D3 SWD3 Stopwatch timer data D2 SWD2 D1 SWD1 BCD (1/100 sec) D0 SWD0  OOFF20 D7 PK01 D6 PK00 Serial interface interrupt priority register D4 PSIF0 Serial interface interrupt priority register D3 PSW1 D2 PSW0 D1 PTM1 D0 PTM0 Clock timer interrupt priority register D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1 Hz interrupt enable register D4 ESW1 Clock timer 2 Hz interrupt enable register D6 ETM2 Clock timer 2 Hz interrupt enable register D7 ETM2 Clock timer 2 Hz interrupt enable register D8 ESW10 Clock timer 2 Hz interrupt enable register D9 ETM1 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D2 ETM8 Clock timer 3 Hz interrupt enable register D3 ETM1 ETM2 Clock timer 3 Hz interrupt enable register D4 EXM1 EXM2 Clock timer 3 Hz |         | D5  | SWD5    | BCD (1/10 sec)                                   |            |              |         |     | /                   |
| D3 SWD2 D1 SWD1 D0 SWD0  O0FF20 D7 PK01 D6 PK00 D5 PSIF1 D4 PSIF0 D3 PSW1 D2 PSW0 D1 PTM1 D2 PSW0 D1 PTM1 D0 PTM0 Clock timer interrupt priority register D5 ESW100 Stopwatch timer 100 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1 Hz interrupt enable register D1 ETM2 D2 ETM8 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         | D4  | SWD4    |                                                  |            |              | 0       |     |                     |
| D1   SWD1   BCD (1/100 sec)   D0   SWD0   D0   SWD0   D0   SWD0   D0   FX00   D5   PK01   D6   PK00   D5   PSIF1   D4   PSIF0   D2   PSW0   D1   PTM1   D0   PTM0   D1   PTM1   D0   PTM0   D6   ESW100   Stopwatch timer interrupt priority register   D5   ESW10   Stopwatch timer 10 Hz interrupt enable register   D3   ETM1M   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 2 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock timer 1 Hz interrupt enable register   D1   ETM2   Clock time   |         | D3  | SWD3    | Stopwatch timer data                             |            |              | U       | K   |                     |
| DOFF20 D7 PK01 D6 PK00 D5 PSIF1 D4 PSIF0 D1 PTM1 D0 PTM0 D1 PTM1 D0 PTM0 D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D5 ESW10 Stopwatch timer 1 Hz interrupt enable register D6 ESW10 Stopwatch timer 1 Hz interrupt enable register D7 ETM8 D8 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 D1 ETM2 D1 ETM2 D1 ETM1 D2 ETM8 Clock timer 2 Hz interrupt enable register D1 ETM1 D2 ETM1 D3 ETM1 Clock timer 1 Hz interrupt enable register D6 ETM1 Clock timer 1 Hz interrupt enable register D7 ETM1 D8 ETM1 Clock timer 2 Hz interrupt enable register D8 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM1 Clock timer 1 Hz interrupt enable register D9 ETM2 D9 ETM3  |         | D2  | SWD2    |                                                  |            |              |         |     |                     |
| OOFF20 D7 PK01 D6 PK00 D5 PSIF1 D4 PSIF0 D5 PSW0 D7 PK01 D6 PSW1 D6 PSW1 D7 PS |         | D1  | SWD1    | BCD (1/100 sec)                                  |            |              |         |     |                     |
| D6 PK00 D5 PSIF1 D4 PSIF0 Serial interface interrupt priority register D3 PSW1 D0 PTM1 D0 PTM1 D0 PTM0 D5 ESW100 Stopwatch timer 100 Hz interrupt enable register D4 ESW1 D5 ESW10 D6 ESW100 Stopwatch timer 1/60 Hz interrupt enable register D6 ESW100 Stopwatch timer 1/60 Hz interrupt enable register D7 ESW1 D8 ETM1 Clock timer 1/60 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D1 ETM2 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 Clock timer 1 Hz interrupt enable register D1 ETM2 Clock timer 1 Hz interrupt enable register D2 ETM8 Clock timer 1 Hz interrupt enable register D3 ETM1 Clock timer 1 Hz interrupt enable register D4 ESW1 Clock timer 1 Hz interrupt enable register D5 ESW10 Clock timer 1 Hz interrupt enable register D6 ETM1 Clock timer 1 Hz interrupt enable register D7 — — — — — — — — — — — — — — — — — — —                                                                                                                                                                                                                                                                                                                                                                                                                                     |         | D0  | SWD0    |                                                  |            |              |         |     | /                   |
| D6 PK00 D5 PSIF1 D4 PSIF0 D7 PSW0 D8W1 D8W1 D9W1 D1 PTM1 D0 PTM0 D1 PTM1 D0 PTM0 D1 PTM1 D0 PTM0 D1 ESW100 D1 Level 0 D1 PTM1 D0 PTM0 D1 PTM1 D0 PTM0 D1 ESW100 D1 Level 0 D1 ESW100 D1 Level 0 D1 ESW100 D1 Level 0 D1 ETM1 D2 ETM8 D3 ETM1M Clock timer 1/60 Hz interrupt enable register D1 ETM2 D1 ETM2 D1 ETM2 D1 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 D1 Clock timer 2 Hz interrupt enable register D1 ETM1 Clock timer 1 Hz interrupt enable register D1 ETM2 D1 Clock timer 2 Hz interrupt enable register D2 ETM8 D3 ETM1 Clock timer 1 Hz interrupt enable register D3 ETM1 Clock timer 1 Hz interrupt enable register D4 ESW1 Clock timer 2 Hz interrupt enable register D5 ESW10 Clock timer 1 Hz interrupt enable register D7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 00FF20  | D7  | PK01    |                                                  |            |              |         |     | /                   |
| D5   PSIF1   Serial interface interrupt priority register   D4   PSIF0   PSW1   PSW0   Priority   PTM1   PTM0   level   1   1   Level 3   1   0   Level 2   0   R/W   PTM1   PTM0   level 3   1   Leve   |         | D6  | PK00    | K00–K07 interrupt priority register              | PK01 PK0   | 0            | 0       | R/W | /                   |
| D4 PSIFO D3 PSW1 D2 PSW0 Stopwatch timer interrupt priority register D1 PTM1 D0 PTM0  O0FF22 D7 0 - 0 - 0 - 0 - 0 - 0 - 0 - 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         | D5  | PSIF1   |                                                  | PSIF1 PSIF | 05           |         |     |                     |
| D3   PSW1   D2   PSW0   Stopwatch timer interrupt priority register   D1   PTM1   Clock timer interrupt priority register   D7   PTM0   Clock timer interrupt priority register   D6   ESW100   Stopwatch timer 100 Hz interrupt enable register   D5   ESW10   Stopwatch timer 10 Hz interrupt enable register   D3   ETM1M   Clock timer 1/60 Hz interrupt enable register   D2   ETM8   Clock timer 1/60 Hz interrupt enable register   D1   ETM2   Clock timer 2 Hz interrupt enable register   D1   ETM2   Clock timer 2 Hz interrupt enable register   D0   ETM1   Clock timer 1 Hz interrupt enable register   D7   PTM1   Clock timer 1 Hz interrupt enable register   D7   PTM2   Clock timer 2 Hz interrupt enable register   D7   PTM2   Clock timer 1 Hz interrupt enable register   D7   PTM3   Clock timer 2 Hz interrupt enable register   D7   PTM4   Clock timer 1 Hz interrupt enable register   D7   PTM4   Clock timer 2 Hz interrupt enable register   D7   PTM4   Clock timer 2 Hz interrupt enable register   D7   PTM4   Clock timer 2 Hz interrupt enable register   D7   PTM5    |         | D4  | PSIF0   | Serial interface interrupt priority register     |            | -            | 0       | R/W |                     |
| D1 PTM1 D0 PTM0 Clock timer interrupt priority register  0 1 Level 0 0 R/W  00FF22 D7 "0" when being 1 D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D5 ESW1 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         | D3  | PSW1    |                                                  | 1 1        | Level 3      |         |     |                     |
| D1 PTM1 D0 PTM0 Clock timer interrupt priority register  0 0 Level 0 0 R/W  00FF22 D7 "0" when being 1 D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D5 ESW10 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 FF24 D7 "0" when being 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         | D2  | PSW0    | Stopwatch timer interrupt priority register      |            |              | 0       | R/W |                     |
| D0 PTM0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |         | D1  | PTM1    |                                                  |            |              |         |     |                     |
| O0FF22 D7 "0" when being to D6 ESW100 Stopwatch timer 100 Hz interrupt enable register D5 ESW10 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         | D0  | PTM0    | Clock timer interrupt priority register          |            |              | 0   R/W |     | /                   |
| D5 ESW10 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 FF24 D7 "0" when being the company of the co         | 00FF22  |     | _       | _                                                | -          | -            | _       | -   | "0" when being read |
| D5 ESW10 Stopwatch timer 10 Hz interrupt enable register D4 ESW1 Stopwatch timer 1 Hz interrupt enable register D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 FF24 D7 "0" when being the company of the co         |         | D6  | ESW100  | Stopwatch timer 100 Hz interrupt enable register |            |              |         |     | /                   |
| D3 ETM1M Clock timer 1/60 Hz interrupt enable register D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register D0 F724 D7 "0" when being 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |     |         |                                                  |            |              |         |     |                     |
| D3 ETM1M   Clock timer 1/60 Hz interrupt enable register   D2 ETM8   Clock timer 8 Hz interrupt enable register   D1 ETM2   Clock timer 2 Hz interrupt enable register   D0 ETM1   Clock timer 1 Hz interrupt enable register   D7 "0" when being 1   Clock timer 1 Hz interrupt enable register   D7 "0" when being 1   Clock timer 1 Hz interrupt enable register   D7 "0" when being 1   Clock timer 1 Hz interrupt enable register   Clock timer 1 Hz interrupt enable register   Clock timer 1 Hz interrupt enable register   Clock timer 2 Hz interrupt enable register   Clock timer 2 Hz interrupt enable register   Clock timer 2 Hz interrupt enable register   Clock timer 3 Hz interrupt enable register   Clock timer 4 Hz interrupt enable register   Clock timer 5 Hz interrupt enable register   Clock timer 6 Hz interrupt enable register   Clock timer 7 Hz interrupt enable register   Clock timer 6 Hz interrupt enable register   Clock timer 6 Hz interrupt enable register   Clock timer 7 Hz interrupt enable register   Clock timer 6 Hz interrupt enable register   Clock timer 7 Hz inter                         |         | D4  | ESW1    | Stopwatch timer 1 Hz interrupt enable register   |            |              |         |     |                     |
| D2 ETM8 Clock timer 8 Hz interrupt enable register D1 ETM2 Clock timer 2 Hz interrupt enable register D0 ETM1 Clock timer 1 Hz interrupt enable register  00FF24 D7 "0" when being 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |         | D3  | ETM1M   | Clock timer 1/60 Hz interrupt enable register    | •          | Interrupt    | 0       | R/W |                     |
| D0   ETM1   Clock timer 1 Hz interrupt enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         | D2  | ETM8    |                                                  | enable     | disable      |         |     |                     |
| 00FF24 D7 "0" when being 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         | D1  | ETM2    | Clock timer 2 Hz interrupt enable register       |            |              |         |     |                     |
| 00FF24 D7 "0" when being 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |         | D0  | ETM1    | <del>-</del>                                     |            |              |         |     |                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 00FF24  | D7  | _       | _                                                | _          | _            | _       | _   | "0" when being read |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         | D6  | FSW100  | Stopwatch timer 100 Hz interrupt factor flag     | (R)        | (R)          |         |     | /                   |
| D5 FSW10 Stopwatch timer 10 Hz interrupt factor flag Interrupt No interrupt                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |     |         |                                                  | , ,        | ` ′          |         |     | /                   |
| D4 FSW1 Stopwatch timer 1 Hz interrupt factor flag factor is factor is                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |     |         |                                                  | •          |              |         |     | /                   |
| D3 FTM1M Clock timer 1/60 Hz interrupt factor flag generated generated 0 R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Ī       |     |         | 1 0                                              |            |              | 0       | R/W | /                   |
| D2 FTM8   Clock timer 8 Hz interrupt factor flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |     |         |                                                  |            |              | _       |     |                     |
| D1 FTM2   Clock timer 2 Hz interrupt factor flag   (W) (W)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | ŀ       |     | <b></b> |                                                  | (W)        | (W)          |         |     |                     |
| D0 FTM1 Clock timer 1 Hz interrupt factor flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ł       |     |         |                                                  | Reset      | No operation |         |     | /                   |

### SWD0-SWD7: 00FF43H

The stopwatch timer data can be read out. Higher and lower nibbles and BCD digit correspondence are as follows:

SWD0–SWD3: BCD (1/100sec) SWD4–SWD7: BCD (1/10sec)

Since SWD0–SWD7 are exclusively for reading, the write operation is invalid.

At initial reset, the timer data is set to "00H".

#### SWRST: 00FF42H•D1

Resets the stopwatch timer.

When "1" is written: Stopwatch timer reset

When "0" is written: No operation Reading: Always "0"

The stopwatch timer is reset by writing "1" to the SWRST. When the stopwatch timer is reset in the RUN status, it restarts immediately after resetting. In the case of the STOP status, the reset data "00H" is maintained.

No operation results when "0" is written to the SWRST.

Since the SWRST is exclusively for writing, it always becomes "0" during reading.

# SWRUN: 00FF42H•D0

Controls RUN/STOP of the stopwatch timer.

When "1" is written: RUN When "0" is written: STOP Reading: Valid

The stopwatch timer starts up-counting by writing "1" to the SWRUN and stops by writing "0". In the STOP status, the timer data is maintained until it is reset or set in the next RUN status. Also, when the STOP status changes to the RUN status, the data that was maintained can be used for resuming the count.

At initial reset, the SWRUN is set at "0" (STOP).

# PSW0, PSW1: 00FF20H•D2, D3

Sets the priority level of the stopwatch timer interrupt.

The two bits PSW0 and PSW1 are the interrupt priority register corresponding to the stopwatch timer interrupt. Table 5.10.4.2 shows the interrupt priority level which can be set by this register.

Table 5.10.4.2 Interrupt priority level settings

| PSW1 | PSW0 | Interrupt priority level |
|------|------|--------------------------|
| 1    | 1    | Level 3 (IRQ3)           |
| 1    | 0    | Level 2 (IRQ2)           |
| 0    | 1    | Level 1 (IRQ1)           |
| 0    | 0    | Level 0 (None)           |

At initial reset, this register is set to "0" (level 0).

# ESW1, ESW10, ESW100: 00FF22H•D4, D5, D6

Enables or disables the generation of an interrupt for the CPU.

When "1" is written: Interrupt enabled When "0" is written: Interrupt disabled

Reading: Valid

The ESW1, ESW10 and ESW100 are interrupt enable registers that respectively correspond to the interrupt factors for 1 Hz, 10 Hz and 100 Hz. Interrupts set to "1" are enabled and interrupts set to "0" are disabled.

At initial reset, this register is set to "0" (interrupt disabled).

# FSW1, FSW10, FSW100: 00FF24H•D4, D5, D6

Indicates the stopwatch timer interrupt generation status.

When "1" is read: Interrupt factor present
When "0" is read: Interrupt factor not present

When "1" is written: Resets factor flag

When "0" is written: Invalid

The FSW1, FSW10 and FSW100 are interrupt factor flags that respectively correspond to the interrupts for 1 Hz, 10 Hz and 100 Hz and are set to "1" in synchronization with the falling edge of each signal. When set in this manner, if the corresponding interrupt enable register is set to "1" and the corresponding interrupt priority register is set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. Regardless of the interrupt enable register and interrupt priority register settings, the interrupt factor flag will be set to "1" by the occurrence of an interrupt generation condition.

To accept the subsequent interrupt after interrupt generation, re-setting of the interrupt flags (set interrupt flag to lower level than the level indicated by the interrupt priority registers, or execute the RETE instruction) and interrupt factor flag reset are necessary. The interrupt factor flag is reset to "0" by writing "1".

At initial reset, this flag is reset to "0".

# 5.10.5 Programming notes

(1) The stopwatch timer is actually made to RUN/STOP in synchronization with the falling edge of the 256 Hz signal after writing to the SWRUN register. Consequently, when "0" is written to the SWRUN, the timer shifts to STOP status when the counter is incremented "1". The SWRUN maintains "1" for reading until the timer actually shifts to STOP status. Figure 5.10.5.1 shows the timing chart of the RUN/STOP control.



Fig. 5.10.5.1 Timing chart of RUN/STOP control

(2) The SLP instruction is executed when the stopwatch timer is in the RUN status (SWRUN = "1"). The stopwatch timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (SWRUN = "0") prior to executing the SLP instruction.

# 5.11 Programmable Timer

# 5.11.1 Configuration of programmable timer

The E0C88365 has two built-in 8-bit programmable timer systems (timer 0 and timer 1).

Timer 0 and timer 1 are composed of 8-bit presettable down counters and they can be used as 8-bit  $\times$  2 channels or 16-bit  $\times$  1 channel programmable timer. They also have an event counter function and a pulse width measurement function using the K10 input port terminal.

Figure 5.11.1.1 shows the configuration of the programmable timer.

Programmable setting of the transfer rate is possible, due to the fact that the programmable timer underflow signal can be used as a synchronous clock for the serial interface.

The underflow divided by 1/2 signal can also be output externally from the R27 output port terminal.

# 5.11.2 Count operation and setting basic mode

Here we will explain the basic operation and setting of the programmable timer.

# ■ Setting of initial value and counting down

The timers 0 and 1 each have a down counter and reload data register.

The reload data registers RLD00–RLD07 (timer 0) and RLD10–RLD17 (timer 1) are registers that set the initial value of the counter.

By writing "1" to the preset control bit PSET0 (timer 0) or PSET1 (timer 1), the down counter loads the initial value set in the reload register RLD. Therefore, down-counting is executed from the stored initial value according to the input clock.



Fig. 5.11.1.1 Configuration of programmable timer



Fig. 5.11.2.1 Basic operation timing of the counter

The registers PRUN0 (timer 0) and PRUN1 (timer 1) are provided to control the RUN/STOP for timers 0 and 1.

After the reload data has been preset into the counter, down-counting is begun by writing "1" to this register. When "0" is written, the clock input is prohibited and the count stops.

The control of this RUN/STOP has no affect on the counter data. The counter data is maintained even during the stoppage of the counter and it can start the count, continuing from that data.

The reading of the counter data can be done through the data buffers PTD00–PTD07 (timer 0) and PTD10–PTD17 (timer 1) with optional timing. When the down-counting has progressed and an underflow is generated, the counter reloads the initial value set in the reload data register. This underflow signal controls an interrupt generation, pulse (TOUT signal) output and serial inter-

face clocking, in addition to reloading the counter.

# ■ Continuous/one-shot mode setting

By writing "1" to the continuous/one-shot mode selection registers CONT0 (timer 0) and CONT1 (timer 1), the programmable timer is set to the continuous mode. In the continuous mode, the initial counter value is automatically loaded when an underflow is generated, and counting is continued. This mode is suitable when programmable intervals are necessary (such as an interrupt and a synchronous clock for the serial interface). On the other hand, when writing "0" to the registers CONT0 (timer 0) and CONT1 (timer 1), the programmable timer is set to the one-shot mode. The counter loads an initial value and stops when an underflow is generated. At this time, the RUN/ STOP control register PRUN0 (timer 0) and PRUN1 (timer 1) are automatically reset to "0". After the counter stops, a one-shot count can be performed once again by writing "1" to registers PRUN0 (timer 0) and PRUN1 (timer 1). This mode is suitable for single time measurement, for example.



When "A6H" is set into reload data register RLD.

Fig. 5.11.2.2 Continuous mode and one-shot mode

# ■ 8/16-bit mode setting

By writing "0" to the 8/16-bit mode selection register MODE16, timer 0 and timer 1 are set as independent timers in 8-bit  $\times$  2 channels. In this mode, timer 0 and timer 1 can be controlled individually and each of them operates independently.

On the other hand, when writing "1" to the register MODE16, timer 0 and timer1 are set as 1 channel 16-bit timer. This is done by setting timer 0 to the lower 8 bits, and timer 1 to the upper 8 bits. The timer is controlled by timer 0's registers. In this case, the control registers for timer 1 are invalid. (PRUN1 is fixed at "0".)



Fig. 5.11.2.3 8/16-bit mode setting and counter configuration

# 5.11.3 Setting of input clock

Prescalers have been provided for timers 0 and 1. The prescalers generate the input clock for each by dividing the source clock signal from the OSC1 or OSC3 oscillation circuit.

The source clock and the dividing ratio of the prescaler can be selected individually for timer 0 and timer 1 in software.

The input clocks are set by the below sequence.

### (1) Selection of source clock

Select the source clock (OSC1 or OSC3) for each prescaler. This is done with the source clock selection registers CKSEL0 (timer 0) and CKSEL1 (timer 1): when "0" is written, OSC1 is selected and when "1" is written, OSC3 is selected. When the 16-bit mode is selected, the source clock is selected by register CKSEL0, and the register CKSEL1 setting becomes invalid. When the OSC3 oscillation circuit is made the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer.

From the time the OSC3 oscillation circuit is turning ON until oscillation stabilizes, an interval of 1 msec is necessary. Consequently, you should allow an adequate waiting time after turning the OSC3 oscillation circuit ON before starting the count of the programmable timer

At initial reset, OSC3 oscillation circuit is set to OFF status.

# (2) Selection of prescaler dividing ratio

Select the dividing ratio of each prescaler from among 4 types. This selection is done by the prescaler dividing ratio selection registers PSC00/PSC01 (timer 0) and PSC10/PSC11 (timer 1). Setting value and dividing ratio correspondence are shown in Table 5.11.3.1.

Table 5.11.3.1 Selection of prescaler dividing ratio

| PSC11<br>PSC01 | PSC10<br>PSC00 | Prescaler dividing ratio |
|----------------|----------------|--------------------------|
| 1              | 1              | Source clock / 64        |
| 1              | 0              | Source clock / 16        |
| 0              | 1              | Source clock / 4         |
| 0              | 0              | Source clock / 1         |

By writing "1" to the register PRUN0 (timer 0) and PRUN1 (timer 1), the source clock is input to the prescaler. Therefore, the clock with selected dividing ratio is input to the timer and the timer starts counting down.

When the 16-bit mode has been selected, the dividing ratio for the source clock is selected by register PSC00/PSC01 and the setting of register PSC10/PSC11 becomes invalid.

# 5.11.4 Timer mode

The timer mode counts down using the prescaler output as an input clock. In this mode, the programmable timer operates as a timer that obtains fixed cycles using the OSC1 or OSC3 oscillation circuit as a clock source.

See "5.11.2 Count operation and basic mode setting" for basic operation and control, and "5.11.3 Setting input clock" for the clock source and setting of the prescaler.

#### 5.11.5 Event counter mode

Timer 0 includes an even counter function that counts by inputting an external clock (EVIN) to input port K10. This function is selected by writing "1" to the timer 0 counter mode selection register EVCNT.

When the event counter mode is selected, timer 0 operates as an event counter and timer 1 operates as a normal timer in 8-bit mode. In the 16-bit mode, timer 0 and timer 1 operate as 1 channel 16-bit event counter. In the event counter mode, since the timer 0 is clocked externally, the settings of registers PSC00/PSC01 become invalid.

Count down timing can be controlled by either the falling edge or rising edge selected by the timer 0 pulse polarity selection register PLPOL. When "0" is written to the register PLPOL, the falling edge is selected, and when "1" is written, the rising edge is selected. The timing is shown in Figure 5.11.5.1.



Fig. 5.11.5.1 Timing chart for event counter mode

The event counter also includes a noise rejecter to eliminate noise such as chattering for the external clock (EVIN). This function is selected by writing "1" to the timer 0 function selection register FCSEL. For a reliable count when "with noise rejecter" is selected, you must allow 0.98 msec/0.84 msec\*1 or more pulse width for both LOW and HIGH levels.

(The noise rejecter allows clocking counter at the second falling edge of the internal 2,048 Hz/2,400 Hz\*2 signal after changing the input level of the K10 input port terminal. Consequently, the pulse width that can reliably be rejected is 0.48 msec/0.41 msec\*3.)

Figure 5.11.5.2 shows the count down timing with the noise rejecter selected.



Fig. 5.11.5.2 Count down timing with noise rejecter

The event counter mode is the same as the timer mode except that the clock is external (EVIN). See "5.11.2 Count operation and setting basic mode" for the basic operation and control.

| fosc1      | *1        | *2       | *3        |
|------------|-----------|----------|-----------|
| 32.768 kHz | 0.98 msec | 2,048 Hz | 0.48 msec |
| 38.4 kHz   |           |          |           |
| 76.8 kHz   | 0.04      | 2 400 11 | 0.41      |
| 96.0 kHz   | 0.84 msec | 2,400 Hz | 0.41 msec |
| 153.6 kHz  |           |          |           |

# 5.11.6 Pulse width measurement timer mode

Timer 0 includes a pulse width measurement function that measures the width of the input signal to the K10 input port terminal. This function is selected by writing "1" to the timer function selection register FCSEL when in the timer mode (EVCNT = "0").



Fig. 5.11.6.1 Timing chart for pulse width measurement timer mode

When the pulse width measurement mode is selected, timer 0 operates as an pulse width measurement and timer 1 operates as a normal timer in 8-bit mode. In the 16-bit mode, timer 0 and timer 1 operate as 1 channel 16-bit pulse width measurement.

The level of the input signal (EVIN) for measurement can be changed either a LOW or HIGH level by the timer 0 pulse polarity selection register PLPOL. When "0" is written to register PLPOL, a LOW level width is measured and when "1" is written, a HIGH level width is measured. The timing is shown in Figure 5.11.6.1.

The pulse width measurement timer mode is the same as the timer mode except that the input clock is controlled by the level of the signal (EVIN) input to the K10 input port terminal.

See "5.11.2 Count operation and setting basic mode" for the basic operation and control.

# 5.11.7 Interrupt function

The programmable timer can generate an interrupt due to an underflow signal of timer 0 and timer 1. Figure 5.11.7.1 shows the configuration of the programmable timer interrupt circuit.

The respectively corresponding interrupt factor flags FPT0 and FPT1 are set to "1" and an interrupt is generated by an underflow signal of timers 1 and 0. Interrupt can also be prohibited by the setting of the interrupt enable registers EPT0 and EPT1 corresponding to each interrupt flag.

In addition, a priority level of the programmable timer interrupt for the CPU can be optionally set at levels 0 to 3 by the interrupt priority registers PPT0 and PPT1.

For details on the above mentioned interrupt control registers and the operation following generation of an interrupt, see "5.16 Interrupt and Standby Status".

The exception processing vector addresses of each interrupt factor are respectively set as shown below.

Programmable timer 1 interrupt: 000006H Programmable timer 0 interrupt: 000008H

When the 16-bit mode is selected, the interrupt factor flag FPT0 is not set to "1" and a timer 0 interrupt cannot be generated. (In the 16-bit mode, the interrupt factor flag FPT1 is set to "1" by an underflow of the 16-bit counter.

# 5.11.8 Setting of TOUT output

The programmable timer can generate a TOUT signal due to an underflow of timer 0 or timer 1. A TOUT signal is the above mentioned underflow divided by 1/2. The timer underflow which is to be used can be selected by the TOUT output channel selection register CHSEL. When writing "0" to register CHSEL, timer 0 is selected and when "1" is written, timer 1 is selected. However, in the 16-bit mode, it is fixed in timer 1 (underflow of the 16-bit timer) and the setting of register CHSEL becomes invalid.

Figure 5.11.8.1 shows the TOUT signal waveform when channel switching.



Fig. 5.11.8.1 TOUT signal waveform at channel change

The TOUT signal can be output from the R27 output port terminal and the programmable clock can be supplied to an external device. The configuration of the output port R27 is shown in Figure 5.11.8.2.



Fig. 5.11.8.2 Configuration of R27



The output control of the TOUT signal is done by register PTOUT. When "1" is set to the PTOUT, the TOUT signal is output from the R27 output port and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set in the data register R27D.

Since the TOUT signal is generated asynchronously from the register PTOUT, when the signal is turned ON or OFF by the register setting, a hazard of a 1/2 cycle or less is generated.

Figure 5.11.8.3 shows the output waveform of TOUT signal.



Fig. 5.11.8.3 Output waveform of the TOUT signal

# 5.11.9 Transmission rate setting of serial interface

The underflow signal of the timer 1 can be used to clock the serial interface.

The transmission rate setting in this case is made in registers PSC1X and PLD1X, and is used to set the count mode to the reload count mode (RLMD1 = "1").

Since the underflow signal of the timer 1 is divided by 1/32 in the serial interface, the value set in register RLD1X which corresponds to the transmission rate is shown in the following expression:

# $RLD1X = fosc / (32*bps*4^{PSC1X}) - 1$

fosc: Oscillation frequency (OSC1)

bps: Transmission rate

PSC1X: Setting value to the register PSC1X (0–3)

(00H can be set to RLD1X)

Table 5.11.9.1 shows an example of the transmission rate setting when the OSC1 oscillation circuit is used as a clock source.

Table 5.11.9.1 Example of transmission rate setting

| Transfer rate | OSC1 oscillation frequency / Programmable timer settings |       |                  |       |                  |       |                  |       |
|---------------|----------------------------------------------------------|-------|------------------|-------|------------------|-------|------------------|-------|
| Transfer rate | fosc1 = 153.6 kHz                                        |       | fosc1 = 96.0 kHz |       | fosc1 = 76.8 kHz |       | fosc1 = 38.4 kHz |       |
| (bps)         | PSC1X                                                    | RLD1X | PSC1X            | RLD1X | PSC1X            | RLD1X | PSC1X            | RLD1X |
| 9,600         | -                                                        | -     | -                | -     | -                | -     | -                | -     |
| 4,800         | 0 (1/1)                                                  | 00H   | _                | _     | -                | _     | _                | _     |
| 2,400         | 0 (1/1)                                                  | 01H   | _                | -     | 0 (1/1)          | 00H   | -                | _     |
| 1,200         | 0 (1/1)                                                  | 03H   | _                | -     | 0 (1/1)          | 01H   | 0 (1/1)          | 00H   |
| 600           | 0 (1/1)                                                  | 07H   | 0 (1/1)          | 04H   | 0 (1/1)          | 03H   | 0 (1/1)          | 01H   |
| 300           | 0 (1/1)                                                  | 0FH   | 0 (1/1)          | 09H   | 0 (1/1)          | 07H   | 0 (1/1)          | 03H   |
| 150           | 0 (1/1)                                                  | 1FH   | 0 (1/1)          | 13H   | 0 (1/1)          | 0FH   | 0 (1/1)          | 07H   |

# 5.11.10 Control of programmable timer

Table 5.11.10.1 shows the programmable timer control bits.

Table 5.11.10.1(a) Programmable timer control bits

| Address | Bit | Name   | Fui                     | nction                   | 1                         | 0                        | SR | R/W | Comment             |
|---------|-----|--------|-------------------------|--------------------------|---------------------------|--------------------------|----|-----|---------------------|
| 00FF30  | D7  | _      | -                       |                          | -                         | _                        | -  | _   | Constantry "0" when |
|         | D6  | _      | -                       |                          | _                         | _                        | -  | _   | being read          |
|         | D5  | _      | _                       |                          | _                         | _                        | -  | _   |                     |
|         | D4  | MODE16 | 8/16-bit mode selection | on                       | 16-bit x 1                | 8-bit x 2                | 0  | R/W |                     |
|         | D3  | CHSEL  | TOUT output channe      | l selection              | Timer 1                   | Timer 0                  | 0  | R/W |                     |
|         | D2  | PTOUT  | TOUT output control     |                          | On                        | Off                      | 0  | R/W |                     |
|         | D1  | CKSEL1 | Prescaler 1 source clo  | ock selection            | fosc3                     | foscı                    | 0  | R/W |                     |
|         | D0  | CKSEL0 | Prescaler 0 source clo  | ock selection            | fosc3                     | foscı                    | 0  | R/W |                     |
| 00FF31  | D7  | EVCNT  | Timer 0 counter mode    | e selection              | Event counter             | Timer                    | 0  | R/W |                     |
|         | D6  | FCSEL  | Timer 0                 | In timer mode            | Pulse width               | Normal                   | 0  | R/W | ] /                 |
|         |     |        | function selection      | !<br>!<br>!              | measurement               | mode                     |    |     | /                   |
|         |     |        |                         | In event counter mode    | With                      | Without                  |    |     | /                   |
|         |     |        |                         | !<br>!<br>!              | noise rejector            | noise rejector           |    |     | /                   |
|         | D5  | PLPOL  | Timer 0                 | Down count timing        | Rising edge               | Falling edge             | 0  | R/W | ] / /               |
|         |     |        | pulse polarity          | in event counter mode    | of K10 input              |                          |    |     |                     |
|         |     |        | selection               | In pulse width           | High level<br>measurement | Low level<br>measurement |    |     |                     |
|         |     |        |                         | measurement mode         |                           | for K10 input            |    |     |                     |
|         | D4  | PSC01  | Timer 0 prescaler div   | iding ratio selection    | -                         | -                        | 0  | R/W |                     |
|         |     |        | PSC01 PSC00             | Prescaler dividing ratio |                           |                          |    |     |                     |
|         |     |        | 1 1                     | Source clock / 64        |                           |                          |    |     |                     |
|         | D3  | PSC00  | 1 0                     | Source clock / 16        | _                         | _                        | 0  | R/W |                     |
|         |     |        | 0 1                     | Source clock / 4         |                           |                          |    |     |                     |
|         |     |        | 0 0                     | Source clock / 1         |                           |                          |    |     | /                   |
|         | D2  | CONT0  | Timer 0 continuous/o    | ne-shot mode selection   | Continuous                | One-shot                 | 0  | R/W | V                   |
|         | D1  | PSET0  | Timer 0 preset          |                          | Preset                    | No operation             | -  | W   | "0" when being read |
|         | D0  | PRUN0  | Timer 0 Run/Stop con    | ntrol                    | Run                       | Stop                     | 0  | R/W |                     |
| 00FF32  | D7  | _      | _                       |                          | _                         | _                        | -  | _   | G                   |
|         | D6  | _      | _                       |                          | _                         | _                        | -  | _   | Constantry "0" when |
|         | D5  | _      | _                       |                          | -                         | -                        | _  | _   | being read          |
|         | D4  | PSC11  | Timer 1 prescaler div   | iding ratio selection    | _                         | _                        | 0  | R/W |                     |
|         |     |        | PSC11 PSC10             | Prescaler dividing ratio |                           |                          |    |     |                     |
|         |     |        | 1 1                     | Source clock / 64        |                           |                          |    | L   |                     |
|         | D3  | PSC10  | 1 0                     | Source clock / 16        | -                         | _                        | 0  | R/W |                     |
|         |     |        | 0 1                     | Source clock / 4         |                           |                          |    |     |                     |
|         |     |        | 0 0                     | Source clock / 1         |                           |                          |    |     |                     |
|         | D2  | CONT1  | Timer 1 continuous/o    | ne-shot mode selection   | Continuous                | One-shot                 | 0  | R/W | <u>/</u>            |
|         | D1  | PSET1  | Timer 1 preset          |                          | Preset                    | No operation             | _  | W   | "0" when being read |
|         | D0  | PRUN1  | Timer 1 Run/Stop con    | ntrol                    | Run                       | Stop                     | 0  | R/W |                     |

Table 5.11.10.1(b) Programmable timer control bits

| Address | Bit | Name  | Function                      | 1      | 0   | SR | R/W   | Comment |
|---------|-----|-------|-------------------------------|--------|-----|----|-------|---------|
| 00FF33  | D7  | RLD07 | Timer 0 reload data D7 (MSB)  |        |     |    |       |         |
|         | D6  | RLD06 | Timer 0 reload data D6        |        |     |    |       | /       |
|         | D5  | RLD05 | Timer 0 reload data D5        |        |     |    |       |         |
|         | D4  | RLD04 | Timer 0 reload data D4        | High   | Low | 1  | R/W   |         |
|         | D3  | RLD03 | Timer 0 reload data D3        | nigii  | Low | 1  | IN/ W |         |
|         | D2  | RLD02 | Timer 0 reload data D2        |        |     |    |       |         |
|         | D1  | RLD01 | Timer 0 reload data D1        |        |     |    |       |         |
|         | D0  | RLD00 | Timer 0 reload data D0 (LSB)  |        |     |    |       |         |
| 00FF34  | D7  | RLD17 | Timer 1 reload data D7 (MSB)  |        |     |    |       | /       |
|         | D6  | RLD16 | Timer 1 reload data D6        |        |     |    |       |         |
|         | D5  | RLD15 | Timer 1 reload data D5        |        |     |    |       |         |
|         | D4  | RLD14 | Timer 1 reload data D4        | High   | Low | 1  | R/W   |         |
|         | D3  | RLD13 | Timer 1 reload data D3        | підіі  | Low | 1  | IN/ W |         |
|         | D2  | RLD12 | Timer 1 reload data D2        |        |     |    |       |         |
|         | D1  | RLD11 | Timer 1 reload data D1        |        |     |    |       |         |
|         | D0  | RLD10 | Timer 1 reload data D0 (LSB)  |        |     |    |       |         |
| 00FF35  | D7  | PTD07 | Timer 0 counter data D7 (MSB) |        |     |    |       | /       |
|         | D6  | PTD06 | Timer 0 counter data D6       |        |     |    |       |         |
|         | D5  | PTD05 | Timer 0 counter data D5       |        |     |    |       |         |
|         | D4  | PTD04 | Timer 0 counter data D4       | High   | Low | 1  | R     |         |
|         | D3  | PTD03 | Timer 0 counter data D3       | riigii | Low | 1  | K     |         |
|         |     | PTD02 | Timer 0 counter data D2       |        |     |    |       |         |
|         | D1  | PTD01 | Timer 0 counter data D1       |        |     |    |       |         |
|         |     | PTD00 | Timer 0 counter data D0 (LSB) |        |     |    |       | /       |
| 00FF36  |     | PTD17 | Timer 1 counter data D7 (MSB) |        |     |    |       | /       |
|         | D6  | PTD16 | Timer 1 counter data D6       |        |     |    |       | /       |
|         | D5  | PTD15 | Timer 1 counter data D5       |        |     |    |       |         |
|         | D4  | PTD14 | Timer 1 counter data D4       | High   | Low | 1  | R     | /       |
|         | D3  | PTD13 | Timer 1 counter data D3       | nigii  | Low | 1  | "     |         |
|         | D2  | PTD12 | Timer 1 counter data D2       |        |     |    |       |         |
|         | D1  | PTD11 | Timer 1 counter data D1       |        |     |    |       |         |
|         | D0  | PTD10 | Timer 1 counter data D0 (LSB) |        |     |    |       | /       |

Address Bit Name Function SR R/W Comment 1 00FF21 D7 D6 Constantly "0" when \_ \_ D5 being read D4 \_ PPT1 PPT0 D3 PPT1 Priority R/W Programmable timer interrupt priority register 0 PK11 PK10 level D2 PPT0 Level 3 1 0 D1 PK11 1 Level 2 K10 and K11 interrupt priority register 0 Level 1 0 R/W D0 PK10 0 Level 0 00FF23 D7 EPT1 Programmable timer 1 interrupt enable register D6 EPT0 Programmable timer 0 interrupt enable register D5 EK1 K10 and K11 interrupt enable register D4 EK0H K04-K07 interrupt enable register Interrupt Interrupt 0 R/W D3 EK0L K00-K03 interrupt enable register enable disable D2 ESERR Serial I/F (error) interrupt enable register D1 ESREC Serial I/F (receiving) interrupt enable register D0 ESTRA Serial I/F (transmitting) interrupt enable register 00FF25 D7 FPT1 Programmable timer 1 interrupt factor flag (R) (R) D6 FPT0 Programmable timer 0 interrupt factor flag Interrupt No interrupt D5 FK1 K10 and K11 interrupt factor flag factor is factor is D4 FK0H K04–K07 interrupt factor flag generated generated 0 R/W D3 FK0L K00-K03 interrupt factor flag D2 FSERR | Serial I/F (error) interrupt factor flag (W) (W) D1 FSREC Serial I/F (receiving) interrupt factor flag Reset No operation Serial I/F (transmitting) interrupt factor flag D0 FSTRA

Table 5.11.10.1(c) Programmable timer control bits

### MODE16: 00FF30H•D4

Selects the 8/16-bit mode.

When "1" is written:  $16 \text{ bits} \times 1 \text{ channel}$ When "0" is written:  $8 \text{ bits} \times 2 \text{ channels}$ 

Reading: Valid

Select whether timer 0 and timer 1 will be used as 2 channel independent 8-bit timers or as a 1 channel combined 16-bit timer. When "0" is written to MODE16, 8-bit  $\times$  2 channels is selected and when "1" is written, 16-bit  $\times$  1 channel is selected. At initial reset, MODE16 is set to "0" (8-bit  $\times$  2 channels).

# CKSEL0, CKSEL1: 00FF30H•D0, D1

Select the source clock of the prescaler.

When "1" is written: OSC3 clock When "0" is written: OSC1 clock Reading: Valid

Select whether the source clock of prescaler 0 will be set to OSC1 or OSC3. When "0" is written to CKSEL0, OSC1 is selected and when "1" is written, OSC3 is selected.

In the same way, the source clock of prescaler 1 is selected by CKSEL1.

When event counter mode has been selected, the setting of the CKSEL0 becomes invalid. In the same way, the CKSEL1 setting becomes invalid when 16-bit mode has been selected.

At initial reset, this register is set to "0" (OSC1 clock).

# PSC00, PSC01: 00FF31H•D3, D4 PSC10, PSC11: 00FF32H•D3, D4

Select the dividing ratio of the prescaler. Two-bit PSC00 and PSC01 is the prescaler dividing ratio selection registers for timer 0, and the two-bit PSC10 and PSC11 correspond to timer 1. The prescaler dividing ratios that can be set by these registers are shown in Table 5.11.10.2.

*Table 5.11.10.2 Selection of prescaler dividing ratio* 

| PSC11 | PSC10 | Prescaler dividing ratio |  |
|-------|-------|--------------------------|--|
| PSC01 | PSC00 |                          |  |
| 1     | 1     | Input clock / 64         |  |
| 1     | 0     | Input clock / 16         |  |
| 0     | 1     | Input clock / 4          |  |
| 0     | 0     | Input clock / 1          |  |

When event counter mode has been selected, the setting of the PSC00 and PSC01 becomes invalid. In the same way, the PSC10 and PSC11 setting becomes invalid when 16-bit mode has been selected. At initial reset, this register is set to "0" (input clock/1).

# EVCNT: 00FF31H•D7

Selects the counter mode for the timer 0.

When "1" is written: Event counter mode
When "0" is written: Timer mode
Reading: Valid

Select whether timer 0 will be used as an event counter or a timer. When "1" is written to EVCNT, the event counter mode is selected and when "0" is written, the timer mode is selected.

At initial reset, EVCNT is set to "0" (timer mode).

#### FCSEL: 00FF31H•D6

Selects the function for each counter mode of timer 0.

# • In timer mode

When "1" is written: Pulse width measurement

timer mode

When "0" is written: Normal mode

Reading: Valid

In the timer mode, select whether timer 0 will be used as a pulse width measurement timer or a normal timer. When "1" is written to FCSEL, the pulse width measurement mode is selected and the counting is done according to the level of the signal (EVIN) input to the K10 input port terminal. When "0" is written to FCSEL, the normal mode is selected and the counting is not affected by the K10 input port terminal.

#### • In event counter mode

When "1" is written: With noise rejecter When "0" is written: Without noise rejecter

Reading: Valid

In the event counter mode, select whether the noise rejecter for the K10 input port terminal will be selected or not.

When "1" is written to FCSEL, the noise rejecter is selected and counting is done by an external clock (EVIN) with 0.98 msec/0.84 msec\*1 or more pulse width. (The noise rejecter allows clocking counter at the second falling edge of the internal 2,048 Hz/2,400 Hz\*2 signal after changing the input level of the K10 input port terminal. Consequently, the pulse width that can reliably be rejected is 0.48 msec/0.41 msec\*3.)

When "0" is written to FCSEL, the noise rejector is not selected and the counting is done directly by an external clock (EVIN) input to the K10 input port terminal.

At initial reset, FCSEL is set to "0".

| fosc1      | *1        | *2        | *3        |
|------------|-----------|-----------|-----------|
| 32.768 kHz | 0.98 msec | 2,048 Hz  | 0.48 msec |
| 38.4 kHz   |           |           |           |
| 76.8 kHz   | 0.84 msec | 2 400 11- | 0.41      |
| 96.0 kHz   | 0.84 msec | 2,400 Hz  | 0.41 msec |
| 153.6 kHz  |           |           |           |

### PLPOL: 00FF31H•D5

Selects the pulse polarity for the K10 input port terminal.

#### • In event counter mode

When "1" is written: Rising edge When "0" is written: Falling edge Reading: Valid

In the event counter mode, select whether the count timing will be set at the falling edge of the external clock (EVIN) input to the K10 input port terminal or at the rising edge. When "0" is written to PLPOL, the falling edge is selected and when "1" is written, the rising edge is selected.

### • In pulse width measurement mode

When "1" is written: High level pulse width

measurement

When "0" is written: LOW level pulse width

measurement

Reading: Valid

In the pulse width measurement mode, select whether the LOW level width of the signal (EVIN) input to the K10 input port terminal will be measured or the HIGH level will be measured. When "0" is written to PLPOL, the LOW level width measurement is selected and when "1" is written, the HIGH level width measurement is selected.

In the normal mode (EVCNT = FCSEL = "0"), the setting of PLPOL becomes invalid.

At initial reset, PLPOL is set to "0".

### CONTO, CONT1: 00FF31H•D2, 00FF32H•D2

Select the continuous / one-shot mode.

When "1" is written: Continuous mode When "0" is written: One-shot mode

Reading: Valid

Select whether timer 0 will be used in the continuous mode or in the one-shot mode.

By writing "1" to CONTO, the programmable timer is set to the continuous mode. In the continuous mode, the initial counter value is automatically loaded when an underflow is generated, and counting is continued. On the other hand, when writing "0" to CONTO, the programmable timer is set to the one-shot mode. The counter loads an initial value and stops when an underflow is generated. At this time, PRUNO is automatically reset to "0".

In the same way, the continuous/one-shot mode for timer 1 is selected by CONT1. (In the one-shot mode for timer 1, PRUN1 is automatically reset to "0" when the counter underflow is generated.) At initial reset, this register is set to "0" (one-shot mode).

# RLD00-RLD07: 00FF33H RLD10-RLD17: 00FF34H

Sets the initial value for the counter.

RLD00-RLD07: Reload data for Timer 0 RLD10-RLD17: Reload data for Timer 1

The reload data set in this register is loaded into the respective counters and is counted down with that as the initial value.

Reload data is loaded to the counter under two conditions, when "1" is written to PSET0 or PSET1 and when the counter underflow automatically loads.

At initial reset, this register is set to "FFH".

# PTD00-PTD07: 00FF35H PTD10-PTD17: 00FF36H

Data of the programmable timer can be read out.

PTD00–PTD07: Timer 0 counter data PTD10–PTD17: Timer 1 counter data

These bits act as a buffer to maintain the counter data during readout, and the data can be read as optional timing. However, in the 16-bit mode, to avoid a read error, (data error when a borrow from timer 0 to timer 1 is generated in the middle of reading PTD00–PTD07 and PTD10–PTD17), PTD10–PTD17 latches the timer 1 counter data according to the reading of PTD00–PTD07.

The latched status of PTD10–PTD17 is canceled according to the readout of PTD10–PTD17 or when 0.73/0.62\*1–1.22/1.04\*2 msec (depends on the readout timing) has elapsed. Therefore, in 16-bit mode, be sure to read the counter data of PTD00–PTD07 and PTD10–PTD17 in order.

Since these bits are exclusively for reading, the write operation is invalid.

At initial reset, these bits are set to "FFH".

| fosc1      | *1        | *2        |  |
|------------|-----------|-----------|--|
| 32.768 kHz | 0.73 msec | 1.22 msec |  |
| 38.4 kHz   |           |           |  |
| 76.8 kHz   | 0.62 msec | 1.04 msec |  |
| 96.0 kHz   |           |           |  |
| 153.6 kHz  |           |           |  |

# PSET0, PSET1: 00FF31H•D1, 00FF32H•D1

Presets the reload data to the counter.

When "1" is written: Preset
When "0" is written: No operation
Reading: Always "0"

By writing "1" to PSET0, the reload data in PLD00–PLD07 is preset to the counter of timer 0. When the counter of timer 0 is preset in the RUN status, it restarts immediately after presetting.

In the case of STOP status, the reload data that has been preset is maintained.

No operation results when "0" is written. In the same way, the reload data in PLD10–PLD17 is preset to the counter of timer 1 by PSET1. When the 16-bit mode is selected, writing "1" to PSET1 is invalid.

This bit is exclusively for writing, it always becomes "0" during reading.

# PRUNO, PRUN1: 00FF31H•D0, 00FF32H•D0

Controls the RUN/STOP of the counter.

When "1" is written: RUN When "0" is written: STOP Reading: Valid

The counter of timer 0 starts down-counting by writing "1" to PRUN0 and stops by writing "0". In the STOP status, the counter data is maintained until it is preset or set in the next RUN status. Also, when the STOP status changes to the RUN status, the data that was maintained can be used for resuming the count.

In the same way, the RUN/STOP of the timer 1 counter is controlled by PRUN1.

When the 16-bit mode is selected, PRUN1 is fixed at "0".

At initial reset and when an underflow is generated in the one-shot mode, this register is set to "0" (STOP).

#### CHSEL: 00FF30H•D3

Selects the channel of the TOUT signal.

When "1" is written: Timer 0 underflow When "0" is written: Timer 1 underflow

Reading: Valid

Select whether the timer 0 underflow will be used for the TOUT signal or the timer 1 underflow will be used. When "0" is written to CHSEL, timer 0 is selected and when "1" is written, timer 1 is selected. When the 16-bit mode has been selected, it is fixed to timer 1 (underflow of the 16-bit timer), and setting of CHSEL becomes invalid.

At initial reset CHSEL is set to "0" (timer 1

At initial reset, CHSEL is set to "0" (timer 1 underflow).

# PTOUT: 00FF30H•D2

Controls the TOUT signal output.

When "1" is written: TOUT signal output When "0" is written: HIGH level (DC) output

Reading: Valid

PTOUT is the output control register for TOUT signal. When "1" is set, the TOUT signal is output from the output port terminal R27 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R27D. At initial reset, PTOUT is set to "0" (HIGH level output).

### PPT0, PPT1: 00FF21H•D2, D3

Sets the priority level of the programmable timer interrupt.

The two bits PPT0 and PPT1 are the interrupt priority register corresponding to the programmable timer interrupt. Table 5.11.10.3 shows the interrupt priority level which can be set by this register.

Table 5.11.10.3 Interrupt priority level settings

| PPT1 | PPT0 | Interrupt priority level |
|------|------|--------------------------|
| 1    | 1    | Level 3 (IRQ3)           |
| 1    | 0    | Level 2 (IRQ2)           |
| 0    | 1    | Level 1 (IRQ1)           |
| 0    | 0    | Level 0 (None)           |

At initial reset, this register is set to "0" (level 0).

#### EPT0, EPT1: 00FF23H•D6, D7

Enables or disables the generation of an interrupt for the CPU.

When "1" is written: Interrupt enabled When "0" is written: Interrupt disabled

Reading: Valid

The EPT0 and EPT1 are interrupt enable registers that respectively correspond to the interrupt factors for timer 0 and timer 1. Interrupts set to "1" are enabled and interrupts set to "0" are disabled. When the 16-bit mode is selected, setting of EPT0 becomes invalid.

At initial reset, this register is set to "0" (interrupt disabled).

# FPT0, FPT1: 00FF25H•D6, D7

Indicates the programmable timer interrupt generation status.

When "1" is read: Interrupt factor present When "0" is read: Interrupt factor not present

When "1" is written: Resets factor flag

When "0" is written: Invalid

The FPT0 and FPT1 are interrupt factor flags that respectively correspond to the interrupts for timer 0 and timer 1 and are set to "1" in synchronization with the underflow of each counter.

When set in this manner, if the corresponding interrupt enable register is set to "1" and the corresponding interrupt priority register is set to a higher level than the setting of interrupt flags (I0 and I1), an interrupt will be generated to the CPU. Regardless of the interrupt enable register and interrupt priority register settings, the interrupt factor flag will be set to "1" by the occurrence of an interrupt generation condition.

To accept the subsequent interrupt after interrupt generation, re-setting of the interrupt flags (set interrupt flag to lower level than the level indicated by the interrupt priority registers, or execute the RETE instruction) and interrupt factor flag reset are necessary. The interrupt factor flag is reset to "0" by writing "1".

When the 16-bit mode is selected, the interrupt factor flag FPT0 is not set to "1" and a timer 0 interrupt cannot be generated. (In the 16-bit mode, the interrupt factor flag FPT1 is set to "1" by an underflow of the 16-bit counter.)

At initial reset, this flag is reset to "0".

# 5.11.11 Programming notes

(1) The programmable timer is actually made to RUN/STOP in synchronization with the falling edge of the input clock after writing to the PRUN0(1) register. Consequently, when "0" is written to the PRUN0(1), the timer shifts to STOP status when the counter is decremented "1". The PRUN0(1) maintains "1" for reading until the timer actually shifts to STOP status. Figure 5.11.11.1 shows the timing chart of the RUN/STOP control.



Fig. 5.11.11.1 Timing chart of RUN/STOP control

The event counter mode is excluded from the above note.

(2) The SLP instruction is executed when the programmable timer is in the RUN status (PRUN0(1) = "1"). The programmable timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (PRUN0(1) = "0") prior to executing the SLP instruction.

In the same way, disable the TOUT signal (PTOUT = "0") to avoid an unstable clock output to the R27 output port terminal.

- (3) Since the TOUT signal is generated asynchronously from the register PTOUT, when the signal is turned ON or OFF by the register setting, a hazard of a 1/2 cycle or less is generated.
- (4) When the OSC3 oscillation circuit is made the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer.

From the time the OSC3 oscillation circuit is turning ON until oscillation stabilizes, an interval of 1 msec is necessary. Consequently, you should allow an adequate waiting time after turning the OSC3 oscillation circuit ON before starting the count of the programmable timer

At initial reset, OSC3 oscillation circuit is set to OFF status.

(5) When the 16-bit mode has been selected, be sure to read the counter data in the order of PTD00– PTD07 and PTD10–PTD17. Moreover, the time interval between reading PTD00–PTD07 and PTD10–PTD17 should be 0.73 msec/0.62 msec\*1 or less.

| fosc1      | *1        |
|------------|-----------|
| 32.768 kHz | 0.73 msec |
| 38.4 kHz   |           |
| 76.8 kHz   | 0.62      |
| 96.0 kHz   | 0.62 msec |
| 153.6 kHz  |           |

# 5.12 LCD Controller

# 5.12.1 Configuration of LCD controller

The E0C88365 has a built-in dot matrix LCD driver. The E0C88365 allows an LCD panel with a maximum of 1,440 dots (80 segments × 18 commons). Figure 5.12.1.1 shows the configuration of the LCD controller and the drive power supply.

Note: A load resistance between

# 5.12.2 LCD power supply

The LCD system drive voltages VC1–VC5 are generated by the power supply circuit (voltage regurater and voltage booster).

The internal power supply is designed for a small scale LCD panel and is not suitable for driving a panel that has large size pixels using an external expanded LCD driver.



terminals Vss–Vc1 is needed when driving an LCD panel that constitutes a heavy load. Do not supply any voltage to the Vc1 to Vc5 terminals and CA to CE terminals from outside.

Fig. 5.12.1.1 Configuration of LCD controller and drive power supply

# 5.12.3 LCD driver

The drive bias is 1/5 (five potentials, VC1–VC5) for the 1/18 duty. The waveform is showns in Figure 5.12.3.1.



| fosc1      | *1       |
|------------|----------|
| 32.768 kHz | 28.4 Hz  |
| 38.4 kHz   |          |
| 76.8 kHz   | 22 2 11- |
| 96.0 kHz   | 33.3 Hz  |
| 153.6 kHz  |          |

Fig. 5.12.3.1 Drive waveform for 1/18 duty

COM0-SEG1

VC4VC3VC2VC1VSS (GND)

— -VC1 — -VC2 — -VC3 — -VC4 — -VC5

## 5.12.4 Display memory

The E0C88365 has a built-in 576-byte display memory. The display memory is allocated to address Fx00H-Fx5FH (x = 8-DH).

Two-screen memory can be secured, and the two screens can be switched by the display memory area selection register DSPAR. When "0" is written to DSPAR, display area 0 is selected and when "1" is written, display area 1 is selected.

When "1" is written to the display memory bit corresponding to the dot on the LCD panel, the dot goes ON and when "0" is written, it goes OFF.

Since display memory is designed to permit reading/writing, it can be controlled in bit units by logical operation instructions (read, modify and write instructions).

The display area bits which have not been assigned within the 576-byte display memory can be used as general purpose RAM with read/write capabilities. Even when external memory has expanded into the display memory area, this area is not released to external memory. Access to this area is always via display memory.

| Address/Data bit 0 1 2 3 4 5 6 7 8 9 A B C D E F 0 1 2 3 4 5 6 7 8 9 A B                                                            | 1 4 5 5 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 5 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 1 8 1 7 8 9 | 5<br>0 1 1 2 3 4 5 6 7 8 9 A B C D E F COM   |
|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
|                                                                                                                                     | Display area 0 (when "0" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 2 2 1                                      |
| 00F900H D2 D3                                                                                   | Display area 0 (when "0" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8 9 9 10 10 11 11 11 11 11 11 11 11 11 11 11 |
|                                                                                                                                     | Display area 1 (when "1" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0      |
|                                                                                                                                     | Display area 1 (when "1" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8 9 9 9 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1      |
|                                                                                                                                     | Display area 1 (when "0" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 16                                           |
| 00FC00H                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |
|                                                                                                                                     | Display area 1 (when "1" is set into DSPAR)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 16                                           |
| 00FD00H                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                              |
| SEG 0   1   2   3   4   5   6   7   8   9   10   11   12   13   14   15   16   17   18   19   20   21   22   23   24   25   26   27 | SEG 0 1 1 2 3 4 5 6 7 8 9 10111121314151617181920271222222222222222222222222222222222                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                              |

Fig. 5.12.4.1 1/18 duty and  $5 \times 8$  dots display memory map

## 5.12.5 Display control

The display status of the built-in LCD driver and the contrast adjustment can be controlled with the built-in LCD controller. The LCD display status can be selected by display control registers LCDC0 and LCDC1. Setting the value and display status are shown in Table 5.12.5.1.

Table 5.12.5.1 LCD display control

|       |       | 1 2                    |
|-------|-------|------------------------|
| LCDC1 | LCDC0 | LCD display            |
| 1     | 1     | All LCDs lit (Static)  |
| 1     | 0     | All LCDs out (Dynamic) |
| 0     | 1     | Normal display         |
| 0     | 0     | Drive OFF              |

All the dots in the LCD display can be turned on or off directly by the drive waveform output from the LCD driver, and data in the display memory is not changed. Also, since the common terminal at this time is set to static drive when all the dots are on and is set to dynamic drive when they are off, this function can be used as follows:

- (1) Since all dots on is binary output (VC5 and Vss) with static drive, the common/segment terminal can be used as a monitor terminal for the OSC1 oscillation frequency adjustment.
- (2) Since all dots off is dynamic drive, you can brink the entire LCD display without changing display memory data.

Selecting LCD drive OFF turns the LCD drive power circuit OFF and all the VC1–VC5 terminals go to Vss level.

Furthermore, when the SLP instruction is executed, registers LCDC0 and LCDC1 are automatically reset to "0" (set to drive off) by hardware.

The LCD contrast can be adjusted in 16 stages. This adjustment is done by the contrast adjustment register LC0–LC3, and the setting values correspond to the contrast as shown in Table 5.12.5.2.

Table 5.12.5.2 LCD contrast adjustment

| L | .C3 | LC2 | LC1 | LC0 | Contrast     |
|---|-----|-----|-----|-----|--------------|
|   | 1   | 1   | 1   | 1   | Dark         |
|   | 1   | 1   | 1   | 0   | <b>↑</b>     |
|   | 1   | 1   | 0   | 1   |              |
|   | :   | :   | :   | :   |              |
|   | 0   | 0   | 1   | 0   |              |
|   | 0   | 0   | 0   | 1   | $\downarrow$ |
|   | 0   | 0   | 0   | 0   | Light        |

#### 5.12.6 CL and FR outputs

In order for the E0C88365 to handle connection to an externally expanded LCD driver, output ports R25 and R26 can be used to output a CL signal (LCD synchronous signal) and FR signal (LCD frame signal), respectively.

The configuration of output ports R25 and R26 are shown in Figure 5.12.6.1.



Fig. 5.12.6.1 Configuration of R25 and R26

The output control for the CL signal is done by the register LCCLK. When you set "1" for the LCCLK, the CL signal is output from the output port terminal R25, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R25D.

The output control for the FR signal is done by the register LCFRM. When you set "1" for the LCFRM, the FR signal is output from the output port terminal R26, when "0" is set, the HIGH (VDD) level is output. At this time, "1" must always be set for the data register R26D.

The frequencies of each signal are changed as shown in Table 5.12.6.1 according to the fosc1 frequency selection.

Table 5.12.6.1 Frequencies of CL and FR signals

| fosc1      | CL signal (Hz) | FR signal (Hz) |
|------------|----------------|----------------|
| 32.768 kHz | 1,024          | 28.4           |
| 38.4 kHz   |                |                |
| 76.8 kHz   | 1 200          | 22.2           |
| 96.0 kHz   | 1,200          | 33.3           |
| 153.6 kHz  |                |                |

Since the signals are generated asynchronously from the registers LCCLK and LCFRM, when the signals are turned ON or OFF by the register settings, a hazard of a 1/2 cycle or less is generated. Figure 5.12.6.2 shows the output waveforms of the CL and FR signals.



Fig. 5.12.6.2 Output waveforms of CL and FR signals (1/18 duty)

## 5.12.7 Control of LCD controller

Table 5.12.7.1 shows the LCD controller control bits.

Table 5.12.7.1 LCD controller control bits

| Address | Bit | Name  | Function                                  | 1              | 0              | SR | R/W | Comment              |
|---------|-----|-------|-------------------------------------------|----------------|----------------|----|-----|----------------------|
| 00FF10  | D7  | _     | _                                         | -              | -              | _  | _   | C                    |
|         | D6  | _     | _                                         | -              | -              | _  | _   | Constantry "0" when  |
|         | D5  | _     | _                                         | -              | -              | _  | _   | being read           |
|         | D4  | LCCLK | CL output control for expanded LCD driver | On             | Off            | 0  | R/W |                      |
|         | D3  | LCFRM | FR output control for expanded LCD driver | On             | Off            | 0  | R/W |                      |
|         | D2  | DTFNT | R/W register                              | -              | _              | 0  | R/W |                      |
|         | D1  | LDUTY | R/W register                              | -              | _              | 0  | R/W |                      |
|         | D0  | SGOUT | R/W register                              | -              | _              | 0  | R/W |                      |
| 00FF11  | D7  | _     | _                                         | _              | -              | _  | _   | "0" when being read  |
|         | D6  | DSPAR | LCD display memory area selection         | Display area 1 | Display area 0 | 0  | R/W |                      |
|         | D5  | LCDC1 | LCD display control                       | _              | _              | 0  | R/W |                      |
|         |     |       | LCDC1 LCDC0 LCD display                   |                |                |    |     | These bits are reset |
|         |     |       | 1 1 All LCDs lit                          |                |                |    |     | to (0, 0) when       |
|         | D4  | LCDC0 | 1 0 All LCDs out                          | _              | -              | 0  | R/W | SLP instruction      |
|         |     |       | 0 1 Normal display                        |                |                |    |     | is executed.         |
|         |     |       | 0 0 Drive off                             |                |                |    |     |                      |
|         | D3  | LC3   | LCD contrast adjustment                   | _              | _              | 0  | R/W |                      |
|         | D2  | LC2   | LC3 LC2 LC1 LC0 Contrast Dark             |                | _              | 0  | R/W |                      |
|         | D1  | LC1   |                                           | _              | _              | 0  | R/W |                      |
|         | D0  | LC0   | 0 0 0 0 Light                             | _              | _              | 0  | R/W |                      |

#### DSPAR: 00FF11H•D6

Selects the display area.

When "1" is written: Display area 1 When "0" is written: Display area 0

Reading: Valid

Selects display area from two screens secured in the display memory.

When "0" is written to DSPAR, display area 0 is selected and when "1" is written, display area 1 is selected.

The correspondence between the display memory bits set according to the display area, and the common/segment terminals are shown in Figure 5.12.4.1.

At initial reset, DSPAR is set to "0" (display area 0).

#### LCDC0, LCDC1: 00FF11H•D4, D5

Controls the LCD display.

Table 5.12.7.2 LCD display control

| LCDC1 | LCDC0 | LCD display            |
|-------|-------|------------------------|
| 1     | 1     | All LCDs lit (Static)  |
| 1     | 0     | All LCDs out (Dynamic) |
| 0     | 1     | Normal display         |
| 0     | 0     | Drive OFF              |

The four settings mentioned above can be made without changing the display memory data. At initial reset and in the SLEEP status, this register is set to "0" (drive off).

#### LC0-LC3: 00FF11H•D0-D3

Adjusts the LCD contrast.

Table 5.12.7.3 LCD contract adjustment

| LC3 | LC2 | LC1 | LC0 | Contrast     |
|-----|-----|-----|-----|--------------|
| 1   | 1   | 1   | 1   | Dark         |
| 1   | 1   | 1   | 0   | <b>↑</b>     |
| 1   | 1   | 0   | 1   |              |
| 1   | 1   | 0   | 0   |              |
| 1   | 0   | 1   | 1   |              |
| 1   | 0   | 1   | 0   |              |
| 1   | 0   | 0   | 1   |              |
| 1   | 0   | 0   | 0   |              |
| 0   | 1   | 1   | 1   |              |
| 0   | 1   | 1   | 0   |              |
| 0   | 1   | 0   | 1   |              |
| 0   | 1   | 0   | 0   |              |
| 0   | 0   | 1   | 1   |              |
| 0   | 0   | 1   | 0   |              |
| 0   | 0   | 0   | 1   | $\downarrow$ |
| 0   | 0   | 0   | 0   | Light        |

The contrast can be adjusted in 16 stages as mentioned above. This adjustment changes the drive voltage on terminals VC1-VC5.

At initial reset, this register is set to "0".

#### LCCLK: 00FF10H•D4

Controls the CL signal output.

When "1" is written: CL signal output When "0" is written: HIGH level (DC) output

Reading: Valid

LCCLK is the output control register for CL signal. When "1" is set, the CL signal is output from the output port terminal R25 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R25D.

At initial reset, LCCLK is set to "0" (HIGH level output).

#### LCFRM: 00FF10H•D3

Controls the FR signal output.

When "1" is written: FR signal output When "0" is written: HIGH level (DC) output

Reading: Valid

LCFRM is the output control register for FR signal. When "1" is set, the FR signal is output from the output port terminal R26 and when "0" is set, HIGH (VDD) level is output. At this time, "1" must always be set for the data register R26D.

At initial reset, LCFRM is set to "0" (HIGH level output).

#### 5.12.8 Programming notes

- (1) Since the CL and FR signals are generated asynchronously from the output control registers LCCLK and LCFRM, when the signals is turned ON or OFF by setting of the registers LCCLK and LCFRM, a hazard of a 1/2 cycle or less is generated.
- (2) When the SLP instruction is executed, display control registers LCDC0 and LCDC1 are automatically reset to "0" by hardware. Furthermore, in the SLEEP status, HIGH (VDD) level is output for the CL and FR signals. (When registers R25D and R26D are set to "1".)

## 5.13 Sound Generator

## 5.13.1 Configuration of sound generator

The E0C88365 has a built-in sound generator for generating BZ (buzzer) signal.

BZ signals generated from the sound generator can be output from the R50 output port terminal. Aside permitting the respective setting of the buzzer signal frequency and sound level (duty adjustment) to 8 stages, it permits the adding of a digital envelope by means of duty ratio control. It also has a one-shot output function for outputting key operated sounds.

Figure 5.13.1.1 shows the configuration of the sound generator.



Fig. 5.13.1.1 Configuration of sound generator



5.13.2 Control of buzzer output

terminal.

in Figure 5.13.2.1.

BZ signal can be output from the R50 output port

The configuration of the output port R50 is shown

The output control for the BZ signal generated by

the sound generator is done by the buzzer output

control register BZON, one-shot buzzer trigger bit

BZSHT and one-shot buzzer forced stop bit BZSTP.

When "1" is set to BZON or BZSHT, the BZ signal is

when "0" is set to BZON or "1" is set to BZSTP, the

LOW (Vss) level is output. At this time, "0" must

always be set for the output data register R50D.

Figure 5.13.2.2 shows the output waveform of the

output from the R50 output port terminal and

Fig. 5.13.2.1 Configuration of R50



Fig. 5.13.2.2 Output waveform of BZ signal

## 5.13.3 Setting of buzzer frequency and sound level

The BZ signal is a divided signal using the OSC1 oscillation circuit as the clock source and 8 frequencies can be selected. This selection is done by the buzzer frequency selection register BZFQ0–BZFQ2. The setting value and buzzer frequency correspondence is shown in Table 5.13.3.1. By selecting the duty ratio of the BZ signal from among 8 types, the buzzer sound level can be adjusted. This selection is made in the duty ratio selection register DUTY0–DUTY2. The setting value and duty ratio correspondence is shown in Table 5.13.3.2.

Table 5.13.3.1 Buzzer signal frequency settings

| BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) |
|-------|-------|-------|-----------------------|
| 0     | 0     | 0     | fosc1/8               |
| 0     | 0     | 1     | fosc1/10              |
| 0     | 1     | 0     | fosc1/12              |
| 0     | 1     | 1     | fosc <sub>1</sub> /14 |
| 1     | 0     | 0     | foscı/16              |
| 1     | 0     | 1     | fosc1/20              |
| 1     | 1     | 0     | fosc1/24              |
| 1     | 1     | 1     | fosc1/28              |

Table 5.13.3.2 Duty ratio settings

|               |       |       |       | Duty                  | ratio by buzze | er frequencies        | s (Hz)   |
|---------------|-------|-------|-------|-----------------------|----------------|-----------------------|----------|
| Level         | DUTY2 | DUTY1 | DUTY0 | fosc1/8               | fosc1/10       | fosc <sub>1</sub> /12 | fosc1/14 |
|               |       |       |       | fosc <sub>1</sub> /16 | fosc1/20       | fosc1/24              | fosc1/24 |
| Level 1 (Max) | 0     | 0     | 0     | 8/16                  | 8/20           | 12/24                 | 12/28    |
| Level 2       | 0     | 0     | 1     | 7/16                  | 7/20           | 11/24                 | 11/28    |
| Level 3       | 0     | 1     | 0     | 6/16                  | 6/20           | 10/24                 | 10/28    |
| Level 4       | 0     | 1     | 1     | 5/16                  | 5/20           | 9/24                  | 9/28     |
| Level 5       | 1     | 0     | 0     | 4/16                  | 4/20           | 8/24                  | 8/28     |
| Level 6       | 1     | 0     | 1     | 3/16                  | 3/20           | 7/24                  | 7/28     |
| Level 7       | 1     | 1     | 0     | 2/16                  | 2/20           | 6/24                  | 6/28     |
| Level 8 (Min) | 1     | 1     | 1     | 1/16                  | 1/20           | 5/24                  | 5/28     |

Duty ratio refers to the ratio of pulse width to the pulse cycle; given that HIGH level output time is TH, and low level output time is TL the BZ signal becomes TH/(TH+TL).

When DUTY0-DUTY2 have all been set to "0", the duty ratio becomes maximum and the sound level also becomes maximum. Conversely, when DUTY0-DUTY2 have all been set to "1", the duty ratio becomes minimum and the sound level also becomes minimum.

Note that the duty ratio setting differ depending on frequency. See Table 5.13.3.2.



Fig. 5.13.3.1 Duty ratio of buzzer signal waveform

Note: When using the digital envelope, the DUTY0-DUTY2 setting becomes invalid.

## 5.13.4 Digital envelope

A digital envelope with duty control can be added to the BZ signal.

The envelope can be realized by staged changing of the same duty ratio as detailed in Table 5.13.3.2 in the preceding section from level 1 (maximum) to level 8 (minimum).

The addition of an envelope to the buzzer signal can be done by writing "1" to the envelope control register ENON. When "0" is written, the duty ratio is set at the level selected in DUTY0–DUTY2. By writing "1" to ENON to turn the buzzer output ON (writing "1" to BZON), a BZ signal with a level 1 duty ratio is output, and then the duty ratio can be attenuated in stages to level 8. The attenuated envelope can be returned to level 1 by writing "1" to the envelope reset bit ENRST. When attenuated to level 8, the duty level remains at level 8 until the buzzer output is turned OFF (writing "0" to BZON) or writing "1" to ENRST.

The stage changing time for the envelope level can be selected either 125 msec or 62.5 msec by the envelope attenuation time selection register ENRTM.

Figure 5.13.4.1 shows the timing chart of the digital envelope.



Fig. 5.13.4.1 Timing chart of digital envelope

## 5.13.5 One-shot output

The sound generator has a built-in one-shot output function for outputting a short duration buzzer signal for key operation sounds and similar effects. Either 125 msec or 31.25 msec can be selected by the one-shot buzzer duration selection register SHTPW for buzzer signal output time.

The output control of the one-shot buzzer is done by writing "1" to the one-shot buzzer trigger BZSHT, then the BZ signal is output in synchronization with the internal 256 Hz signal from the R50 output port terminal. Thereafter, when the set time has elapsed, the BZ signal in synchronization with the 256 Hz signal automatically goes OFF in the same manner.

The BZSHT can be read to determine status. When BZSHT is "1", it indicates a BUSY status (during one-shot output) and when BZSHT is "0", it indicates a READY status (during stop).

When you want to turn the BZ signal OFF prior to the elapse of the set time, the BZ signal can be immediately stopped (goes OFF in asynchonization with 256 Hz signal) by writing "1" to the one-shot forced stop bit BZSTP.

Since the one-shot output has a short duration, an envelope cannot be added. (When "1" is written to BZSHT, ENON is automatically reset to "0".) Consequently, only the frequency and sound level can be set for one-shot output.

The control for the one-shot output is invalid during normal buzzer output.

Figure 5.13.5.1 shows the timing chart of the one-shot output.



Fig. 5.13.5.1 Timing chart of one-shot output

## 5.13.6 Control of sound generator

Table 5.13.6.1 shows the sound generator control bits.

Table 5.13.6.1 Sound generator control bits

| Address | Bit | Name  |                                                |       | Fu           | nction       |                      |                | 1             | 0            | SR | R/W | Comment             |
|---------|-----|-------|------------------------------------------------|-------|--------------|--------------|----------------------|----------------|---------------|--------------|----|-----|---------------------|
| 00FF44  | D7  | -     | _                                              |       |              |              |                      |                | _             | 1            | _  | -   | Constantry "0" when |
|         | D6  | BZSTP | One-shot                                       | buzz  | zer forc     | ibly stop    | )                    |                | Forcibly stop | No operation | _  | W   | being read          |
|         | D5  | BZSHT | One-shot                                       | buzz  | zer trig     | ger/statu    | s                    | R              | Busy          | Ready        | 0  | R/W |                     |
|         |     |       |                                                |       |              |              |                      | W              | Trigger       | No operation |    |     |                     |
|         | D4  | SHTPW | One-shot                                       | buzz  | zer dura     | ation wic    | ith select           | ion            | 125 msec      | 31.25 msec   | 0  | R/W |                     |
|         | D3  | ENRTM | Envelope                                       | atte  | nuation      | time         |                      |                | 1 sec         | 0.5 sec      | 0  | R/W |                     |
|         | D2  | ENRST | Envelope                                       | rese  | t            |              |                      |                | Reset         | No operation | _  | W   | "0" when being read |
|         | D1  | ENON  | Envelope                                       | On/   | Off cor      | ntrol        |                      |                | On            | Off          | 0  | R/W | *1                  |
|         | D0  | BZON  | Buzzer o                                       | utput | contro       | l            |                      |                | On            | Off          | 0  | R/W |                     |
| 00FF45  | D7  | -     | _                                              |       |              |              |                      |                | _             | 1            | _  | -   | "0" when being read |
|         | D6  | DUTY2 | Buzzer si                                      |       |              |              |                      |                | _             | 1            | 0  | R/W |                     |
|         |     |       | DUTY2                                          |       |              |              | fosci/12             |                |               |              |    |     | /                   |
|         |     |       | 2 1                                            |       |              |              | fosc1/12<br>fosc1/24 |                |               |              |    |     |                     |
|         | D5  | DUTY1 | 0 0                                            | 0     | 8/16         | 8/20         | 12/24                | 12/28          | _             | _            | 0  | R/W |                     |
|         |     |       | $\begin{pmatrix} 0 & 0 \\ 0 & 1 \end{pmatrix}$ | 1     | 7/16<br>6/16 | 7/20<br>6/20 | 11/24<br>10/24       | 11/28<br>10/28 |               |              |    |     |                     |
|         |     |       | 0 1                                            | 1     | 5/16         | 5/20         | 9/24                 | 9/28           |               |              |    |     |                     |
|         | D4  | DUTY0 | 1 0                                            | 0     | 4/16         | 4/20         | 8/24                 | 8/28           | _             | _            | 0  | R/W |                     |
|         |     |       | 1 0<br>1 1                                     | 1     | 3/16<br>2/16 | 3/20<br>2/20 | 7/24<br>6/24         | 7/28<br>6/28   |               |              |    |     |                     |
|         |     |       | 1 1                                            | 1     | 1/16         | 1/20         | 5/24                 | 5/28           |               |              |    |     | /                   |
|         | D3  | _     | _                                              |       |              |              |                      |                | _             | _            | _  | -   | "0" when being read |
|         | D2  | BZFQ2 | Buzzer fr                                      | eque  | ncy sel      | ection       |                      |                | _             | _            | 0  | R/W | /                   |
|         |     |       | BZFQ2                                          | BZF   | Q1 B2        | ZFQ0 F       | requency (           | (Hz)           |               |              |    |     | /                   |
|         |     |       | 0                                              | 0     |              | 0            | fosc1/8              |                |               |              |    |     | /                   |
|         | D1  | BZFQ1 | 0                                              | 0     |              | 1            | fosc <sub>1</sub> /1 |                | _             | _            | 0  | R/W |                     |
|         |     |       | 0                                              | 1     |              | 0            | fosc1/1              |                |               |              |    |     |                     |
|         |     |       | 0<br>1                                         | 1     |              | 1            | fosc <sub>1</sub> /1 |                |               |              |    |     | /                   |
|         | D0  | BZFQ0 | 1                                              | 0     |              | 1            | fosci/1              |                | _             |              | 0  | R/W | /                   |
|         |     |       | 1                                              | 1     |              | 0            | fosci/2              |                |               |              | -  |     | /                   |
|         |     |       | 1                                              | 1     |              | 1            | fosci/2              |                |               |              |    |     | /                   |
|         |     |       |                                                |       |              |              |                      |                | 1             |              |    | 1   | V                   |

<sup>\*1</sup> Reset to "0" during one-shot output.

#### BZON: 00FF44H•D0

Controls the BZ signal output.

When "1" is written: BZ signal output When "0" is written: LOW level (DC) output

Reading: Valid

BZON is the output control register for BZ signal. When "1" is set, the BZ signal is output from the output port terminal R50 and when "0" is set, LOW (Vss) level is output. At this time, "0" must always be set for the data register R50D.

At initial reset, BZON is set to "0" (LOW level output).

#### BZFQ0-BZFQ2: 00FF45H•D0-D2

Selects the BZ signal frequency.

Table 5.13.6.2 Buzzer frequency settings

| BZFQ2 | BZFQ1 | BZFQ0 | Buzzer frequency (Hz) |
|-------|-------|-------|-----------------------|
| 0     | 0     | 0     | fosc1/8               |
| 0     | 0     | 1     | fosc <sub>1</sub> /10 |
| 0     | 1     | 0     | fosc1/12              |
| 0     | 1     | 1     | fosc1/14              |
| 1     | 0     | 0     | foscı/16              |
| 1     | 0     | 1     | fosc1/20              |
| 1     | 1     | 0     | fosc1/24              |
| 1     | 1     | 1     | fosc1/28              |

The buzzer frequency can be selected from among the above 8 types that have divided the OSC1 clock. At initial reset, this register is set at "0" (fosc1/8).

#### DUTY0-DUTY2: 00FF45H•D4-D6

Selects the duty ratio of the BZ signal.

Table 5.13.6.3 Duty ratio settings

|               |       |       |       | Duty                  | ratio by buzze        | er frequencies        | s (Hz)                |
|---------------|-------|-------|-------|-----------------------|-----------------------|-----------------------|-----------------------|
| Level         | DUTY2 | DUTY1 | DUTY0 | fosc1/8               | fosc <sub>1</sub> /10 | fosc <sub>1</sub> /12 | fosc <sub>1</sub> /14 |
|               |       |       |       | fosc <sub>1</sub> /16 | fosc1/20              | fosc1/24              | fosc1/24              |
| Level 1 (Max) | 0     | 0     | 0     | 8/16                  | 8/20                  | 12/24                 | 12/28                 |
| Level 2       | 0     | 0     | 1     | 7/16                  | 7/20                  | 11/24                 | 11/28                 |
| Level 3       | 0     | 1     | 0     | 6/16                  | 6/20                  | 10/24                 | 10/28                 |
| Level 4       | 0     | 1     | 1     | 5/16                  | 5/20                  | 9/24                  | 9/28                  |
| Level 5       | 1     | 0     | 0     | 4/16                  | 4/20                  | 8/24                  | 8/28                  |
| Level 6       | 1     | 0     | 1     | 3/16                  | 3/20                  | 7/24                  | 7/28                  |
| Level 7       | 1     | 1     | 0     | 2/16                  | 2/20                  | 6/24                  | 6/28                  |
| Level 8 (Min) | 1     | 1     | 1     | 1/16                  | 1/20                  | 5/24                  | 5/28                  |

The buzzer sound level can be adjusted by selecting the duty ratio from among the above 8 types. However, when the envelope has been set to ON (ENON = "1"), this setting becomes invalid.

At initial reset, this register is set to "0" (level 1).

#### ENRST: 00FF44H•D2

Resets the envelope.

When "1" is written: Reset

When "0" is written: No operation Reading: Always "0"

The envelope is reset by writing "1" to ENRST and the duty ratio returns to level 1 (maximum). Writing "0" to ENRST and writing "1" when an envelope has not been added become invalid. Since ENRST is exclusively for writing, it always becomes "0" during reading.

#### ENON: 00FF44H•D1

Controls the addition of an envelope to the BZ signal.

When "1" is written: ON When "0" is written: OFF Reading: Valid

By writing "1" to ENON, an envelope can be added to BZ signal output. When "0" is written, an envelope is not added and the BZ signal is fixed at the duty ratio selected in DUTY0–DUTY2. At initial reset and when "1" is written to BZSHT, ENON is set to "0" (OFF).

#### ENRTM: 00FF44H•D3

Selects the envelope attenuation time that is added to the BZ signal.

When "1" is written: 1.0 sec

 $(125 \operatorname{msec} \times 7 = 875 \operatorname{msec})$ 

When "0" is written: 0.5 sec

 $(62.5 \text{ msec} \times 7 = 437.5 \text{ msec})$ 

Reading: Valid

The attenuation time of the digital envelope is determined by the time for changing the duty ratio. The duty ratio is changed in 125 msec (8 Hz) units when "1" is written to ENRTM and in 62.5 msec (16 Hz) units, when "0" is written.

This setting becomes invalid when an envelope has been set to OFF (ENON = "0").

At initial reset, ENRTM is set to "0" (0.5 sec).

#### SHTPW: 00FF44H•D4

Selects the output duration width of the one-shot buzzer.

When "1" is written: 125 msec When "0" is written: 31.25 msec Reading: Valid

The one-shot buzzer output duration width is set to 125 msec when "1" is written to SHTPW and 62.5 msec, when "0" is written.

At initial reset, SHTPW is set to "0" (31.25 msec).

#### BZSHT: 00FF44H•D5

Controls the one-shot buzzer output.

When "1" is written: Trigger When "0" is written: No operation

When "1" is read: Busy
When "0" is read: Ready

Writing "1" into BZSHT causes the one-shot output circuit to operate and the BZ signal to be output. The buzzer output is automatically turned OFF after the time set by SHTPW has elapsed. At this time, "0" must always be set for the data register R50D.

The one-shot output is only valid when the normal buzzer output is OFF (BZON = "0") status. The trigger is invalid during ON (BZON = "1") status. When a re-trigger is assigned during a one-shot output, the one-shot output time set with SHTPW is measured again from that point. (time extension) The operation status of the one-shot output circuit can be confirmed by reading BZSHT, when the one-shot output is ON (busy), BZSHT reads "1" and when the output is OFF (ready), it reads "0". At initial reset, BZSHT is set to "0" (ready).

#### BZSTP: 00FF44H•D6

Forcibly stops the one-shot buzzer output.

When "1" is written: Forcibly stop When "0" is written: No operation Reading: Constantly "0"

By writing "1" into BZSTP, the one-shot buzzer output can be stopped prior to the elapsing of the time set with SHTPW.

Writing "0" is invalid and writing "1" except during one-shot output is also invalid.

When "1" is written to BZSHT and BZSTP simultaneously, BZSTP takes precedence and one-shot output becomes stop status.

Since BZSTP is for writing only, during readout it is constantly set to "0".

## 5.13.7 Programming notes

- (1) Since the BZ signal is generated asynchronously from the register BZON, when the signal is turned ON or OFF by the register setting, a hazard of a 1/2 cycle or less is generated.
- (2) The SLP instruction has executed when the BZ signal is in the enable status (BZON = "1" or BZSHT = "1"), an unstable clock is output from the R50 output port terminal at the time of return from the SLEEP status. Consequently, when shifting to the SLEEP status, you should set the BZ signal to the disable status (BZON = BZSHT = "0") prior to executing the SLP instruction.
- (3) The one-shot output is only valid when the normal buzzer output is OFF (BZON = "0") status. The trigger is invalid during ON (BZON = "1") status.

## 5.14 Analog Comparator

## 5.14.1 Configuration of analog comparator

The E0C88365 has an MOS input analog comparator built into two channels. The respective analog comparators have two differential input terminals (inverted input terminal CMPMx and non-inverted input terminal CMPPx) that are available for general purpose use.

Figure 5.14.1.1 shows the configuration of the analog comparator.



Fig. 5.14.1.1 Configuration of analog comparator

Since the input terminals of the analog comparator CMPP0, CMPM0, CMPP1 and CMPM1 are common to I/O ports P14–P17, when using as the input terminal for the analog comparator, "0" (input mode) must be written to I/O control registers IOC14–IOC17.

Table 5.14.1.1 Input terminal configuration

| Terminal | When analog comparator is used |
|----------|--------------------------------|
| P14      | CMPP0                          |
| P15      | CMPM0                          |
| P16      | CMPP1                          |
| P17      | CMPM1                          |

#### 5.14.2 Mask option

Since the input terminals of the analog comparator are common to the I/O ports, the mask option for the I/O port corresponding to the channel to be used must be set to "Gate direct".

| I/O ports pull-up resistor          |               |
|-------------------------------------|---------------|
| P14 (CMPP0) □ With resistor         |               |
| P15 (CMPM0) □ With resistor         | ✓ Gate direct |
| P16 (CMPP1) □ With resistor         | ✓ Gate direct |
| P17 (CMPM1) $\square$ With resistor | ✓ Gate direct |

\* "\" above shows an example of both channels being used.

## 5.14.3 Analog comparator operation

By writing "1" to the analog comparator control register CMPxON, the analog comparator goes ON, and the analog comparator starts comparing the external voltages that have been input to the two differential input terminals CMPPx and CMPMx. The result can be read from the comparator comparison result detection bit CMPxDT through the latch and when CMPPx (+) > CMPMx (-), it is "1" and when CMPPx (+) < CMPMx (-), it is "0". After the analog comparator has been turned ON, a maximum time of 3 msec is necessary until output stabilizes. Consequently, you should allow an adequate waiting time after turning the analog comparator ON, before reading the comparison result

When the analog comparator is turned OFF, the comparison result at that point will be latched and the concerned data can be read thereafter, until the analog comparator is turned ON.

You should turn the analog comparator OFF, when it is not necessary, so as to reduce current consumption.

See "7 ELECTRICAL CHARACTERISTICS" for the input voltage range.

Note: Since the input terminals of the analog comparator are common to the I/O ports, the I/O control registers (IOC14–IOC17) corresponding to the channel to be used must be set to the input mode.

## 5.14.4 Control of analog comparator

Table 5.14.4.1 shows the analog comparator control bits.

Table 5.14.4.1 Analog comparator control bits

| Address | Bit | Name   | Function                    | 1   | 0     | SR | R/W | Comment             |
|---------|-----|--------|-----------------------------|-----|-------|----|-----|---------------------|
| 00FF13  | D7  | _      | _                           | -   | -     | _  | _   |                     |
|         | D6  | _      | _                           | -   | -     | _  | _   | Constantly "0" when |
|         | D5  | _      | _                           | -   | -     | _  | _   | being read          |
|         | D4  | _      | _                           | -   | -     | _  | _   |                     |
|         | D3  | CMP10N | Comparator 1 On/Off control | On  | Off   | 0  | R/W |                     |
|         | D2  | CMP0ON | Comparator 0 On/Off control | On  | Off   | 0  | R/W |                     |
|         | D1  | CMP1DT | Comparator 1 data           | +>- | +<-   | 0  | R   |                     |
|         | D0  | CMP0DT | Comparator 0 data           | +>- | + < - | 0  | R   |                     |

#### CMPOON, CMP1ON: 00FF13H•D2, D3

Controls the analog comparator ON/OFF.

When "1" is written: ON When "0" is written: OFF Reading: Valid

The analog comparator 0 goes ON by writing "1" to CMP0ON and goes OFF, when "0" is written. The analog comparator 1 can be controlled with CMP1ON in the same way.

At initial reset, this register is set "0" (OFF).

### CMP0DT, CMP1DT: 00FF13H•D0, D1

The comparison result of the analog comparator can be read out.

When "1" is read: CMPPx (+) > CMPMx (-)When "0" is read: CMPPx (+) < CMPMx (-)

Writing: Invalid

The result of analog comparator 0 can be read from CMP0DT. When the status of external voltage input to differential input terminals CMPP0 and CMPM0 is CMPP0 (+) > CMPM0 (-), CMP0DT becomes "1" and when it is CMPP0 (+) < CMPM0 (-), CMP0DT becomes "0".

As the same way, the comparison result between CMPP1 and CMPM1 can be read from CMP1DT. When the analog comparator is turned OFF, the latched result immediately prior to going OFF is read out.

At initial reset, this bit is set to "1".

## 5.14.5 Programming notes

- (1) To reduce current consumption, turn the analog comparator OFF (CMP0ON = CMP1ON = "0") when it is not necessary.
- (2) After the analog comparator has been turned ON, a maximum time of 3 msec is necessary until output stabilizes. Consequently, you should allow an adequate waiting time after turning the analog comparator ON, before reading the comparison result.
- (3) Since the input terminals of the analog comparator are common to the I/O ports, the I/O control registers (IOC14–IOC17) corresponding to the channel to be used must be set to the input mode.

# 5.15 Supply Voltage Detection (SVD) Circuit

## 5.15.1 Configuration of SVD circuit

The E0C88365 has a built-in supply voltage detection (SVD) circuit configured with a 4-bit successive approximation A/D converter.

The SVD circuit has 16 sampling levels (level 0–level 15) for supply voltage, and this can be controlled by software.

## 5.15.2 Operation of SVD circuit

#### ■ Sampling control of the SVD circuit

The SVD circuit has two operation modes: continuous sampling and 1/4 Hz auto-sampling mode. Operation mode selection is done by the SVD control registers SVDON and SVDSP as shown in Table 5.15.2.1. When both bits of SVDON and SVDSP are set to "1", continuous sampling is selected.

Table 5.15.2.1 Correspondence between control register and operation mode

| SVDON | SVDSP | Operating mode          |
|-------|-------|-------------------------|
| 0     | 0     | SVD circuit OFF         |
| 0     | 1     | 1/4 Hz auto-sampling ON |
| 1     | ×     | Continuous sampling ON  |

In both operation modes, reading SVDON can confirm whether the SVD circuit is operating (BUSY) or on standby (READY); "1" indicates BUSY and "0" indicates READY.

When executing an SLP instruction while the SVD circuit is operating, the stop operation of the OSC1 oscillation circuit is kept waiting until the sampling is completed. The two bits of SVDON and SVDSP are automatically reset to "0" by hardware while waiting for completion of sampling.

To reduce current consumption, turn the SVD circuit OFF when it is not necessary.

#### Detection result

The SVD circuit A/D converts the supply voltage (VDD–Vss) by 4-bit resolution and sets the result thereof into the SVD0–SVD3 register.

The data in SVD0–SVD3 correspond to the detection levels as shown in Table 5.15.2.2 and the detection data is maintained until the next sampling.

For the correspondence between the detection level and the supply voltage, see "7 ELECTRICAL CHARACTERISTICS".

An interval of 7.8 msec/6.7 msec\*2 is required from the start of supply voltage sampling by the SVD circuit to completion by writing the result into SVD0–SVD3. Therefore, when reading SVD0–SVD3 before sampling is finished, the previous result will be read.

| fosc1      | *1       | *2       |  |
|------------|----------|----------|--|
| 32.768 kHz | 2,048 Hz | 7.8 msec |  |
| 38.4 kHz   |          |          |  |
| 76.8 kHz   | 2 400 11 | 67       |  |
| 96.0 kHz   | 2,400 Hz | 6.7 msec |  |
| 153.6 kHz  |          |          |  |

Table 5.15.2.2 Supply voltage detection results

| SVD3 | SVD2 | SVD1 | SVD0 | Detection level |
|------|------|------|------|-----------------|
| 1    | 1    | 1    | 1    | Level 15        |
| 1    | 1    | 1    | 0    | Level 14        |
| 1    | 1    | 0    | 1    | Level 13        |
| 1    | 1    | 0    | 0    | Level 12        |
| 1    | 0    | 1    | 1    | Level 11        |
| 1    | 0    | 1    | 0    | Level 10        |
| 1    | 0    | 0    | 1    | Level 9         |
| 1    | 0    | 0    | 0    | Level 8         |
| 0    | 1    | 1    | 1    | Level 7         |
| 0    | 1    | 1    | 0    | Level 6         |
| 0    | 1    | 0    | 1    | Level 5         |
| 0    | 1    | 0    | 0    | Level 4         |
| 0    | 0    | 1    | 1    | Level 3         |
| 0    | 0    | 1    | 0    | Level 2         |
| 0    | 0    | 0    | 1    | Level 1         |
| 0    | 0    | 0    | 0    | Level 0         |



Fig.5.15.1.1 Configuration of SVD circuit

#### ■ Timing of sampling

Next, we will explain the timing for two operation modes.

#### (1) Continuous sampling mode

This mode is selected when "1" is written to SVDON and sampling of the supply voltage is done continuously in 7.8 msec/6.7 msec\*2 cycles.

The SVD circuit starts operation in synchronization with the internal 2,048  $\rm Hz/2,400~Hz*1$  signal and performs one sampling in 16 clock cycles.

The sampling is done continuously without setting the standby time and the result is latched to SVD0–SVD3 in every 16 clock cycles. Cancellation of continuous sampling is done by writing "0" to SVDON. The SVD circuit maintains ON status until completion of sampling and then goes OFF.

After writing "0" to SVDON, SVDON reads "1" until the SVD circuit actually goes OFF. Figure 5.15.2.1 shows the timing chart of the continuous sampling.

#### (2) 1/4 Hz auto-sampling mode

This mode is selected when "0" is written to SVDON and "1" is written to SVDSP. In this case, supply voltage sampling is done in every 4 seconds.

The sampling time is 7.8 msec/6.7 msec\*2 as in continuous sampling, and the result in SVD0–SVD3 is updated every 4 seconds.

Cancellation of 1/4 Hz auto-sampling is done by writing "0" to SVDSP. If the SVD circuit is sampling, SVD circuit waits until completion and then turns OFF. In addition, "1" is read from SVDON while the SVD circuit is sampling. Figure 5.15.2.2 shows the timing chart of the 1/4 Hz auto-sampling.

| fosc1      | *1           | *2       |  |  |
|------------|--------------|----------|--|--|
| 32.768 kHz | 2,048 Hz     | 7.8 msec |  |  |
| 38.4 kHz   |              |          |  |  |
| 76.8 kHz   | 2 400 11-    | 6.7 msec |  |  |
| 96.0 kHz   | 2,400 Hz 6.7 |          |  |  |
| 153.6 kHz  |              |          |  |  |



Fig. 5.15.2.1 Timing chart of continuous sampling



Fig. 5.15.2.2 Timing chart of 1/4 Hz auto-sampling

## 5.15.3 Control of SVD circuit

Table 5.15.3.1 shows the SVD circuit control bits.

Table 5.15.3.1 SVD circuit control bits

| Address | Bit | Name  | Function                                     | 1    | 0     | SR    | R/W | Comment             |
|---------|-----|-------|----------------------------------------------|------|-------|-------|-----|---------------------|
| 00FF12  | D7  | _     | _                                            | -    | -     | -     | _   | Constantry "0" when |
|         | D6  | _     | _                                            | -    | ı     | ı     | _   | being read          |
|         | D5  | SVDSP | SVD auto-sampling control                    | On   | Off   | 0     | R/W | These registers are |
|         |     |       |                                              |      |       |       |     | reset to "0" when   |
|         | D4  | SVDON | SVD continuous sampling control/status R     | Busy | Ready | 1→0*1 | R/W | SLP instruction     |
|         |     |       | W                                            | On   | Off   | 0     |     | is executed.        |
|         | D3  | SVD3  | SVD detection level                          |      | _     | X     | R   | *2                  |
|         | D2  | SVD2  | SVD3 SVD2 SVD1 SVD0 Detection level Level 15 |      | _     | X     | R   |                     |
|         | D1  | SVD1  | 1 1 1 0 Level 14                             | _    | -     | X     | R   |                     |
|         | D0  | SVD0  | 0 0 0 0 Level 0                              | _    | -     | X     | R   |                     |

<sup>\*1</sup> After initial reset, this status is set "1" until conclusion of hardware first sampling.

#### SVDON: 00FF12H•D4

Controls the turning ON/OFF of the continuous sampling mode.

When "1" is written: Continuous sampling ON When "0" is written: Continuous sampling OFF

When "1" is read: BUSY
When "0" is read: READY

The continuous sampling mode goes ON when "1" is written to SVDON and goes OFF, when "0" is written.

In the ON status, sampling of the supply voltage is done continuously in 7.8 msec/6.7 msec\*1 cycles and the detection result is latched to SVD0–SVD3. SVDON can be read, and "1" indicates SVD circuit operation (BUSY) and "0" indicates standby (READY).

At initial reset and in the SLEEP status, SVDON is set to "0" (continuous sampling OFF/READY).

#### SVDSP: 00FF12H•D5

Controls the turning ON/OFF of the 1/4 Hz auto-sampling mode.

When "1" is written: Auto-sampling ON When "0" is written: Auto-sampling OFF

Reading: Valid

The 1/4 Hz auto-sampling mode goes ON when "1" is written to SVDSP and goes OFF, when "0" is written.

In the ON status, sampling is done in every 4 seconds and "1" is read from SVDON during the actual sampling period (7.8 msec/6.7 msec\*1). At initial reset and in the SLEEP status, SVDSP is set to "0" (auto-sampling OFF).

| fosc1      | *1       |
|------------|----------|
| 32.768 kHz | 7.8 msec |
| 38.4 kHz   |          |
| 76.8 kHz   | 67       |
| 96.0 kHz   | 6.7 msec |
| 153.6 kHz  |          |

<sup>\*2</sup> Initial values are set according to the supply voltage detected at first sampling by hardware. Until conclusion of first sampling, SVD0–SVD3 data are undefined.

#### SVD0-SVD3: 00FF12H•D0-D3

The detection result of the SVD is set. The reading data correspond to the detection levels as shown in Table 5.15.3.2 and the data is maintained until the next sampling.

Table 5.15.3.2 Supply voltage detection results

| SVD3 | SVD2 | SVD1 | SVD0 | Detection level |
|------|------|------|------|-----------------|
| 1    | 1    | 1    | 1    | Level 15        |
| 1    | 1    | 1    | 0    | Level 14        |
| 1    | 1    | 0    | 1    | Level 13        |
| 1    | 1    | 0    | 0    | Level 12        |
| 1    | 0    | 1    | 1    | Level 11        |
| 1    | 0    | 1    | 0    | Level 10        |
| 1    | 0    | 0    | 1    | Level 9         |
| 1    | 0    | 0    | 0    | Level 8         |
| 0    | 1    | 1    | 1    | Level 7         |
| 0    | 1    | 1    | 0    | Level 6         |
| 0    | 1    | 0    | 1    | Level 5         |
| 0    | 1    | 0    | 0    | Level 4         |
| 0    | 0    | 1    | 1    | Level 3         |
| 0    | 0    | 1    | 0    | Level 2         |
| 0    | 0    | 0    | 1    | Level 1         |
| 0    | 0    | 0    | 0    | Level 0         |

For the correspondence between the detection level and the supply voltage, see "7 ELECTRICAL CHARACTERISTICS".

The initial value at initial reset is set according to the supply voltage detected at first sampling by hardware. Data of this bit is undefined until this sampling is completed.

## 5.15.4 Programming notes

- (1) To reduce current consumption, turn the SVD circuit OFF (SVDON = SVDSP = "0") when it is not necessary.
- (2) When executing an SLP instruction while the SVD circuit is operating, the stop operation of the OSC1 oscillation circuit is kept waiting until the sampling is completed. The two bits of SVDON and SVDSP are automatically reset to "0" by hardware while waiting for completion of sampling.

## 5.16 Interrupt and Standby Status

#### ■ Types of interrupts

Six systems and 15 types of interrupts have been provided for the E0C88365.

#### **External interrupt**

- K00–K07 input interrupt (2 types)
- •K10 and K11 input interrupt (1 type)

#### Internal interrupt

- •Clock timer interrupt (4 types)
- •Stopwatch interrupt (3 types)
- Programmable timer interrupt (2 types)
- •Serial interface interrupt (3 types)

An interrupt factor flag that indicates the generation of an interrupt factor and an interrupt enable register that sets enable/disable for interrupt requests have been provided for each interrupt and interrupt generation can be optionally set for each factor.

In addition, an interrupt priority register has been provided for each system of interrupts and the priority of interrupt processing can be set to 3 levels in each system.

Figure 5.16.1 shows the configuration of the interrupt circuit.

Refer to the explanations of the respective peripheral circuits for details on each interrupt.



Fig. 5.16.1 Configuration of interrupt circuit

#### ■ HALT status

By executing the program's HALT instruction, the E0C88365 shifts to the HALT status.

Since CPU operation stops in the HALT status, power consumption can be reduced with only peripheral circuit operation.

Cancellation of the HALT status is done by initial reset or an optional interrupt request, and the CPU restarts program execution from an exception processing routine.

See the "E0C88 Core CPU Manual" for the HALT status and reactivation sequence.

#### **■ SLEEP status**

By executing the program's SLP instruction, the E0C88365 shifts to the SLEEP status. Since the operation of the CPU and peripheral circuits stop completely in the SLEEP status, power consumption can be reduced even more than in the HALT status.

Cancellation of the SLEEP status is done by initial reset or an input interrupt from the input port. The CPU reactivates after waiting 250 msec of oscillation stabilization time. At this time, the CPU restarts program execution from an exception processing routine (input interrupt routine).

Note: Since oscillation is unstable for a short time after reactivation from the SLEEP status, the wait time is not always 250 msec even when using the 32.768 kHz crystal oscillator for the OSC1 oscillation circuit.

## 5.16.1 Interrupt generation conditions

The interrupt factor flags that indicate the generation of their respective interrupt factors are provided for the previously indicated 6 systems and 15 types of interrupts and they will be set to "1" by the generation of a factor.

In addition, interrupt enable registers with a 1 to 1 correspondence to each of the interrupt factor flags are provided. An interrupt is enabled when "1" is written and interrupt is disabled when "0" is written.

The CPU manages the enable / disable of interrupt requests at the interrupt priority level. An interrupt priority register that sets the priority level is provided for each of the interrupts of the 6 systems and the CPU accepts only interrupts above the level that has been indicated with the interrupt flags (I0 and I1).

Consequently, the following three conditions are necessary for the CPU to accept the interrupt.

- (1) The interrupt factor flag has been set to "1" by generation of an interrupt factor.
- (2) The interrupt enable register corresponding to the above has been set to "1".
- (3) The interrupt priority register corresponding to the above has been set to a priority level higher than the interrupt flag (I0 and I1) setting.

The CPU initially samples the interrupt for the first op-code fetch cycle of each instruction. Thereupon, the CPU shifts to the exception processing when the above mentioned conditions have been established. See the "E0C88 Core CPU Manual" for the exception processing sequence.

## 5.16.2 Interrupt factor flag

Table 5.16.2.1 shows the correspondence between the factors generating an interrupt and the interrupt factor flags.

The corresponding interrupt factor flags are set to "1" by generation of the respective interrupt factors. The corresponding interrupt factor can be confirmed by reading the flags through software.

FTM2

FTM1

| ······································                                                    |                       |             |
|-------------------------------------------------------------------------------------------|-----------------------|-------------|
| Interrupt factor                                                                          | Interrupt factor flag |             |
| Programmable timer 1 underflow                                                            | FPT1                  | (00FF25 D7) |
| Programmable timer 0 underflow                                                            | FPT0                  | (00FF25 D6) |
| Non matching of the K10 and K11 inputs and the input comparison registers KCP10 and KCP11 | FK1                   | (00FF25 D5) |
| Non matching of the K04–K07 inputs and the input comparison registers KCP04–KCP07         | FK0H                  | (00FF25 D4) |
| Non matching of the K00–K03 inputs and the input comparison registers KCP00–KCP03         | FK0L                  | (00FF25 D3) |
| Serial interface receiving error (in asynchronous mode)                                   | FSERR                 | (00FF25 D2) |
| Serial interface receiving completion                                                     | FSREC                 | (00FF25 D1) |
| Serial interface transmitting completion                                                  | FSTRA                 | (00FF25 D0) |
| Falling edge of the stopwatch timer 100 Hz signal                                         | FSW100                | (00FF24 D6) |
| Falling edge of the stopwatch timer 10 Hz signal                                          | FSW10                 | (00FF24 D5) |
| Falling edge of the stopwatch timer 1 Hz signal                                           | FSW1                  | (00FF24 D4) |
| Rising edge of the clock timer 1/60 Hz signal                                             | FTM1M                 | (00FF24 D3) |
| Rising edge of the clock timer 8 Hz signal                                                | FTM8                  | (00FF24 D2) |
|                                                                                           | 1                     |             |

Table 5.16.2.1 Interrupt factors

(00FF24 D1)

(00FF24 D0)

Rising edge of the clock timer 2 Hz signal

Rising edge of the clock timer 1 Hz signal

Interrupt factor flag that has been set to "1" is reset to "0" by writing "1".

At initial reset, the interrupt factor flags are reset to "0".

Note: When executing the RETE instruction without resetting the interrupt factor flag after an interrupt has been generated, the same interrupt will be generated. Consequently, the interrupt factor flag corresponding to that routine must be reset (writing "1") in the interrupt processing routine.

## 5.16.3 Interrupt enable register

The interrupt enable register has a 1 to 1 correspondence with each interrupt factor flag and enable/disable of interrupt requests can be set.

When "1" is written to the interrupt enable register, an interrupt request is enabled, and is disabled when "0" is written. This register also permits reading, thus making it possible to confirm that a status has been set.

At initial reset, the interrupt enable registers are set to "0" and shifts to the interrupt disable status. Table 5.16.3.1 shows the correspondence between the interrupt enable registers and the interrupt factor flags.

# 5.16.4 Interrupt priority register and interrupt priority level

The interrupt priority registers shown in Table 5.16.4.1 are set to each system of interrupts and the interrupt priority levels for the CPU can be set to the optional priority level (0–3). As a result, it is possible to have multiple interrupts that match the system's interrupt processing priority levels.

The interrupt priority level between each system can optionally be set to three levels by the interrupt priority register. However, when more than one system is set to the same priority level, they are processed according to the default priority level.

Table 5.16.4.2 Setting of interrupt priority level

| P*1 | P*0 | Interrupt priority level    |  |  |  |
|-----|-----|-----------------------------|--|--|--|
| 1   | 1   | Level 3 ( <del>IRQ3</del> ) |  |  |  |
| 1   | 0   | Level 2 (IRQ2)              |  |  |  |
| 0   | 1   | Level 1 ( <del>IRQ1</del> ) |  |  |  |
| 0   | 0   | Level 0 (non)               |  |  |  |

Table 5.16.3.1 Interrupt enable registers and interrupt factor flags

| Interrupt                                | Interrup | ot factor flag | Interrupt e | enable register |
|------------------------------------------|----------|----------------|-------------|-----------------|
| Programmable timer 1                     | FPT1     | (00FF25 D7)    | EPT1        | (00FF23 D7)     |
| Programmable timer 0                     | FPT0     | (00FF25 D6)    | EPT0        | (00FF23 D6)     |
| K10 and K11 input                        | FK1      | (00FF25 D5)    | EK1         | (00FF23 D5)     |
| K04-K07 input                            | FK0H     | (00FF25 D4)    | EK0H        | (00FF23 D4)     |
| K00-K03 input                            | FK0L     | (00FF25 D3)    | EK0L        | (00FF23 D3)     |
| Serial interface receiving error         | FSERR    | (00FF25 D2)    | ESERR       | (00FF23 D2)     |
| Serial interface receiving completion    | FSREC    | (00FF25 D1)    | ESREC       | (00FF23 D1)     |
| Serial interface transmitting completion | FSTRA    | (00FF25 D0)    | ESTRA       | (00FF23 D0)     |
| Stopwatch timer 100 Hz                   | FSW100   | (00FF24 D6)    | ESW100      | (00FF22 D6)     |
| Stopwatch timer 10 Hz                    | FSW10    | (00FF24 D5)    | ESW10       | (00FF22 D5)     |
| Stopwatch timer 1 Hz                     | FSW1     | (00FF24 D4)    | ESW1        | (00FF22 D4)     |
| Clock timer 1/60 Hz                      | FTM1M    | (00FF24 D3)    | ETM1M       | (00FF22 D3)     |
| Clock timer 8 Hz                         | FTM8     | (00FF24 D2)    | ETM8        | (00FF22 D2)     |
| Clock timer 2 Hz                         | FTM2     | (00FF24 D1)    | ETM2        | (00FF22 D1)     |
| Clock timer 1 Hz                         | FTM1     | (00FF24 D0)    | ETM1        | (00FF22 D0)     |

Table 5.16.4.1 Interrupt priority register

| Interrupt                    | Interrupt priority register  |
|------------------------------|------------------------------|
| Programmable timer interrupt | PPT0, PPT1 (00FF21 D2, D3)   |
| K10 and K11 input interrupt  | PK10, PK11 (00FF21 D0, D1)   |
| K00-K07 input interrupt      | PK00, PK01 (00FF20 D6, D7)   |
| Serial interface interrupt   | PSIF0, PSIF1 (00FF20 D4, D5) |
| Stopwatch timer interrupt    | PSW0, PSW1 (00FF20 D2, D3)   |
| Clock timer interrupt        | PTM0, PTM1 (00FF20 D0, D1)   |

At initial reset, the interrupt priority registers are all set to "0" and each interrupt is set to level 0. Furthermore, the priority levels in each system have been previously decided and they cannot be changed.

The CPU can mask each interrupt by setting the interrupt flags (I0 and I1). The relation between the interrupt priority level of each system and interrupt flags is shown in Table 5.16.4.3, and the CPU accepts only interrupts above the level indicated by the interrupt flags.

The  $\overline{\text{NMI}}$  (watchdog timer) that has level 4 priority, is always accepted regardless of the setting of the interrupt flags.

Table 5.16.4.3 Interrupt mask setting of CPU

| I1 | 10 | Acceptable interrupt                      |
|----|----|-------------------------------------------|
| 1  | 1  | Level 4 (NMI)                             |
| 1  | 0  | Level 4, Level 3 (IRQ3)                   |
| 0  | 1  | Level 4, Level 3, Level 2 (IRQ2)          |
| 0  | 0  | Level 4, Level 3, Level 2, Level 1 (IRQ1) |

After an interrupt has been accepted, the interrupt flags are written to the level of that interrupt. However, interrupt flags after an  $\overline{NMI}$  has been accepted are written to level 3 (I0 = I1 = "1").

Table 5.16.4.4 Interrupt flags after acceptance of interrupt

| Accepted interru | pt priority level           | I1 | 10 |
|------------------|-----------------------------|----|----|
| Level 4          | $(\overline{\mathrm{NMI}})$ | 1  | 1  |
| Level 3          | $(\overline{IRQ3})$         | 1  | 1  |
| Level 2          | $(\overline{IRQ2})$         | 1  | 0  |
| Level 1          | $(\overline{IRQ1})$         | 0  | 1  |

The set interrupt flags are reset to their original value on return from the interrupt processing routine. Consequently, multiple interrupts up to 3 levels can be controlled by the initial settings of the interrupt priority registers alone. Additional multiplexing can be realized by rewriting the interrupt flags and interrupt enable register in the interrupt processing routine.

Note: Beware. If the interrupt flags have been rewritten (set to lower priority) prior to resetting an interrupt factor flag after an interrupt has been generated, the same interrupt will be generated again.

#### 5.16.5 Exception processing vectors

When the CPU accepts an interrupt request, it starts exception processing following completion of the instruction being executed. In exception processing, the following operations branch the program.

- (1) In the minimum mode, the program counter (PC) and system condition flag (SC) are moved to stack and in the maximum mode, the code bank register (CB), PC and SC are moved.
- (2) The branch destination address is read from the exception processing vector corresponding to each exception processing (interrupt) factor and is placed in the PC.

An exception vector is 2 bytes of data in which the top address of each exception (interrupt) processing routine has been stored and the vector addresses correspond to the exception processing factors as shown in Table 5.16.5.1.

Table 5.16.5.1 Vector address and exception processing correspondence

| Vector address | Exception processing factor                | Priority     |
|----------------|--------------------------------------------|--------------|
| 000000Н        | Reset                                      | High         |
| 000002H        | Zero division                              | $\uparrow$   |
| 000004H        | Watchdog timer (NMI)                       |              |
| 000006Н        | Programmable timer 1 interrupt             |              |
| 000008H        | Programmable timer 0 interrupt             |              |
| 00000AH        | K10, K11 input interrupt                   |              |
| 00000CH        | K04–K07 input interrupt                    |              |
| 00000EH        | K00–K03 input interrupt                    |              |
| 000010H        | Serial I/F error interrupt                 |              |
| 000012H        | Serial I/F receiving complete interrupt    |              |
| 000014H        | Serial I/F transmitting complete interrupt |              |
| 000016H        | Stopwatch timer 100 Hz interrupt           |              |
| 000018H        | Stopwatch timer 10 Hz interrupt            |              |
| 00001AH        | Stopwatch timer 1 Hz interrupt             |              |
| 00001CH        | Clock timer 1/60 Hz interrupt              |              |
| 00001EH        | Clock timer 8 Hz interrupt                 |              |
| 000020H        | Clock timer 2 Hz interrupt                 | $\downarrow$ |
| 000022H        | Clock timer 1 Hz interrupt                 | Low          |
| 000024H        | System reserved (cannot be used)           | No           |
| 000026Н        |                                            |              |
| :              | Software interrupt                         | priority     |
| 0000FEH        |                                            | rating       |

Note: An exception processing vector is fixed at 2 bytes, so it cannot specify a branch destination bank address. Consequently, to branch from multiple banks to a common exception processing routine, the top portion of an exception processing routine must be described within the common area (000000H–007FFFH).

## 5.16.6 Control of interrupt

Table 5.16.6.1 shows the interrupt control bits.

Table 5.16.6.1 Interrupt control bits

| Address | Bit | Name         | Function                                                                                                       | 1                     |              | 0                   | SR | R/W    | Comment             |
|---------|-----|--------------|----------------------------------------------------------------------------------------------------------------|-----------------------|--------------|---------------------|----|--------|---------------------|
| 00FF20  | D7  | PK01         | ************                                                                                                   |                       |              |                     |    |        | /                   |
|         | D6  | PK00         | K00–K07 interrupt priority register                                                                            | PK01 F                | K00          |                     | 0  | R/W    |                     |
|         | D5  | PSIF1        |                                                                                                                | PSIF1 P               | SIF0         | )                   |    | D 411  | 1 / 1               |
|         | D4  | PSIF0        | Serial interface interrupt priority register                                                                   | PSW1 P<br>PTM1 P      |              |                     | 0  | R/W    |                     |
|         | D3  | PSW1         | Carrent data di mana independenti di misa di mana di misa di mana di misa di mana di misa di mana di misa di m | 1                     | 1            | Level 3             | 0  | D/W    | ] /                 |
|         | D2  | PSW0         | Stopwatch timer interrupt priority register                                                                    | 1<br>0                | 0<br>1       | Level 2<br>Level 1  | 0  | R/W    |                     |
|         | D1  | PTM1         | Clark disconsistance desirable and sixty                                                                       | 0                     | 0            | Level 0             | 0  | D/W    |                     |
|         | D0  | PTM0         | Clock timer interrupt priority register                                                                        |                       |              |                     | 0  | R/W    |                     |
| 00FF21  | D7  | -            | _                                                                                                              | -                     |              | -                   | _  | -      |                     |
|         | D6  | _            | _                                                                                                              | _                     |              | -                   | _  | _      | Constantly "0" when |
|         | D5  | _            | _                                                                                                              | _                     |              | -                   | _  | _      | being read          |
|         | D4  | _            | _                                                                                                              | _                     |              | -                   | -  | _      |                     |
|         | D3  | PPT1         | Programmable timer interrupt priority register                                                                 |                       | PPT0<br>PK10 |                     | 0  | R/W    |                     |
|         | D2  | PPT0         | 110grammable timer interrupt priority register                                                                 | 1                     | 1            | Level 3             | 0  | IX VV  |                     |
|         | D1  | PK11         | K10 and K11 interrupt priority register                                                                        | 1<br>0                | 0<br>1       | Level 2<br>Level 1  | 0  | R/W    |                     |
|         | D0  | PK10         | KTO and KTT interrupt priority register                                                                        | 0                     | 0            | Level 0             |    | 10 11  |                     |
| 00FF22  | D7  | _            | _                                                                                                              | _                     |              | -                   | _  | _      | "0" when being read |
|         |     |              | Stopwatch timer 100 Hz interrupt enable register                                                               |                       |              |                     |    |        |                     |
|         |     | ESW10        | Stopwatch timer 10 Hz interrupt enable register                                                                |                       |              |                     |    |        |                     |
|         |     | ESW1         | Stopwatch timer 1 Hz interrupt enable register                                                                 | Interrup              | of           | Interrupt           |    |        |                     |
|         |     | ETM1M        | Clock timer 1/60 Hz interrupt enable register                                                                  | enable                |              | disable             | 0  | R/W    |                     |
|         |     | ETM8         | Clock timer 8 Hz interrupt enable register                                                                     | ciacio                |              |                     |    |        |                     |
|         |     | ETM2         | Clock timer 2 Hz interrupt enable register                                                                     |                       |              |                     |    |        |                     |
|         |     | ETM1         | Clock timer 1 Hz interrupt enable register                                                                     |                       |              |                     |    |        | /                   |
| 00FF23  |     | EPT1         | Programmable timer 1 interrupt enable register                                                                 |                       |              |                     |    |        |                     |
|         |     | EPT0         | Programmable timer 0 interrupt enable register                                                                 |                       |              |                     |    |        |                     |
|         |     | EK1          | K10 and K11 interrupt enable register                                                                          |                       |              |                     |    |        |                     |
|         |     | EK0H         | K04–K07 interrupt enable register                                                                              | Interrup              |              | Interrupt           | 0  | R/W    |                     |
|         |     | EK0L         | K00–K03 interrupt enable register                                                                              | enable                |              | disable             |    |        |                     |
|         |     | ESERR        | Serial I/F (error) interrupt enable register                                                                   |                       |              |                     |    |        |                     |
|         |     | ESREC        | Serial I/F (receiving) interrupt enable register                                                               |                       |              |                     |    |        |                     |
| 00FF24  | D0  | ESTRA        | Serial I/F (transmitting) interrupt enable register                                                            |                       | _            |                     |    |        | O   1 1 1 1         |
| 00FF24  |     | -<br>ECM/100 | Stopwatch timer 100 Hz interrupt factor flag                                                                   | -<br>(D)              |              | -<br>(D)            |    | _      | "0" when being read |
|         |     | FSW100       | Stopwatch timer 100 Hz interrupt factor flag                                                                   | (R)                   | .            | (R)<br>No interrupt |    |        |                     |
|         |     | FSW10        | Stopwatch timer 1 Hz interrupt factor flag                                                                     | Interrup<br>factor is |              | factor is           |    |        |                     |
|         |     | FTM1M        | Clock timer 1/60 Hz interrupt factor flag                                                                      | generate              |              | generated           | 0  | R/W    |                     |
|         |     | FTM8         | Clock timer 8 Hz interrupt factor flag                                                                         | generate              |              | generated           | U  | IX/ VV |                     |
|         |     | FTM2         | Clock timer 2 Hz interrupt factor flag                                                                         | (W)                   |              | (W)                 |    |        |                     |
|         |     | FTM1         | Clock timer 1 Hz interrupt factor flag                                                                         | Reset                 | 1            | No operation        |    |        |                     |
| 00FF25  |     | FPT1         | Programmable timer 1 interrupt factor flag                                                                     | (R)                   |              | (R)                 |    |        |                     |
| 0020    |     | FPT0         | Programmable timer 0 interrupt factor flag                                                                     | Interrup              | of .         | No interrupt        |    |        |                     |
|         |     | FK1          | K10 and K11 interrupt factor flag                                                                              | factor is             |              | factor is           |    |        |                     |
|         |     | FK0H         | K04–K07 interrupt factor flag                                                                                  | generate              |              | generated           |    |        | /                   |
|         |     | FK0L         | K00–K03 interrupt factor flag                                                                                  |                       |              | -21-1-111-1         | 0  | R/W    | /                   |
|         |     | FSERR        | Serial I/F (error) interrupt factor flag                                                                       | (W)                   |              | (W)                 |    |        | /                   |
|         |     | FSREC        | Serial I/F (receiving) interrupt factor flag                                                                   | Reset                 | 1            | No operation        |    |        | /                   |
|         |     | FSTRA        | Serial I/F (transmitting) interrupt factor flag                                                                |                       |              |                     |    |        | /                   |
|         | -   |              |                                                                                                                |                       |              |                     |    |        | v                   |

Refer to the explanations on the respective peripheral circuits for the setting content and control method for each bit.

## 5.16.7 Programming notes

- (1) When executing the RETE instruction without resetting the interrupt factor flag after an interrupt has been generated, the same interrupt will be generated. Consequently, the interrupt factor flag corresponding to that routine must be reset (writing "1") in the interrupt processing routine.
- (2) Beware. If the interrupt flags (I0 and I1) have been rewritten (set to lower priority) prior to resetting an interrupt factor flag after an interrupt has been generated, the same interrupt will be generated again.
- (3) An exception processing vector is fixed at 2 bytes, so it cannot specify a branch destination bank address. Consequently, to branch from multiple banks to a common exception processing routine, the front portion of an exception processing routine must be described within the common area (000000H–007FFFH).

# 5.17 Notes for Low Current Consumption

The E0C88365 can turn circuits, which consume a large amount of power, ON or OFF by control registers.

You can reduce power consumption by creating a program that operates the minimum necessary circuits using these control registers.

Next, which circuit systems' operation can be controlled and their control registers (instructions) are explained. You should refer to these when programming.

See Chapter 7, "ELECTRICAL CHARACTERISTICS" for the current consumption.

Table 5.17.1 Circuit systems and control registers

| Circuit type        | Control register (Instruction) | Status at time of initial resetting |
|---------------------|--------------------------------|-------------------------------------|
| CPU                 | HALT and SLP instructions      | Operation status                    |
| Oscillation circuit | CLKCHG, OSCC                   | OSC1 clock (CLKCHG = "0")           |
|                     |                                | OSC3 oscillation OFF (OSCC = "0")   |
| LCD controller      | LCDC0, LCDC1                   | Drive OFF (LCDC0 = LCDC1 = "0")     |
| SVD circuit         | SVDON, SVDSP                   | OFF status (SVDON = SVDSP = "0")    |
| Analog comparator   | CMP0ON, CMP1ON                 | OFF status (CMP0ON = CMP1ON = "0")  |

## 6 BASIC EXTERNAL WIRING DIAGRAM



#### Recommended values for external parts

| Symbol | Name                          | Recommended value |
|--------|-------------------------------|-------------------|
| RCR3   | Feedback resistor             | 50 kΩ *1          |
| CG1    | Trimmer capacitor             | 5–25 pF *2        |
| C1     | Capacitor between Vss and VD1 | 0.1 μF            |
| C2     | Capacitor between Vss and Vc1 | 0.1 μF            |
| C3     | Capacitor between Vss and Vc2 | 0.1 μF            |
| C4     | Capacitor between Vss and Vc3 | 0.1 μF            |

| Symbol | Name                          | Recommended value                                    |
|--------|-------------------------------|------------------------------------------------------|
| C5     | Capacitor between Vss and Vc4 | 0.1 μF                                               |
| C6     | Capacitor between Vss and Vc5 | 0.1 μF                                               |
| C7-C9  | Booster capacitors            | 0.1 μF                                               |
| СР     | Capacitor for power supply    | 3.3 μF                                               |
| Cres   | Capacitor for RESET terminal  | 0.47 μF                                              |
| R1     | Load resistor between         | $100 \text{ k}\Omega$ (It is needed when             |
|        | Vss and Vc1                   | driving an LCD panel that constitutes a heavy load.) |

- \*1 The CR oscillation frequency changes depending on conditions such as board pattern and elements used.  $50 \text{ k}\Omega$  is only for reference, so select the resistance according to the evaluation using the actual product.
- \*2 CG1 = 5-20 pF (including board capacitance) when fosc1 is 153.6 kHz.

## 7 ELECTRICAL CHARACTERISTICS

The Typ. value that is shown in each item is a projected manufacturing value.

## 7.1 Absolute Maximum Rating

(Vss = 0 V)

| Item                         | Symbol          | Condition              | Rated value        | Unit | Note |
|------------------------------|-----------------|------------------------|--------------------|------|------|
| Power voltage                | V <sub>DD</sub> | _                      | -0.3 to +7.0       | V    | -    |
| Liquid crystal power voltage | VC5             |                        | -0.3 to +7.0       | V    | _    |
| Input voltage                | VI              | _                      | -0.3 to VDD $+0.3$ | V    | _    |
| Output voltage               | Vo              | _                      | -0.3 to VDD $+0.3$ | V    | 1    |
| High level output current    | Іон             | 1 terminal             | -5                 | mA   | _    |
|                              |                 | Total of all terminals | -20                | mA   | _    |
| Low level output current     | Iol             | 1 terminal             | 5                  | mA   | _    |
|                              |                 | Total of all terminals | 20                 | mA   | _    |
| Operating temperature        | Topr            | _                      | -40 to +85         | °C   | _    |
| Storage temperature          | Tstg            | _                      | -65 to +150        | °C   | _    |

Note) 1 Case that to Nch open drain output by the mask option is included.

## 7.2 Recommended Operating Conditions

 $(Vss = 0 V, Ta = -40 to 85^{\circ}C)$ 

| Item                          | Symbol | Condition          | Min. | Тур. | Max. | Unit | Note |
|-------------------------------|--------|--------------------|------|------|------|------|------|
| Operating power voltage       | VDD    | _                  | 2.2  | _    | 5.5  | V    | -    |
| Operating frequency           | fosc1  | VDD = 2.2 to 5.5 V | 30   | _    | 155  | kHz  | 2    |
|                               | fosc3  |                    | 0.03 | _    | 2.5  | MHz  | -    |
| Capacitor between VD1 and Vss | C1     | _                  | _    | 0.1  | _    | μF   | -    |
| Capacitor between VC1 and Vss | C2     | _                  | -    | 0.1  | _    | μF   | -    |
| Capacitor between Vc2 and Vss | C3     | _                  | -    | 0.1  | _    | μF   | -    |
| Capacitor between Vc3 and Vss | C4     | _                  | -    | 0.1  | _    | μF   | -    |
| Capacitor between VC4 and Vss | C5     | _                  | -    | 0.1  | _    | μF   | -    |
| Capacitor between Vc5 and Vss | C6     | _                  | -    | 0.1  | _    | μF   | -    |
| Capacitor between CA and CB   | C7     | _                  | -    | 0.1  | -    | μF   | _    |
| Capacitor between CA and CC   | C8     | _                  | _    | 0.1  | _    | μF   | -    |
| Capacitor between CD and CE   | C9     | _                  | _    | 0.1  | -    | μF   | -    |
| Resistor between VC1 and Vss  | R1     | _                  | -    | 100  | -    | kΩ   | 3    |

Note) 2 When an external clock is input from the OSC1 terminal by the mask option, do not connect anything to the OSC2 terminal.

<sup>3</sup> It is necessary when a large panel is used. The resistance value should be decided by connecting it to the actual panel to be used.

## 7.3 DC Characteristics

Unless otherwise specified: VDD = 2.2 to 5.5 V, Vss = 0 V, Ta = -40 to  $85^{\circ}C$ 

| Item                             | Symbol           | Condition                                                     | Min.   | Тур. | Max.   | Unit | Note |
|----------------------------------|------------------|---------------------------------------------------------------|--------|------|--------|------|------|
| High level input voltage (1)     | VIH1             | Kxx, Pxx, MCU/MPU                                             | 0.8Vdd | -    | Vdd    | V    | -    |
| Low level input voltage (1)      | VIL1             | Kxx, Pxx, MCU/MPU                                             | 0      | -    | 0.2Vdd | V    | _    |
| High level input voltage (2)     | VIH2             | OSC1                                                          | 1.6    | -    | Vdd    | V    | 4    |
| Low level input voltage (2)      | VIL2             | OSC1                                                          | 0      | -    | 0.6    | V    | 4    |
| High level schmitt input voltage | V <sub>T+</sub>  | RESET                                                         | 0.5Vdd | -    | 0.9Vdd | V    | _    |
| Low level schmitt input voltage  | V <sub>T</sub> - | RESET                                                         | 0.1Vdd | -    | 0.5Vdd | V    | _    |
| High level output current (1)    | Іоні             | P1x, Rxx, Voh = 0.9 Vdd                                       | _      | -    | -0.5   | mA   | _    |
| Low level output current (1)     | IOL1             | P1x, $Rxx$ , $Vol = 0.1 Vdd$                                  | 0.5    | -    | _      | mA   | _    |
| High level output current (2)    | Іон2             | P0x                                                           | _      | -    | -0.1   | mA   | _    |
| Low level output current (2)     | IOL2             | P0x                                                           | 0.1    | -    | _      | mA   | _    |
| Input leak current               | ILI              | Kxx, Pxx, RESET, MCU/MPU                                      | -1     | -    | 1      | μΑ   | _    |
| Output leak current              | ILO              | Pxx, Rxx                                                      | -1     | -    | 1      | μΑ   | _    |
| Input pull-up resistance         | RIN              | Kxx, Pxx, RESET, MCU/MPU                                      | 100    | -    | 500    | kΩ   | 5    |
| Input terminal capacitance       | CIN              | Kxx, Pxx                                                      | _      | -    | 15     | pF   | -    |
|                                  |                  | $V_{IN} = 0 \text{ V, } f = 1 \text{ MHz, } Ta = 25^{\circ}C$ |        |      |        |      |      |
| Segment/Common output current    | ISEGH            | SEGxx, COMxx, Vsegh = Vc5-0.1 V                               | _      | _    | -5     | μΑ   | _    |
|                                  | ISEGL            | SEGxx, COMxx, Vsegl = 0.1 V                                   | 5      | -    | _      | μΑ   | _    |

Note) 4 When external clock is selected by mask option.



<sup>5</sup> When addition of pull-up resistor is selected by mask option.

## 7.4 Analog Circuit Characteristics

#### ■ LCD drive circuit

The Typ. values of the LCD drive voltage shown in the following table shift in difference of panel load (panel size, drive duty, display segment number). Therefore, these should be evaluated by connecting to the actual panel to be used. Moreover, if the display is uneven with a large panel load, connect a resistor (R1) between the Vss and Vc1 terminal.

Unless otherwise specified:  $VDD = VC2 (LCX = FH) + 0.3 \text{ to } 5.5 \text{ V}, Vss = 0 \text{ V}, Ta = 25^{\circ}C,$ 

 $C1 = C2 = C3 = C4 = C5 = C6 = C7 = C8 = C9 = 0.1 \ \mu F$ 

| Item              | Symbol | Condition | on       | Min.     | Тур. | Max.     | Unit | Note |
|-------------------|--------|-----------|----------|----------|------|----------|------|------|
| LCD drive voltage | Vc1    | *1        |          | 0.18Vc5  | -    | 0.22Vc5  | V    | _    |
|                   | VC2    | *2        |          | 0.39Vc5  | _    | 0.43Vc5  | V    | -    |
|                   | Vc3    | *3        |          | 0.59Vc5  | _    | 0.63Vc5  | V    | -    |
|                   | VC4    | *4        |          | 0.80Vc5  | _    | 0.84Vc5  | V    | -    |
|                   | VC5    | *5        | LCX = 0H |          | 3.89 |          | V    | _    |
|                   |        |           | LCX = 1H | 1        | 3.96 |          | V    | _    |
|                   |        |           | LCX = 2H | 1        | 4.04 | ]        | V    | -    |
|                   |        |           | LCX = 3H | 1        | 4.11 | ]        | V    | -    |
|                   |        |           | LCX = 4H | 1        | 4.18 | ]        | V    | -    |
|                   |        |           | LCX = 5H | 1        | 4.26 | ]        | V    | -    |
|                   |        |           | LCX = 6H | 1        | 4.34 | ]        | V    | -    |
|                   |        |           | LCX = 7H | Typ×0.94 | 4.42 | Typ×1.06 | V    | -    |
|                   |        |           | LCX = 8H | 1        | 4.50 | ]        | V    | -    |
|                   |        |           | LCX = 9H | 1        | 4.58 | ]        | V    | -    |
|                   |        |           | LCX = AH | 1        | 4.66 | ]        | V    | -    |
|                   |        |           | LCX = BH | 1        | 4.74 | ]        | V    | -    |
|                   |        |           | LCX = CH | 1        | 4.82 | ]        | V    | -    |
|                   |        |           | LCX = DH | 1        | 4.90 | 1        | V    | -    |
|                   |        |           | LCX = EH | 1        | 4.99 |          | V    | -    |
|                   |        |           | LCX = FH | 1        | 5.08 | 1        | V    | -    |

<sup>\*1</sup> Connects 1 M $\Omega$  load resistor between Vss and Vc1. (without panel load)

<sup>\*2</sup> Connects 1 M $\Omega$  load resistor between Vss and Vc2. (without panel load)

<sup>\*3</sup> Connects 1 M $\Omega$  load resistor between Vss and Vc3. (without panel load)

<sup>\*4</sup> Connects 1  $M\Omega$  load resistor between Vss and Vc4. (without panel load)

<sup>\*5</sup> Connects 1  $M\Omega$  load resistor between Vss and Vcs. (without panel load)

#### ■ SVD circuit

Unless otherwise specified: VDD = 2.2 to 5.5 V, Vss = 0 V, Ta = 25°C

| Item        | Symbol | Condition           | Min.      | Тур. | Max.       | Unit | Note |
|-------------|--------|---------------------|-----------|------|------------|------|------|
| SVD voltage | Vsvd   | Level 1 → Level 0   |           | 1.82 |            | V    | _    |
|             |        | Level 2 → Level 1   |           | 2.00 | 1          | V    | _    |
|             |        | Level 3 → Level 2   |           | 2.18 | 1          | V    | _    |
|             |        | Level 4 → Level 3   |           | 2.36 | 1          | V    | _    |
|             |        | Level 5 → Level 4   | Typ×0.92  | 2.54 | Typ×1.08   | V    | _    |
|             |        | Level 6 → Level 5   |           | 2.72 | 1          | V    | _    |
|             |        | Level 7 → Level 6   |           | 2.90 |            | V    | _    |
|             |        | Level 8 → Level 7   |           | 3.08 |            | V    | -    |
|             |        | Level 9 → Level 8   |           | 3.26 |            | V    | -    |
|             |        | Level 10 → Level 9  |           | 3.45 |            | V    | -    |
|             |        | Level 11 → Level 10 |           | 3.65 |            | V    | -    |
|             |        | Level 12 → Level 11 | Typ×0.88  | 3.85 | Trus (1.12 | V    | -    |
|             |        | Level 13 → Level 12 | 1 ypx0.88 | 4.05 | Typ×1.12   | V    | -    |
|             |        | Level 14 → Level 13 | 1         | 4.25 |            | V    | _    |
|             |        | Level 15 → Level 14 |           | 4.50 |            | V    | _    |

## ■ Analog comparator circuit

Unless otherwise specified: VDD = 2.2 to 5.5 V, VSS = 0 V, Ta = 25°C

| Item                             | Symbol            | Condition                                              | Min. | Тур. | Max.      | Unit | Note |
|----------------------------------|-------------------|--------------------------------------------------------|------|------|-----------|------|------|
| Analog comparator                | VCMIP             | Non-inverted input (CMPP)                              | 0.7  | _    | VDD - 0.7 | V    | 6    |
| operating voltage input range    | VCMIM             | Inverted input (CMPM)                                  | 0.7  | -    | VDD - 0.7 | V    | 6    |
| Analog comparator offset voltage | VCMOF             | VCMIP = 0.7 V to VDD - 0.7 V                           | _    | -    | 20        | mV   | 6    |
|                                  |                   | $V_{CMIM} = 0.7 \text{ V}$ to $V_{DD} - 0.7 \text{ V}$ |      |      |           |      |      |
| Analog comparator stability time | t <sub>CMP1</sub> |                                                        | _    | -    | 1         | mS   | 7    |
| Analog comparator response time  | t <sub>CMP2</sub> | VCMIP = 0.7 V to VDD - 0.7 V                           | _    | -    | 2         | mS   | 6    |
|                                  |                   | $V_{CMIM} = 0.7 \text{ V}$ to $V_{DD} - 0.7 \text{ V}$ |      |      |           |      | 8    |
|                                  |                   | $V_{CMIP} = V_{CMIM} \pm 0.025 V$                      |      |      |           |      |      |

Note) 6 When "without pull-up resistor" (comparator input terminal) is selected by mask option.

<sup>7</sup> Stability time is the time from turning the circuit ON until the circuit is stabilized.

<sup>8</sup> Response time is the time that the output result responds to the input signal.

## 7.5 Power Current Consumption

Unless otherwise specified: VDD = 2.2 to 5.5 V, VSS = 0 V,  $Ta = 25^{\circ}$ C, OSC1 = 153.6 kHz crystal oscillation, CG1 = 20 pF, OSC3 = CR oscillation, Non heavy load protection mode, C1 = C2 = C3 = C4 = C5 = C6 = C7 = C8 = C9 = 0.1  $\mu$ F, No panel load

| Item                              | Symbol | Condition                       |    | Min. | Тур. | Max. | Unit | Note |
|-----------------------------------|--------|---------------------------------|----|------|------|------|------|------|
| Power current                     | IDD1   | In SLEEP status                 | *1 | _    | 0.3  | 1    | μΑ   | -    |
|                                   | IDD2   | In HALT status (153.6 kHz)      | *2 | _    | 10   | 25   | μΑ   | -    |
|                                   | IDD3   | CPU is in operating (153.6 kHz) | *3 | -    | 70   | 90   | μΑ   | _    |
|                                   | IDD4   | CPU is in operating (2.5 MHz)   | *4 | _    | 1.5  | 2    | mA   | -    |
|                                   | IHVL   | In heavy load protection mode   |    | _    | 25   | 50   | μΑ   | 9    |
| LCD drive circuit current         | ILCDN  | _                               |    | -    | 2.5  | 5    | μΑ   | -    |
|                                   | ILCDH  | In heavy load protection mode   |    | -    | 15   | 30   | μΑ   | 9    |
| SVD circuit current               | Isvdn  | VDD = 3.0 V                     |    | _    | 30   | 60   | μΑ   | 10   |
|                                   | Isvdh  | In heavy load protection mode   |    | -    | 25   | 75   | μΑ   | 9    |
| Analog comparator circuit current | ICMP1  | CMPXDT = "1"                    |    | _    | 40   | 100  | μΑ   | _    |
|                                   | ICMP2  | CMPXDT = "0"                    |    | _    | 4    | 10   | μΑ   | _    |

\*1 OSC1: Stop, OSC3: Stop,

CPU, ROM, RAM: SLEEP status,

Clock timer: Stop, Ot

Others: Stop status

\*2 OSC1: Oscillating, OSC3: Stop, \*3 OSC1: Oscillating, OSC3: Stop, CPU, ROM, RAM: HALT status, Clock timer: Operating, Others: Stop status CPU, ROM, RAM: Operating in 153.6 kHz, Clock timer: Operating, Others: Stop status

\*4 OSC1: Oscillating, OSC3: Oscillating, CPU, ROM, RAM: Operating in 2.5 MHz, Clock timer: Operating, Others: Stop status

Note) 9 It is the value of current which flows in the heavy load protection circuit when in the heavy load protection mode (OSC3 ON or buzzer ON).

10 The value in x V can be found by the following expression: IsVDN (VDD = x V) = ( $x \times 20$ ) - 30 (Typ. value), IsVDN (VDD = x V) = ( $x \times 30$ ) - 30 (Max. value)

#### 7.6 AC Characteristics

#### ■ Serial interface

#### Clock synchronous master mode

Condition: VDD = 2.2 to 5.5 V, VSS = 0 V, Ta = -40 to  $85^{\circ}$ C, VIH1 = 0.8VDD, VIL1 = 0.2VDD, VOH = 0.8VDD, VOH = 0.8VDD, VOL = 0.2VDD

| Item                                | Symbol | Min. | Тур. | Max. | Unit | Note |
|-------------------------------------|--------|------|------|------|------|------|
| Transmitting data output delay time | tsmd   | _    | _    | 200  | nS   | _    |
| Receiving data input set-up time    | tsms   | 500  | -    |      | nS   | _    |
| Receiving data input hold time      | tsmh   | 200  | _    | _    | nS   | _    |

#### • Clock synchronous slave mode

 $Condition: V \text{DD} = 2.2 \text{ to } 5.5 \text{ V}, \text{Vss} = 0 \text{ V}, \text{Ta} = -40 \text{ to } 85^{\circ}\text{C}, \text{Vihi} = 0.8 \text{Vdd}, \text{Vili} = 0.2 \text{Vdd}, \text{Voh} = 0.8 \text{Vdd}, \text{Vol} = 0.2 \text{V$ 

| Item                                | Symbol | Min. | Тур. | Max. | Unit | Note |
|-------------------------------------|--------|------|------|------|------|------|
| Transmitting data output delay time | tssd   | _    | _    | 500  | nS   | _    |
| Receiving data input set-up time    | tsss   | 200  | _    | _    | nS   | _    |
| Receiving data input hold time      | tssh   | 200  |      | _    | nS   | -    |

#### · Asynchronous system

Condition: VDD = 2.2 to 5.5 V, Vss = 0 V, Ta = -40 to 85°C

| Item                                     | Symbol | Min.           | Тур. | Max.            | Unit | Note |
|------------------------------------------|--------|----------------|------|-----------------|------|------|
| Start bit detection error time           | tsa1   | 0              | _    | <b>t</b> /16    | S    | 11   |
| Erroneous start bit detection range time | tsa2   | 9 <b>t</b> /16 | _    | 10 <b>t</b> /16 | S    | 12   |

Note) 11 Start bit detection error time is a logical delay time from inputting the start bit until internal sampling begins operating.

(Time as far as AC is excluded.)

12 Erroneous start bit detection range time is a logical range to detect whether a LOW level (start bit) has been input again after a start bit has been detected and the internal sampling clock has started.

When a HIGH level is detected, the start bit detection circuit is reset and goes into a wait status until the next start bit. (Time as far as AC is excluded.)



## ■ Input clock

## • SCLK, EVIN input clock

 $\textit{Condition:} \ \ V\text{dd} = 2.2 \ \text{to} \ 5.5 \ \ V, \ \ V\text{ss} = 0 \ \ V, \ \ Ta = -40 \ \ \text{to} \ 85^{\circ}\text{C}, \ \ V\text{ihi} = 0.8 \ \ V\text{dd}, \ \ V\text{ill} = 0.2 \ \ V\text{dd}$ 

| Item                     |                 | System | Min. | Тур. | Max. | Unit | Note |
|--------------------------|-----------------|--------|------|------|------|------|------|
| SCLK input clock time    | Cycle time      | tsccy  | 4    | _    | _    | μS   | _    |
|                          | "H" pulse width | tsch   | 2    | _    | _    | μS   | _    |
|                          | "L" pulse width | tscl   | 2    | _    | _    | μS   | _    |
| EVIN input clock time    | Cycle time      | tevcy  | 1.96 | _    | _    | mS   | _    |
| (With noise rejector)    | "H" pulse width | tevh   | 0.98 | _    | _    | mS   | _    |
|                          | "L" pulse width | tevl   | 0.98 | _    | _    | mS   | _    |
| EVIN input clock time    | Cycle time      | tevcy  | 4    | _    | _    | μS   | _    |
| (Without noise rejector) | "H" pulse width | tevh   | 2    | _    | _    | μS   | _    |
|                          | "L" pulse width | tevl   | 2    | _    | _    | μS   | _    |
| Input clock rising time  |                 | tckr   | _    | _    | 25   | nS   | _    |
| Input clock falling time |                 | tckf   | I    | _    | 25   | nS   | -    |



## • RESET input clock (Normal operating mode)

 $\textit{Condition:} \ V_{DD} = 2.2 \ \text{to} \ 5.5 \ V, \ V_{SS} = 0 \ V, \ T_a = -40 \ \text{to} \ 85^{\circ}\text{C}, \ V_{IH} = 0.5 V_{DD}, \ V_{IL} = 0.1 V_{DD}$ 

| Item             | Symbol | Min. | Тур. | Max. | Unit | Note |
|------------------|--------|------|------|------|------|------|
| RESET input time | tsr    | 100  | -    | -    | μS   | _    |



#### **■** Power ON reset

Condition: Vss = 0 V, Ta = -40 to  $85^{\circ}C$ 

| Item                    | Symbol | Min. | Тур. | Max. | Unit | Note |
|-------------------------|--------|------|------|------|------|------|
| Operating power voltage | Vsr    | 2.4  | -    | -    | V    | _    |
| RESET input time        | tpsr   | 10   | ı    |      | mS   | _    |



- \*1 When the built-in pull up resistor is not used.
- \*2 Because the potential of the  $\overline{RESET}$  terminal not reached VDD level or higher.

#### **■** External memory access

#### Read cycle

 $Condition: \ V \ DD = 2.2 \ to \ 5.5 \ V, \ Vss = 0 \ V, \ Ta = -40 \ to \ 85^{\circ}C, \ Vihi = 0.8 \ Vdd, \ Vill = 0.2 \ Vdd, \ Vihi = 1.6 \ V, \ Vill = 0.6 \ Vdd, \ Vill = 0.6 \ Vdd, \ Volume = 0.6$ 

VOH = 0.8VDD, VOL = 0.2VDD, CL = 100 pF (load capacitance)

| Item                                 | Symbol       | Min.             | Тур. | Max. | Unit | Note |
|--------------------------------------|--------------|------------------|------|------|------|------|
| Address set-up time in read cycle    | tras         | tc+t1-100+n•tc/2 | _    | _    | nS   | -    |
| Address hold time in read cycle      | trah         | th-80            | _    | _    | nS   | -    |
| Read signal pulse width              | trp          | tc-20+n•tc/2     | _    | _    | nS   | _    |
| Data input set-up time in read cycle | trds         | 300              | _    | _    | nS   | _    |
| Data input hold time in read cycle   | <b>t</b> rdh | 0                | _    | _    | nS   | _    |

Substitute the number of states for wait insertion in n.

#### • Write cycle

Condition: VDD = 2.2 to 5.5 V, VSS = 0 V, Ta = -40 to  $85^{\circ}C$ , VIH1 = 0.8 VDD, VIL1 = 0.2 VDD, VIH2 = 1.6 V, VIL2 = 0.6 V,

 $V_{OH} = 0.8V_{DD}$ ,  $V_{OL} = 0.2V_{DD}$ ,  $C_L = 100 pF$  (load capacitance)

| Item                                   | Symbol | Min.          | Тур. | Max.          | Unit | Note |
|----------------------------------------|--------|---------------|------|---------------|------|------|
| Address set-up time in write cycle     | twas   | tc-180        | _    | _             | nS   | -    |
| Address hold time in write cycle       | twah   | th-80         | _    | _             | nS   | -    |
| Write signal pulse width               | twp    | tı-40+n•tc/2  | _    | _             | nS   | -    |
| Data output set-up time in write cycle | twds   | tc-180+n•tc/2 | -    | _             | nS   | _    |
| Data output hold time in write cycle   | twdh   | th-80         | _    | <b>t</b> h+80 | nS   | _    |

Substitute the number of states for wait insertion in n.





<sup>\*</sup> In the case of CR oscillation:  $th = 0.5tc \pm 0.10tc$ ,  $t_1 = tc - th (1/tc: oscillation frequency)$ 

## 7.7 Oscillation Characteristics

Oscillation characteristics change depending on conditions (board pattern, components used, etc.). Use the following characteristics as reference values. The oscillation start time is important because it becomes the wait time when OSC3 clock is used. (If OSC3 is used as CPU clock before oscillation stabilizes, the CPU may malfunction.)

## ■ OSC1 (Crystal)

Unless otherwise specified: VDD = 2.2 to 5.5 V, Vss = 0 V, Ta = 25°C,

Crystal oscillator = C2-TYPE\*1, CG1 = 25 pF, CD1 = Built-in\*2

| Item                              | Symbol | Condition                                              | Min. | Тур. | Max. | Unit  | Note |
|-----------------------------------|--------|--------------------------------------------------------|------|------|------|-------|------|
| Oscillation start time            | tsta   | _                                                      | _    | -    | 3    | S     | 12   |
| External gate capacitance         | CG1    | Including board capacitance                            | 5    | _    | 25   | pF    | 13   |
| Built-in gate capacitance         | CG1    | In case of the chip                                    | _    | 15   | -    | pF    | 14   |
| Built-in drain capacitance        | CD1    | In case of the chip                                    | _    | 15   | -    | pF    | -    |
| Frequency/IC deviation            | ∂f/∂IC | V <sub>DD</sub> = constant                             | -10  | _    | 10   | ppm   | -    |
| Frequency/power voltage deviation | ∂f/∂V  | _                                                      | _    | _    | 1    | ppm/V | -    |
| Frequency adjustment range        | ∂f/∂CG | V <sub>DD</sub> = constant, C <sub>G</sub> = 5 to 25pF | 25   | _    | _    | ppm   | 15   |

- \*1 C2-TYPE Made by Seiko Epson corporation
- \*2 External CD1 (board capacitance etc.) ≤ 8 pF

Note) 12 Cg1 = 20 pF (including board capacitance) when fosc1 is 153.6 kHz.

- 13 When crystal oscillation is selected by the mask option.
  CG1 = 5-20 pF (including board capacitance) when fosc1 is 153.6 kHz.
- 14 When crystal oscillation (gate capacitor built-in) is selected by the mask option.
- 15 C<sub>G1</sub> = 5–20 pF (including board capacitance) when fosc<sub>1</sub> is 153.6 kHz.

## ■ OSC3 (CR)

Unless otherwise specified: VDD = 2.2 to 5.5 V, Vss = 0 V, Ta = -40 to  $85^{\circ}C$ 

| Item                                 | Symbol | Condition      | Min. | Тур. | Max. | Unit | Note |
|--------------------------------------|--------|----------------|------|------|------|------|------|
| Oscillation start time (Normal mode) | tsta   | _              | -    | _    | 1    | mS   | -    |
| Frequency/IC deviation (Normal mode) | ∂f/∂IC | Rcr = constant | -25  | _    | 25   | %    | -    |

## 7.8 Characteristics Curves (reference value)

## ■ High level output current-voltage characteristic (Rxx, P1x ports) Note 1)



## ■ Low level output current-voltage characteristic (Rxx, P1x ports) Note 1)



Note 1) The P0x port has half the drive capability of the Pxx and P1x ports.

## ■ LCD drive voltage-ambient temperature characteristic



## ■ LCD drive voltage-supply voltage characteristic



## ■ LCD drive voltage-load characteristic



## ■ SVD voltage-ambient temperature characteristic



# ■ Power current (During operation with OSC3) <CR oscillation>



# ■ Power current-ambient temperature characteristic (In HALT status fosc1 = 153.6 kHz)



■ Power current-ambient temperature characteristic (CPU is under 153.6 kHz operation)



■ Power current-ambient temperature characteristic (CPU is under 2.5 MHz operation)



# ■ CR oscillation frequency characteristic

Note: Oscillation frequency changes depending on the conditions (components used, board pattern, etc.). In particular, the OSC3 oscillation frequency changes extensively depending on the product form (chip, plastic package or ceramic package) and board capacitance. Therefore, use the following charts for reference only and select the resistance value after evaluating the actual product. (The resistance value should be set to RcR ≥ 15 kΩ.)

# · Oscillation frequency resistor characteristic



# 8 PAD LAYOUT

# 8.1 Diagram of Pad Layout

# E0C88365



Chip thickness: 0.4 mm Pad opening: 100 µm

# 8.2 Pad Coordinates

Table 8.2.1 Pad coordinates (E0C88365)

(Unit: mm)

|     |       |        |       |     |       |        |        |      | es (EUC88 |        |        | I    | I     |       |        |
|-----|-------|--------|-------|-----|-------|--------|--------|------|-----------|--------|--------|------|-------|-------|--------|
| No. | Name  | X      | Y     | No. | Name  | X      | Y      | No.  | Name      | X      | Y      | No.  | Name  | X     | Y      |
| 1   | SEG19 | 3.450  | 3.968 | 48  | SEG66 | -3.624 | 3.400  | 95   | OSC1      | -3.450 | -3.968 | 142  | R17   | 3.624 | -3.400 |
| 2   | SEG20 | 3.240  | 3.968 | 49  | SEG67 | -3.624 | 3.210  | 96   | OSC2      | -3.240 | -3.968 | 143  | R20   | 3.624 | -3.210 |
| 3   | SEG21 | 3.040  | 3.968 | 50  | SEG68 | -3.624 | 3.020  | 97   | TEST      | -3.040 | -3.968 | 144  | R21   | 3.624 | -3.020 |
| 4   | SEG22 | 2.850  | 3.968 | 51  | SEG69 | -3.624 | 2.830  | 98   | RESET     | -2.850 | -3.968 | 145  | R22   | 3.624 | -2.830 |
| 5   | SEG23 | 2.660  | 3.968 | 52  | SEG70 | -3.624 | 2.660  | 99   | MPU       | -2.660 | -3.968 | 146  | R23   | 3.624 | -2.660 |
| 6   | SEG24 | 2.490  | 3.968 | 53  | SEG71 | -3.624 | 2.490  | 100  | K11       | -2.490 | -3.968 | 147  | R24   | 3.624 | -2.490 |
| 7   | SEG25 | 2.320  | 3.968 | 54  | SEG72 | -3.624 | 2.320  | 101  | K10       | -2.320 | -3.968 | 148  | R25   | 3.624 | -2.320 |
| 8   | SEG26 | 2.150  | 3.968 | 55  | SEG73 | -3.624 | 2.150  | 102  | K07       | -2.150 | -3.968 | 149  | R26   | 3.624 | -2.150 |
| 9   | SEG27 | 2.000  | 3.968 | 56  | SEG74 | -3.624 | 2.000  | 103  | K06       | -2.000 | -3.968 | 150  | R27   | 3.624 | -2.000 |
| 10  | SEG28 | 1.850  | 3.968 | 57  | SEG75 | -3.624 | 1.850  | 104  | K05       | -1.850 | -3.968 | 151  | Vss   | 3.624 | -1.850 |
| 11  | SEG29 | 1.700  | 3.968 | 58  | SEG76 | -3.624 | 1.700  | 105  | K04       | -1.700 | -3.968 | 152  | R30   | 3.624 | -1.700 |
| 12  | SEG30 | 1.550  | 3.968 | 59  | SEG77 | -3.624 | 1.550  | 106  | K03       | -1.550 | -3.968 | 153  | R31   | 3.624 | -1.550 |
| 13  | SEG31 | 1.400  | 3.968 | 60  | SEG78 | -3.624 | 1.400  | 107  | K02       | -1.400 | -3.968 | 154  | R32   | 3.624 | -1.400 |
| 14  | SEG32 | 1.260  | 3.968 | 61  | SEG79 | -3.624 | 1.260  | 108  | K01       | -1.260 | -3.968 | 155  | R33   | 3.624 | -1.260 |
| 15  | SEG33 | 1.120  | 3.968 | 62  | COM17 | -3.624 | 1.120  | 109  | K00       | -1.120 | -3.968 | 156  | R34   | 3.624 | -1.120 |
| 16  | SEG34 | 0.980  | 3.968 | 63  | COM16 | -3.624 | 0.980  | 110  | P17       | -0.980 | -3.968 | 157  | R35   | 3.624 | -0.980 |
| 17  | SEG35 | 0.840  | 3.968 | 64  | COM15 | -3.624 | 0.840  | 111  | P16       | -0.840 | -3.968 | 158  | R36   | 3.624 | -0.840 |
| 18  | SEG36 | 0.700  | 3.968 | 65  | COM14 | -3.624 | 0.700  | 112  | P15       | -0.700 | -3.968 | 159  | R37   | 3.624 | -0.700 |
| 19  | SEG37 | 0.560  | 3.968 | 66  | COM13 | -3.624 | 0.560  | 113  | P14       | -0.560 | -3.968 | 160  | R40   | 3.624 | -0.560 |
| 20  | SEG38 | 0.420  | 3.968 | 67  | COM12 | -3.624 | 0.420  | 114  | P13       | -0.420 | -3.968 | 161  | R41   | 3.624 | -0.420 |
| 21  | SEG39 | 0.280  | 3.968 | 68  | COM11 | -3.624 | 0.280  | 115  | P12       | -0.280 | -3.968 | 162  | R42   | 3.624 | -0.280 |
| 22  | SEG40 | 0.140  | 3.968 | 69  | COM10 | -3.624 | 0.140  | 116  | P11       | -0.140 | -3.968 | 163  | R43   | 3.624 | -0.140 |
| 23  | SEG41 | 0.000  | 3.968 | 70  | COM9  | -3.624 | 0.000  | 117  | P10       | 0.000  | -3.968 | 164  | R44   | 3.624 | 0.000  |
| 24  | SEG42 | -0.140 | 3.968 | 71  | COM8  | -3.624 | -0.140 | 118  | P07       | 0.140  | -3.968 | 165  | R45   | 3.624 | 0.140  |
| 25  | SEG43 | -0.280 | 3.968 | 72  | COM7  | -3.624 | -0.280 | 119  | P06       | 0.280  | -3.968 | 166  | R46   | 3.624 | 0.280  |
| 26  | SEG44 | -0.420 | 3.968 | 73  | COM6  | -3.624 | -0.420 | 120  | P05       | 0.420  | -3.968 | 167  | R47   | 3.624 | 0.420  |
| 27  | SEG45 | -0.560 | 3.968 | 74  | COM5  | -3.624 | -0.560 | 121  | P04       | 0.560  | -3.968 | 168  | R50   | 3.624 | 0.560  |
| 28  | SEG46 | -0.700 | 3.968 | 75  | COM4  | -3.624 | -0.700 | 122  | P03       | 0.700  | -3.968 | 169  | R51   | 3.624 | 0.700  |
| 29  | SEG47 | -0.840 | 3.968 | 76  | COM3  | -3.624 | -0.840 | 123  | P02       | 0.840  | -3.968 | 170  | SEG0  | 3.624 | 0.840  |
| 30  | SEG48 | -0.980 | 3.968 | 77  | COM2  | -3.624 | -0.980 | 124  | P01       | 0.980  | -3.968 | 171  | SEG1  | 3.624 | 0.980  |
| 31  | SEG49 | -1.120 | 3.968 | 78  | COM1  | -3.624 | -1.120 | 125  | P00       | 1.120  | -3.968 | 172  | SEG2  | 3.624 | 1.120  |
| 32  | SEG50 | -1.260 | 3.968 | 79  | COM0  | -3.624 | -1.260 | 126  | Vss       | 1.260  | -3.968 | 173  | SEG3  | 3.624 | 1.260  |
| 33  | SEG51 | -1.400 | 3.968 | 80  | CE    | -3.624 | -1.400 | 127  | R00       | 1.400  | -3.968 | 174  | SEG4  | 3.624 | 1.400  |
| 34  | SEG52 | -1.550 | 3.968 | 81  | CD    | -3.624 | -1.550 | 128  | R01       | 1.550  | -3.968 | 175  | SEG5  | 3.624 | 1.550  |
| 35  | SEG53 | -1.700 | 3.968 | 82  | CC    | -3.624 | -1.700 | 129  | R02       | 1.700  | -3.968 | 176  | SEG6  | 3.624 | 1.700  |
| 36  | SEG54 | -1.850 | 3.968 | 83  | СВ    | -3.624 | -1.850 | 130  | R03       | 1.850  | -3.968 |      |       | 3.624 | 1.850  |
| 37  | SEG55 | -2.000 | 3.968 | 84  | CA    | -3.624 | -2.000 |      |           | 2.000  | -3.968 |      | SEG8  | 3.624 | 2.000  |
| 38  | SEG56 | -2.150 | 3.968 | 85  | VC5   | -3.624 | -2.150 | 132  | R05       | 2.150  | -3.968 | 179  | SEG9  | 3.624 | 2.150  |
| 39  | SEG57 | -2.320 | 3.968 | 86  | VC4   | -3.624 | -2.320 | 133  | R06       | 2.320  | -3.968 | 180  | SEG10 | 3.624 | 2.320  |
| 40  | SEG58 | -2.490 | 3.968 | 87  | VC3   | -3.624 | -2.490 | 134  | R07       | 2.490  | -3.968 | 181  | SEG11 | 3.624 | 2.490  |
| 41  | SEG59 | -2.660 | 3.968 | 88  | VC2   | -3.624 | -2.660 | 135  | R10       | 2.660  | -3.968 | 182  | SEG12 | 3.624 | 2.660  |
| 42  | SEG60 | -2.850 | 3.968 | 89  | VC1   | -3.624 | -2.830 | 136  | R11       | 2.850  | -3.968 | 183  | SEG13 | 3.624 | 2.830  |
| 43  | SEG61 | -3.040 | 3.968 | 90  | OSC3  | -3.624 | -3.020 | 137  | R12       | 3.040  | -3.968 | 184  | SEG14 | 3.624 | 3.020  |
| 44  | SEG62 | -3.240 | 3.968 | 91  | OSC4  | -3.624 | -3.210 | 138  | R13       | 3.240  | -3.968 | 185  | SEG15 | 3.624 | 3.210  |
| 45  | SEG63 | -3.450 | 3.968 | 92  | VD1   | -3.624 | -3.400 | 139  | R14       | 3.450  | -3.968 | 186  | SEG16 | 3.624 | 3.400  |
| 46  | SEG64 | -3.624 | 3.810 | 93  | VDD   | -3.624 | -3.600 | 140  | R15       | 3.624  | -3.810 | 187  | SEG17 | 3.624 | 3.600  |
| 47  | SEG65 | -3.624 | 3.600 | 94  | VSS   | -3.624 | -3.810 | 141  |           | 3.624  | -3.600 |      | SEG18 | 3.624 | 3.810  |
| -71 | OLOUJ | J.UZT  | 5.500 | U-T | ¥ JJ  | 3.027  | 3.010  | 1-71 | 1110      | 3.024  | 3.000  | 1.00 | JECTO | 3.024 | 3.010  |

# II E0C88365 Technical Software

# Contents

|    | PREFACE                                                                                                                                                                                                                                                                  |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|    | Description                                                                                                                                                                                                                                                              |
|    | Notes for Program Example Use                                                                                                                                                                                                                                            |
| 1  | SYSTEM INITIALIZATION                                                                                                                                                                                                                                                    |
| 2  | SYSTEM CONTROLLER AND BUS CONTROL                                                                                                                                                                                                                                        |
| 3  | WATCHDOG TIMER                                                                                                                                                                                                                                                           |
| 4  | OSCILLATION CIRCUIT                                                                                                                                                                                                                                                      |
| 5  | INPUT PORT (K PORT)                                                                                                                                                                                                                                                      |
| 6  | OUTPUT PORT (R PORT)                                                                                                                                                                                                                                                     |
| 7  | I/O PORT (P PORT)                                                                                                                                                                                                                                                        |
| 8  | SERIAL INTERFACE 1 (CLOCK SYNCHRONOUS INTERFACE) II-31  (1) Initialization for clock synchronous serial interface (master mode)  (2) Receiving of clock synchronous serial interface (master mode)  (3) Transmitting of clock synchronous serial interface (master mode) |
| 9  | SERIAL INTERFACE 2 (ASYNCHRONOUS INTERFACE)                                                                                                                                                                                                                              |
| 10 | CLOCK TIMER                                                                                                                                                                                                                                                              |
| 11 | STOPWATCH TIMER                                                                                                                                                                                                                                                          |

| <i>12</i> | PROGI   | RAMMABLE TIMER                                                                                                                                          | II-61  |
|-----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------|--------|
|           |         | ) Initialization and interrupt processing for 8-bit reload timer (two channels)                                                                         |        |
|           |         | ) Initialization and interrupt processing for 16-bit one-shot timer (one channel)                                                                       |        |
|           |         | ) Initialization and interrupt processing for 8-bit event counter<br>) Initialization and interrupt processing for 16-bit pulse width measurement timer |        |
|           |         | 1) 16-bit reload timer pulse output                                                                                                                     |        |
| <i>13</i> | LCD C   | ONTROLLER                                                                                                                                               | II-85  |
|           |         | ) Initialization for LCD controller<br>) Display control                                                                                                |        |
| 14        | SOUNI   | D GENERATOR                                                                                                                                             | II-90  |
|           | (1      | ) Initialization for sound generator                                                                                                                    |        |
|           |         | ) Normal buzzer output                                                                                                                                  |        |
|           |         | ) Buzzer output with digital envelope<br>) One-shot buzzer output                                                                                       |        |
| 15        |         | OG COMPARATOR                                                                                                                                           | II-95  |
| 10        |         | ) Initialization for analog comparator                                                                                                                  |        |
|           |         | ) Data reading for analog comparator                                                                                                                    |        |
| <i>16</i> | SVD (S  | SUPPLY VOLTAGE DETECTION) CIRCUIT                                                                                                                       | II-97  |
|           |         | ) Supply voltage detection in 1/4 Hz auto sampling mode                                                                                                 |        |
|           |         | ) Supply voltage detection in continuously sampling mode                                                                                                |        |
| <i>17</i> |         | RUPT (EXCEPTION) PROCESSING                                                                                                                             | II-99  |
|           |         | ) Interrupt level setting and enables interrupt                                                                                                         |        |
|           |         | ) Zero division exception processing<br>) Watchdog timer (NMI) interrupt processing                                                                     |        |
|           |         | ) Interrupt processing for peripheral circuit                                                                                                           |        |
| 18        | EXPAN   | NDED MODE                                                                                                                                               | II-107 |
|           |         | ) Access for program memory outside logical space                                                                                                       |        |
|           |         | ) Data block transfer between pages<br>) Access for data outside page                                                                                   |        |
|           |         |                                                                                                                                                         | 11 110 |
| App       | endix A | Table of E0C88365 Input/Output Port Terminals                                                                                                           | 11-110 |
| App       | endix B | Instruction List                                                                                                                                        | II-111 |
| App       | endix C | Programming Notes                                                                                                                                       | II-128 |

# **PREFACE**

In this part, example of a control programs for each peripheral circuit are described. Basic initialization and control routines are shown in the program examples use a relocatable method and are based on the assumption that the cross assembler asm88 for the E0C88 Family is being used. When you create an application program referring to these examples, use them after completion of the program by adding the necessary functions.

# Description

Program examples are shown by each peripheral circuit or function, according to the following items.

*I/O MAP* Indicates the I/O memory map that

controls the peripheral circuit. See Part I in this manual, "E0C88365 Technical Hardware", for details of the control registers and operation.

Specification Indicates the purpose, function, etc.,

of the example routine.

**Flowchart** Indicates a flowchart of the example.

**Note** Indicates matters that require attention when using the example

routine and for programming of the

peripheral circuit.

Source List A source code listing using the

relocatable method in assembly

language.

See the "E0C88 Core CPU Manual" for details of the instructions and the "E0C88 Family Structured Assembler Manual" for the assembly language and the format of the source list.

# Notes for Program Example Use

Take the following precautions when reading this manual and using the described routines:

(1) Each program example has been modularized as a low-level routine that controls hardware directly, and examples such as a concrete application have not been included. For a routine to be added by the user, an external declaration with a label such as "user\_program" should be made and the program will branch to the label. Because the name "user\_program" is not very descriptive, you should modify the label name to reflect its function.

- (2) In the program examples, 8-bit absolute addressing has been used for I/O memory access. Consequently, the program loads the upper 8 bits (0FFH) of the I/O memory base address (00FF00H) into the BR register. This part in the flowchart is described as (BR setting) and it is set in each program example. If you use another addressing mode, rewriting this part is necessary.
- (3) These routines do not specify bank or page. When using in the expanded mode, set the bank and page if necessary.
- (4) Input, output and I/O port terminals of the E0C88365 are shared the a bus and special output, and these functions are set by software. Be aware that the port configuration will be changed by these setting. Refer to the terminal configuration tables according to the mode and special output settings which have been mentioned in the "Appendix".
- (5) Unary operators set in the asm88 cross assembler have been used for the program examples. These unary operators get the values below from a constant or a label operand.
  - low ... Presents the lower 8 bits of the expression.
  - high.. Returns the upper 8 bits of a 16-bit expression.
  - boc ... Calculates a bank value from the physical address.
  - loc .... Calculates a logical address in a bank from the physical address.
  - pod .. Calculates a page value from the physical address.
  - lod .... Calculates a logical address in a page from the physical address.
- (6) Seiko Epson assumes no responsibility for any consequences arising from the use of the programs described.

# 1 SYSTEM INITIALIZATION

# I/O Map

Refer to the peripheral circuit descriptions in this manual.

# Specification

# Initialization for E0C88365 single chip mode

# mainrt: Initialization for E0C88365 single chip mode

Settings of the base register, CPU mode,  $\overline{\text{CE}}$  output, stack page, stack pointer, wait and bus authority release signal and clearing of RAM (display memory included) are done sequentially.

## Flowchart



#### Notes

- (1) Interrupts have been set to their initial status (all disabled) except for the watchdog timer (NMI) interrupt which cannot be masked.
- (2) Be sure to declare the watchdog timer (NMI) interrupt processing routine and the vector address, regardless of whether or not the watchdog timer is used.
- (3) For peripheral circuit initialization, you must create a separate routine according to the system configuration to be used. (external call: initialize)
- (4) For the interrupt flags (I0 and I1), set them to adapt to the interrupt factor and priority level of the peripheral I/O that will be enabled.
- (5) When using the peripheral I/O interrupt, declare the front address of the peripheral I/O interrupt processing routine in a vector address corresponding to the interrupt in the order of lower and upper. (Vector address: 000006H–000023H)
- (6) Vector addresses 000026H–0000FFH can be set for software interrupts. In this case as well as the above, declare the front address of the software interrupt processing routine in a vector address of the software interrupt in the order of lower and upper.
- (7) The vector addresses 000024H and 000025H cannot be used since this is a system reserved area for the E0C88365.
- (8) In this initialization routine example, the vector address setting and program have been allocated from 000100H for the sake of convenience.

```
Initialization for E0C88365 single chip mode
        external
                    initialize, watchdog_reset
                    user_program
        external
        public
                   mainrt.
                    000000h
                                            reset vector address;
reset_vector equ
                    000100h
main
                                            ;program start address offset
             equ
br_io
                    Offh
                                            ;base reg. address (set i/o area)
              equ
mcu
              equ
                    00ff00h
                                             ;mcu mode system control address
                    00ff01h
                                            ;stack pointer page address
spp
              equ
mode
                    00ff02h
                                            ;mpu//mcu mode control address
              equ
sp_365
              equ
                    00f800h
                                            ;E0C88365 stack pointer top address
internal_ram equ
                    00ec00h
                                            ;E0C88365 internal ram top address
                    00f800h
lcdram_top
              equ
                                            ;lcd ram top address
lcdram_end
              equ
                    00fd5fh
                                            ;lcd ram end address
        code
intr vectors:
        org
              intr_vectors+reset_vector
        dw
             mainrt
                                            ;initial reset program address
        orq
              intr vectors+main
;******
                              ************
; *
; *
        E0C88365 mcu single-chip mode initialize
;*
mainrt:
        1d
              br,#br_io
                                            ;set br reg. address to Offxxh
                                           /single chip mode, /ce3-/ce0 disable
/set stack pointer page to 0
/satck pointer top address set
              [br:low mcu],#00110000b
        ld
              [br:low spp],#00h
        ld
              sp,#lod sp_365
        1d
              [br:low mode],#0000000b
        1d
                                            ;set mode reg.
        ld
              ba,#0000h
                                            ;internal reg. clear
        ld
             hl,#0000h
              ix,#0000h
        ld
;internal ram clear
        carl watchdog_reset
                                            ;watchdog timer reset ***
              iy,#lod internal_ram
                                            ;E0C88365 internal ram top address
        ld
mainrt00:
        ld
              [iy],a
                                            ;clear data set
        inc iy
                                             ;poniter increment
              iy,#lod internal_ram+0c00h
        ср
                                            ;internal ram end ?
        jrs
              nz,mainrt00
;lcd ram clear including ignore area
                                            ;watchdog timer reset ***
;lcd ram top address
        carl watchdog_reset
        ld
              iy,#lod lcdram top
mainrt01:
        ld
              [iy],a
                                             ;clear data set
        inc
                                            ;pointer increment
              iy
              iy, #lod lcdram_end
                                            ;lcd rasm end ?
        CD
             nz,mainrt01
        jrs
;
        carl initialize
                                            ;initialize i/o area ***
            user_program
        jrl
                                            ; jump user program
;start user program
        end
```

# 2 SYSTEM CONTROLLER AND BUS CONTROL

# I/O Map (MCU mode)

| Address | Bit | Name   |              | Fu         | nction      |          |        | 1          | 0           | SR | R/W | Comment             |
|---------|-----|--------|--------------|------------|-------------|----------|--------|------------|-------------|----|-----|---------------------|
| 00FF00  | D7  | BSMD1  | R/W registe  | r          |             |          |        | -          | -           | 0  | R/W |                     |
| (MCU)   | D6  | BSMD0  | Bus mode (   | CPU mod    | le) control |          |        | Expanded   | Single      | 0  | R/W |                     |
|         |     |        |              |            |             |          |        | 512K       | chip        |    |     |                     |
|         | D5  | CEMD1  | R/W registe  | r          |             |          |        | _          | -           | 1  | R/W |                     |
|         | D4  | CEMD0  | R/W registe  | r          |             |          |        | -          | -           | 1  | R/W |                     |
|         | D3  | CE3    | CE3 (R33)    | ]          |             |          |        | CE3 enable | CE3 disable | 0  | R/W | In the Single chip  |
|         | D2  | CE2    | CE2 (R32)    | 1          | al output E |          |        | CE2 enable | CE2 disable | 0  | R/W | mode, these setting |
|         | D1  | CE1    | CE1 (R31)    | 1          | CE signa    | _        |        | CE1 enable | CE1 disable | 0  | R/W | are fixed at DC     |
|         | D0  | CE0    | CE0 (R30)_   | Disable:   | DC (R3x     | () outpu | it     | CE0 enable | CE0 disable | 0  | R/W | output.             |
| 00FF01  | D7  | SPP7   | Stack pointe | er page ad | ldress      | (M       | SB)    | 1          | 0           | 0  | R/W |                     |
|         | D6  | SPP6   |              |            |             |          |        | 1          | 0           | 0  | R/W | /                   |
|         | D5  | SPP5   | < SP page a  | llocatable | e address > | •        |        | 1          | 0           | 0  | R/W |                     |
|         | D4  | SPP4   | Single chi   | p mode: o  | only 0 pag  | e        |        | 1          | 0           | 0  | R/W |                     |
|         | D3  | SPP3   | • 512K mod   | le: (      | 0–27H pag   | ge       |        | 1          | 0           | 0  | R/W |                     |
|         | D2  | SPP2   |              |            |             |          |        | 1          | 0           | 0  | R/W |                     |
|         | D1  | SPP1   |              |            |             |          |        | 1          | 0           | 0  | R/W |                     |
|         | D0  | SPP0   |              |            |             | (LS      | SB)    | 1          | 0           | 0  | R/W |                     |
| 00FF02  | D7  | EBR    | Bus release  | enable re  | gister      |          | K11    | BREQ       | Input port  | 0  | R/W | /                   |
|         | יט  | EDK    | (K11 and R   | 51 termin  | al specific | ation)   | R51    | BACK       | Output port | U  | K/W | /                   |
|         |     |        | Wait contro  | l register |             | Nur      | nber   |            |             |    |     | /                   |
|         | D6  | WT2    | WT2          | WT1        | WT0         | of s     | tate   |            |             |    |     | / /                 |
|         |     |        | 1            | 1          | 1           | 1        | 4      |            |             |    |     | /                   |
|         |     |        | 1<br>1       | 1<br>0     | 0<br>1      |          | 2      |            |             |    |     |                     |
|         | D5  | WT1    | 1            | 0          | 0           |          | 0      | _          | -           | 0  | R/W |                     |
|         |     |        | 0            | 1          | 1           |          | )<br>j |            |             |    |     |                     |
|         |     |        | 0            | 1          | 0           |          | 1      |            |             |    |     |                     |
|         | D4  | WT0    | 0            | 0          | 1           | 2        | 2      |            |             |    |     |                     |
|         |     |        | 0            | 0          | 0           | No       | wait   |            |             |    |     |                     |
|         | D3  | CLKCHG | CPU operat   | ing clock  | switch      |          |        | OSC3       | OSC1        | 0  | R/W |                     |
|         | D2  | oscc   | OSC3 oscill  | lation On  | Off contro  | ol       |        | On         | Off         | 0  | R/W |                     |
|         | D1  | VDC1   | R/W registe  | r          |             |          |        | _          | _           | 0  | R/W | ]/                  |
|         | D0  | VDC0   | R/W registe  | r          |             |          |        | -          |             | 0  | R/W | <u> </u>            |

Note: All the interrupts including  $\overline{\text{NMI}}$  are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

# I/O Map (MPU mode)

| Address | Bit | Name   |              | Fur        | nction       |        |      | 1          | 0           | SR | R/W | Comment |
|---------|-----|--------|--------------|------------|--------------|--------|------|------------|-------------|----|-----|---------|
| 00FF00  | D7  | BSMD1  | R/W registe  | r          |              |        |      | _          | -           | 0  | R/W |         |
| (MPU)   | D6  | BSMD0  | Bus mode (   | CPU mod    | e) control   |        |      | Expanded   | Expanded    | 1  | R/W |         |
|         |     |        |              |            |              |        |      | 512K       | 512K        |    |     |         |
|         | D5  | CEMD1  | R/W registe  | r          |              |        |      | -          | -           | 1  | R/W | / /     |
|         | D4  | CEMD0  | R/W registe  | r          |              |        |      | -          | -           | 1  | R/W | / /     |
|         | D3  | CE3    | CE3 (R33)    | <u></u>    | 1 F          | 11 /15 | . 11 | CE3 enable | CE3 disable | 0  | R/W |         |
|         | D2  | CE2    | CE2 (R32)    | _          | l output En  |        |      | CE2 enable | CE2 disable | 0  | R/W | /       |
|         | D1  | CE1    | CE1 (R31)    |            | CE signal    | •      |      | CE1 enable | CE1 disable | 0  | R/W | /       |
|         | DO  | CE0    | CE0 (R30)_   | Disable:   | DC (R3x)     | outpu  | t    | CE0 enable | CE0 disable | 1  | R/W |         |
| 00FF01  | D7  | SPP7   | Stack pointe | er page ad | dress        | (M     | SB)  | 1          | 0           | 0  | R/W |         |
|         | D6  | SPP6   |              |            |              |        |      | 1          | 0           | 0  | R/W |         |
|         | D5  | SPP5   | < SP page a  | llocatable | address >    |        |      | 1          | 0           | 0  | R/W | /       |
|         | D4  | SPP4   | Single chip  | p mode: c  | nly 0 page   |        |      | 1          | 0           | 0  | R/W |         |
|         | D3  | SPP3   | • 512K mod   | le: C      | –27H page    | :      |      | 1          | 0           | 0  | R/W | /       |
|         | D2  | SPP2   |              |            |              |        |      | 1          | 0           | 0  | R/W | /       |
|         | D1  | SPP1   |              |            |              |        |      | 1          | 0           | 0  | R/W | /       |
|         | D0  | SPP0   |              |            |              | (LS    | SB)  | 1          | 0           | 0  | R/W |         |
| 00FF02  | D7  | EBR    | Bus release  | enable reg | gister       |        | K11  | BREQ       | Input port  | 0  | R/W | /       |
|         | יט  | EDK    | (K11 and R   | 51 termina | al specifica | tion)  | R51  | BACK       | Output port | U  | K/W | /       |
|         |     |        | Wait contro  | l register |              | Nun    | ıber |            |             |    |     | /       |
|         | D6  | WT2    | WT2          | WT1        | WT0          | of s   | tate |            |             |    |     |         |
|         |     |        | 1            | 1          | 1            | 14     |      |            |             |    |     | / /     |
|         |     |        | 1<br>1       | 1<br>0     | 0<br>1       | 12     |      |            |             |    |     | / /     |
|         | D5  | WT1    | 1 1          | 0          | 0            | 10     |      | -          | -           | 0  | R/W | / /     |
|         |     |        | 0            | 1          | 1            | 6      |      |            |             |    |     | / /     |
|         |     |        | 0            | 1          | 0            | 4      |      |            |             |    |     | /       |
|         | D4  | WT0    | 0            | 0          | 1            | 2      |      |            |             |    |     |         |
|         |     |        | 0            | 0          | 0            | No v   | vait |            |             |    |     | /       |
|         | D3  | CLKCHG | CPU operat   | ing clock  | switch       |        |      | OSC3       | OSC1        | 0  | R/W | /       |
|         | D2  | oscc   | OSC3 oscill  | ation On/  | Off control  |        |      | On         | Off         | 0  | R/W | /       |
|         | D1  | VDC1   | R/W registe  | r          |              |        |      | -          | -           | 0  | R/W | ]/      |
|         | D0  | VDC0   | R/W registe  | r          |              |        |      | _          | _           | 0  | R/W | /       |

Note: All the interrupts including  $\overline{\text{NMI}}$  are disabled, until you write the optional value into both the "00FF00H" and "00FF01H" addresses.

# **Specifications**

# System controller settings and bus control

(1) single\_chip: E0C88365 Single chip mode

(2) mpu512k\_max: E0C88365 MPU Expanded 512K maximum mode

Each of the routines sets the system controller and bus as shown in the table below.

Table 2.1 Setting contents of each routine

| Address | Setting item             | (1)         | (2)          |
|---------|--------------------------|-------------|--------------|
| 0FF00H  | CPU mode                 | Single chip | 512K         |
|         | Chip enable mode         | No          | CE3-CE0      |
|         |                          |             | (128K)       |
|         | E signal output          | No          | CE3-CE0      |
| 0FF01H  | Stack page               | Page 0      | Page 27H     |
| 0FF02H  | Bus release (Note)       | No          | Use          |
|         | Wait control             | No          | 0            |
|         | CPU operating clock      | OSC1        | $\leftarrow$ |
|         | OSC3 oscillation circuit | Off         | $\leftarrow$ |
|         | Operating mode           | Normal mode | $\leftarrow$ |

# Flowchart

# System controller settings and bus control (1), (2)



#### Notes

- (1) Prior to any other processing, be sure to set the system controller and bus control in an initialization routine executed immediately after an initial reset.
- (2) When using the MPU mode, the output of  $\overline{\text{CE0}}$  signal is set to valid at initial reset. Be sure not to set the  $\overline{\text{CE0}}$  output to invalid when setting the system controller.
- (3) The CEO-CE3 output terminals are shared with the R30–R33 terminals. Consequently, the terminals which have been set for CE outputs cannot be used as a general purpose output port, including the high impedance control. Moreover, since the output terminals shift to LOW if "0" is written to the R30–R33 registers prior setting the CE outputs, be sure to avoid this.
- (4) When using the bus release function, the K11 and R51 terminals function as the BREQ and BACK terminals, respectively. Consequently, K11 and R51 cannot be used as an input port and a output port.

```
System controller settings and bus control
        external user_program
       public
                   single_chip,mpu512k_max
br_io
                   0ffh
                                          ;base reg. address (set i/o area)
             equ
mcu
                   00ff00h
                                          ;mcu mode system control address
             eau
                   00ff00h
                                          ;mpu mode system control address
ucam
             equ
                   00ff01h
                                          ;stack pointer page address
             equ
                   00ff02h
                                          ;mcu//mpu mode control address
mode
             equ
                                          ;E0C88365 stack pointer
sp_365
             equ
                   00f800h
        code
(1) E0C88365 Single chip mode
; *
         single chip mode with E0C88365
; *
;***********************************
single_chip:
             br,#br_io
                                          ;set br reg. address to Offxxh
                                         single chip mode /ce3-/ce0 disable
        ld
             [br:low mcu],#00110000b
             [br:low spp],#00h
        14
                                         ;set stack pointer page to 0
                                                                                 (1)
        ld
             sp,#lod sp_365
                                          ;stack pointer set
             [br:low mode],#0000000b
                                         ;set mode reg. to initial value
        jrl
            user_program
                                          ; jump user program
(2) E0C88365 MPU Expanded 512K maximum mode
; *
;*
        mpu 512k maximum mode with E0C88365
mpu512k_max:
       ld
             br, #br io
                                         ;set br req. address to Offxxh
                                         mpu 512k mode /ce3-/ce0(128kb) enable
             [br:low mcu],#11111111b
        1 d
             [br:low spp],#27h
        ld
                                          ;set stack pointer page 27h
                                                                                 (2)
                                         stack pointer set
        ld
             sp,#lod sp_365
                                         ;set mode reg. to 0 wait states ;and breq,/back enable
        14
             [br:low mode],#1000000b
:
        jrl
             user_program
                                          ; jump user program
        end
```

# 3 WATCHDOG TIMER

# I/O Map

| Address | Bit | Name   |                                          |                                          | Function                                   | 1                                                                                      | 1     | 0            | SR | R/W | Comment             |
|---------|-----|--------|------------------------------------------|------------------------------------------|--------------------------------------------|----------------------------------------------------------------------------------------|-------|--------------|----|-----|---------------------|
| 00FF40  | D7  | _      | _                                        |                                          |                                            |                                                                                        | -     | _            | _  | _   | "0" when being read |
|         | D6  | FOUT2  | FOUT fr                                  | equency                                  | selection                                  |                                                                                        | -     | _            | 0  | R/W |                     |
|         |     | FOUT1  | FOUT2<br>0<br>0<br>0<br>0<br>1<br>1<br>1 | FOUT1<br>0<br>0<br>1<br>1<br>0<br>0<br>1 | - FOUTO<br>0<br>1<br>0<br>1<br>0<br>1<br>0 | Frequency  fosc1 / 1  fosc1 / 2  fosc1 / 4  fosc1 / 8  fosc3 / 1  fosc3 / 2  fosc3 / 4 |       |              | 0  | R/W |                     |
|         | D3  | FOUTON | FOUT or                                  | itnut con                                | ıtrol                                      | fosc3 / 8                                                                              | On    | Off          | 0  | R/W |                     |
|         | _   | WDRST  |                                          |                                          |                                            |                                                                                        | Reset | No operation |    | W   | Constantly "0" when |
| '       | D1  | TMRST  | Clock tin                                | ner reset                                |                                            |                                                                                        | Reset | No operation | _  | W   | being read          |
|         | D0  | TMRUN  | Clock tin                                | ner Run/                                 | Stop cont                                  | rol                                                                                    | Run   | Stop         | 0  | R/W |                     |

# **Specifications**

# Watchdog timer processing

Vector address setting for watchdog timer (NMI) interrupt

(1) watchdog\_reset:Watchdog timer reset

(2) nmi\_intr: Watchdog timer (NMI) interrupt processing

# Flowchart

# (2) Watchdog timer (NMI) interrupt processing watchdog\_reset (BR setting) Resets watchdog timer Watchdog timer Watchdog timer interrupt processing Register evacuation Register return Register return

# Notes

- (1) Since the watchdog timer  $(\overline{NMI})$  interrupt cannot be masked, be sure to declare the watchdog timer  $(\overline{NMI})$  interrupt processing routine and the vector address, regardless of whether or not the watchdog timer is used.
- (2) In this program example for the watchdog timer, the vector address setting and program have been allocated from 003000H for the sake of convenience.

```
Watchdog timer processing
                 watchdog_reset,nmi_intr
       public
                 000004h
nmi_vector
           equ
                                     ;watchdog /nmi interrupt routine
                                     ;program start address offset
watchdog
                 003000h
           equ
                                     ;base reg. address (set i/o area)
br_io
                 Offh
            equ
                 00ff40h
rtm_mode
            equ
                                     ;timer mode set address
       code
Vector address setting for watchdog timer (NMI) interrupt
intr_vectors:
       ora
            intr_vectors+nmi_vector
       dw
            nmi_intr
(1) Watchdog timer reset
       org intr_vectors+watchdog
; *
; *
       watchdog timer reset
; *
watchdog_reset:
       ld br,#br_io
                                     ;set br reg. address to Offxxh
                                                                       (1)
            [br:low rtm_mode], #00000100b ; watchdogtimer reset
       or
       ret
(2) Watchdog timer (NMI) interrupt processing
; *
       /nmi (watchdog) interrupt routine
;*
;************************************
nmi intr:
      push ale
       /nmi (watchdog) interrupt routine
;
                                                                       (2)
            ale
       pop
       rete
       end
```

# 4 OSCILLATION CIRCUIT

# I/O Map

| Address | Bit | Name              |                                                                  | Function                               |                                                                     | 1            | 0                      | SR | R/W | Comment |
|---------|-----|-------------------|------------------------------------------------------------------|----------------------------------------|---------------------------------------------------------------------|--------------|------------------------|----|-----|---------|
| 00FF02  | D7  | EBR               | Bus release enable (K11 and R51 term                             | C                                      | K11<br>ration) R51                                                  | BREQ<br>BACK | Input port Output port | 0  | R/W |         |
|         | D5  | WT2<br>WT1<br>WT0 | Wait control regis  WT2 WT7  1 1 1  1 0  1 0  0 1  0 1  0 0  0 0 | WT0  1 0 1 0 1 0 1 0 1 0 1 0 1 0 0 0 0 | Number<br>of state<br>14<br>12<br>10<br>8<br>6<br>4<br>2<br>No wait | -            | -                      | 0  | R/W |         |
|         | D3  | CLKCHG            | CPU operating clo                                                | ock switch                             |                                                                     | OSC3         | OSC1                   | 0  | R/W |         |
|         | D2  | oscc              | OSC3 oscillation                                                 | On/Off contro                          | <u>l</u>                                                            | On           | Off                    | 0  | R/W | /       |
|         | D1  | VDC1              | R/W register                                                     |                                        |                                                                     | _            | -                      | 0  | R/W |         |
|         | D0  | VDC0              | R/W register                                                     |                                        |                                                                     | _            | _                      | 0  | R/W | /       |

# **Specifications**

# **CPU clock switching**

(1) osc1toosc3: Switching from OSC1 to OSC3
Switches system clock from OSC1 to OSC3.

(2) osc3toosc1: Switching from OSC3 to OSC1
Switches system clock from OSC3 to OSC1.

# Notes

- (1) Delay routine for the OSC3 oscillation stabilization waiting time is not included in this program example, so it is necessary to create it separately using a hardware timer or software timer. (external call: osc3\_delay)
- (2) Pay special attention the delay routine setting since the OSC3 oscillation stabilization waiting time varies somewhat depending on the oscillator and externally attached parts used.

## Flowchart



```
CPU clock switching
       external
                 osc3_delay
       public
                 osc1toosc3,osc3toosc1
br_io
            equ
                 0ffh
                                       ;base reg. address (set i/o area)
mode
            equ
                 00ff02h
                                       ;mcu//mpu mode control address
       code
(1) Switching from OSC1 to OSC3
; *
;* change osc1 to osc3
osc1toosc3:
            br,#br_io
                                      ;set br reg. address to Offxxh
       ld
            [br:low mode],#00000100b
       or
                                      osc3 clock on
       carl osc3_delay
                                      ;osc3 start up delay ***
                                                                         (1)
            [br:low mode],#00001000b
       or
                                      ; change system clock to osc3
            osc1toosc301
       jrs
osc1toosc301:
       ret
(2) Switching from OSC3 to OSC1
;* change osc3 to osc1
osc3toosc1:
       ld
            br, #br_io
                                      ;set br reg. address to Offxxh
            [br:low mode],#11110111b
                                     ;change system clock to osc1
;osc3 clock off
       and
                                                                          (2)
       and
            [br:low mode],#11111011b
       ret
;
       end
```

# 5 INPUT PORTS (K PORTS)

# I/O Map

| Address | Bit | Name  | Function                          | 1          | 0         | SR       | R/W          | Comment             |
|---------|-----|-------|-----------------------------------|------------|-----------|----------|--------------|---------------------|
| 00FF50  | D7  | SIK07 | K07 interrupt selection register  |            |           |          |              |                     |
|         | D6  | SIK06 | K06 interrupt selection register  |            |           |          |              |                     |
|         | D5  | SIK05 | K05 interrupt selection register  |            |           |          |              | / /                 |
|         | D4  | SIK04 | K04 interrupt selection register  | Interrupt  | Interrupt |          | D /11/       |                     |
|         | D3  | SIK03 | K03 interrupt selection register  | enable     | disable   | 0        | R/W          |                     |
|         | D2  | SIK02 | K02 interrupt selection register  |            |           |          |              |                     |
|         | D1  | SIK01 | K01 interrupt selection register  |            |           |          |              |                     |
|         | D0  | SIK00 | K00 interrupt selection register  |            |           |          |              |                     |
| 00FF51  | D7  | _     | _                                 | _          | -         | -        | -            |                     |
|         | D6  | _     | _                                 | _          | _         | -        | _            |                     |
|         | D5  | _     | _                                 | _          | _         | -        | -            | Constantly "0" when |
|         | D4  | _     | _                                 | _          | _         | -        | -            | being read          |
|         | D3  | _     | _                                 | _          | _         | _        | -            |                     |
|         | D2  | _     | _                                 | _          | -         | _        | _            |                     |
|         | D1  | SIK11 | K11 interrupt selection register  | Interrupt  | Interrupt |          |              |                     |
|         | D0  | SIK10 | K10 interrupt selection register  | enable     | disable   | 0        | R/W          |                     |
| 00FF52  | D7  | KCP07 | K07 interrupt comparison register |            |           |          |              |                     |
|         | D6  | KCP06 | K06 interrupt comparison register |            |           |          |              | /                   |
|         | D5  | KCP05 | K05 interrupt comparison register | Interrupt  | Interrupt |          |              |                     |
|         | D4  | KCP04 | K04 interrupt comparison register | generated  | generated |          |              |                     |
|         |     |       | K03 interrupt comparison register | at falling | at rising | 1        | R/W          |                     |
|         | D2  |       | K02 interrupt comparison register | edge       | edge      |          |              |                     |
|         | D1  |       | K01 interrupt comparison register |            |           |          |              |                     |
|         | D0  | KCP00 | K00 interrupt comparison register |            |           |          |              |                     |
| 00FF53  | D7  | _     | _                                 | _          | _         | _        | _            |                     |
|         | D6  | _     | _                                 | _          | _         | _        | _            |                     |
|         | D5  | _     | _                                 | _          | _         | _        | _            | Constantly "0" when |
|         | D4  | _     | _                                 | _          | _         | _        | _            | being read          |
|         | D3  | _     | _                                 | _          | _         | _        | _            |                     |
|         | D2  | _     | _                                 | _          | _         | _        | _            | -                   |
|         | D1  | KCP11 | K11 interrupt comparison register | Falling    | Rising    |          |              |                     |
|         | D0  | KCP10 | K10 interrupt comparison register | edge       | edge      | 1        | R/W          |                     |
| 00FF54  | D7  | K07D  | K07 input port data               |            |           |          |              |                     |
|         |     | K06D  | K06 input port data               |            |           | -        |              |                     |
|         | D5  | K05D  | K05 input port data               |            |           |          |              |                     |
|         | D4  | K04D  | K04 input port data               | High level | Low level |          |              |                     |
|         | D3  | K03D  | K03 input port data               | input      | input     | 0        | R            |                     |
|         |     | K02D  | K02 input port data               | -          |           |          |              |                     |
|         |     | K01D  | K01 input port data               |            |           |          |              | /                   |
|         |     | K00D  | K00 input port data               |            |           |          |              | /                   |
| 00FF55  | D7  | _     | _                                 | _          | _         | _        | <b> </b>     |                     |
|         | D6  | _     | _                                 | _          | _         | <u> </u> | <u> </u>     |                     |
|         | D5  | _     | _                                 | _          | _         | <u> </u> | _            | Constantly "0" when |
|         | D4  |       | _                                 | _          | _         | -        | _            | being read          |
|         | D3  |       | _                                 | _          | _         | <u> </u> | <del> </del> |                     |
|         | D2  |       | _                                 | _          | _         | <u> </u> | _            |                     |
|         | _   | K11D  | K11 input port data               | High level | Low level |          |              |                     |
|         |     | K10D  | K10 input port data               | input      | input     | -        | R            |                     |
| $\Box$  | 20  |       | 1110 Input port data              | mput       | прис      | 1        | 1            |                     |

# I/O Map

| Address | Bit | Name  | Function                                            | 1            |            | 0                  | SR | R/W    | Comment             |
|---------|-----|-------|-----------------------------------------------------|--------------|------------|--------------------|----|--------|---------------------|
| 00FF20  | D7  | PK01  | WOO WOOD                                            |              |            |                    | 0  | D/III  | /                   |
|         | D6  | PK00  | K00–K07 interrupt priority register                 | PK01         | PK0        | 0                  | 0  | R/W    |                     |
|         | D5  | PSIF1 |                                                     | PSIF1        |            |                    | _  |        | 1 /                 |
|         | D4  | PSIF0 | Serial interface interrupt priority register        | PSW1<br>PTM1 |            |                    | 0  | R/W    |                     |
|         | D3  | PSW1  |                                                     | 1            | 1          | Level 3            |    |        | 1 /                 |
|         | D2  | PSW0  | Stopwatch timer interrupt priority register         | 1 0          | 0          | Level 2<br>Level 1 | 0  | R/W    |                     |
|         | D1  | PTM1  |                                                     | 0            | 0          | Level 0            |    | D /II/ | 1 /                 |
|         | D0  | PTM0  | Clock timer interrupt priority register             |              |            |                    | 0  | R/W    | /                   |
| 00FF21  | D7  | _     | _                                                   | -            |            | -                  | _  | _      |                     |
|         | D6  | _     | _                                                   | -            |            | -                  | _  | _      | Constantly "0" when |
|         | D5  | _     | _                                                   | -            |            | -                  | _  | _      | being read          |
|         | D4  | _     | _                                                   | -            |            | -                  | _  | _      |                     |
|         | D3  | PPT1  | Programmable timer interrupt priority register      | PPT1         | PPT<br>PK1 |                    | 0  | R/W    |                     |
|         | D2  | PPT0  | Programmable timer interrupt priority register      | PK11<br>1    | 1          | Level 3            | U  | K/W    |                     |
|         | D1  | PK11  | K10 and K11 interrupt priority register             | 1 0          | 0          | Level 2<br>Level 1 | 0  | R/W    |                     |
|         | D0  | PK10  | KTO and KTT interrupt priority register             | 0            | 0          | Level 0            | U  | K/W    |                     |
| 00FF23  | D7  | EPT1  | Programmable timer 1 interrupt enable register      |              |            |                    |    |        | /                   |
|         | D6  | EPT0  | Programmable timer 0 interrupt enable register      |              |            |                    |    |        |                     |
|         | D5  | EK1   | K10 and K11 interrupt enable register               |              |            |                    |    |        | /                   |
|         | D4  | EK0H  | K04–K07 interrupt enable register                   | Interr       | upt        | Interrupt          | 0  | R/W    |                     |
|         | D3  | EK0L  | K00-K03 interrupt enable register                   | enab         | ole        | disable            | U  | IN/ W  |                     |
|         | D2  | ESERR | Serial I/F (error) interrupt enable register        |              |            |                    |    |        |                     |
|         | D1  | ESREC | Serial I/F (receiving) interrupt enable register    |              |            |                    |    |        |                     |
|         | D0  | ESTRA | Serial I/F (transmitting) interrupt enable register |              |            |                    |    |        | /                   |
| 00FF25  | D7  | FPT1  | Programmable timer 1 interrupt factor flag          | (R)          | )          | (R)                |    |        |                     |
|         | D6  | FPT0  | Programmable timer 0 interrupt factor flag          | Interr       | upt        | No interrupt       |    |        | /                   |
|         | D5  | FK1   | K10 and K11 interrupt factor flag                   | facto        | r is       | factor is          |    |        | /                   |
|         | D4  | FK0H  | K04–K07 interrupt factor flag                       | genera       | ated       | generated          | 0  | R/W    | /                   |
|         | D3  | FK0L  | K00-K03 interrupt factor flag                       |              |            |                    | U  | IV W   | /                   |
|         | D2  | FSERR | Serial I/F (error) interrupt factor flag            | (W           | )          | (W)                |    |        | /                   |
|         | D1  | FSREC | Serial I/F (receiving) interrupt factor flag        | Res          | et         | No operation       |    |        | /                   |
|         | D0  | FSTRA | Serial I/F (transmitting) interrupt factor flag     |              |            |                    |    |        | V                   |

# **Specifications**

# Control of input port (K port )

Vector address setting for input port (K port) interrupt

(1) input\_normal: Data reading from normal input port (K port)

# (2) input\_keyscan: Key scan for 8 x 2 key matrix

Assumes the key matrix has been configured with input and output as shown in Figure 5.1, and specifies the key pressed and then stores the data into the RAM area named key\_data.

# <Conditions>

K07–K00 ports: Input with pull-up resistor (mask option setting)
R01, R00 ports: Nch open drain output (mask option setting)

key data: 1 word





Fig. 5.1 Key matrix

(3) input\_keywait, input\_keyintr: Interrupt condition setting and interrupt processing for input port (K port)
Generates an IRQ3 interrupt when changing the input port K10 and K11 from HIGH to LOW.



Fig. 5.2 Interrupt generation timing

# Flowchart



## Notes

- (1) When the pull-up resistor option has been set to "with resistor", a delay in the waveform rise time will occur depending on the time constant of the input gate capacitance when changing the input terminal from LOW to HIGH. For this reason, set an appropriate wait time (for reference, approximately 500 µsec) for the introduction of the input port. In particular, special attention should be paid to key scanning for key matrix formation.
- (2) Note that the K11 terminal cannot be used as an input port when the K11 terminal has been set for input of the bus release request (BREQ) signal.
  See Part I in this manual, "E0C88365 Technical Hardware", for details of the bus release sequence.
- (3) The K10 terminal doubles as the input terminal of the programmable timer/event counter with input port functions sharing the input signal as it is. For this reason, when the K10 terminal has been set to the input terminal of the programmable timer/event counter, pay attention to interrupt setting. See "12 PROGRAMMABLE TIMER", for the control of the programmable timer/event counter.
- (4) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (5) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ3 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (6) The K00 to K05 ports have a noise rejecter. It is not included in the K06, K07, K10 and K11 ports. When reading data from the port without the noise rejecter using the interrupt, interrupts may occur in succession because of noise, such as key chattering. For this reason, some measure must be devised such as adding noise reject processing in software or with an external.
- (7) In this program example for input port (K port), the vector address setting and program have been allocated from 003000H for the sake of convenience.

## Source List

# Control of input port (K port)

```
external
                      scan_delay
                      input_normal,input_keyscan,input_keywait,input_keyintr
         public
         public
                     key_data
k1x_vector
                      00000ah
                                                ;klx interrupt vector address offset
               eau
                      003000h
keyinput
                                                iprogram start address offset
               equ
br_io
               equ
                      Offh
                                                ;base reg. address (set i/o area)
sik1
               equ
                      00ff51h
                                                ;interrupt selection reg. for klx
                      00ff53h
                                               ;interrupt comparison reg. for klx
kcp1
               equ
                      00ff54h
                                               ;input port data from k0x
kOd
               equ
k1d
               eau
                      00ff55h
                                               ;input port data from klx
r0d
                      00ff73h
                                               ;r0x output data
               equ
intr_pr1
                      00ff21h
                                               ;interrupt priority reg. 0
               equ
intr_en1
               equ
                      00ff23h
                                                ;interrupt enable reg. 0
                                                ;interrupt factor flag reg. 0
intr_fac1
                      00ff25h
               equ
        data
key_data:
               dw
                      [1]
        code
```

```
Vector address setting for input port (K port) interrupt
intr vectors:
       org
            intr_vectors+k1x_vector
      dw
            input_keyintr
                                     ;klx interrupt processing routine
(1) Data reading from normal input port (K port)
       orq
          intr vectors+keyinput
;*
; *
       k(input) port read (normal)
; *
         a <- k0x(complementary)</pre>
; *
         b <- klx(complementary)</pre>
input_normal:
       ld
            br,#br_io
                                    ;set br reg. address to Offxxh
       ld
            a,[br:low k0d]
                                     ;k07-00 port read
                                                                       (1)
            b,[br:low kld]
                                     ;k11-00 port read
       1 d
       ret
(2) Key scanning on 8 x 2 key matrix
;************************
; *
; *
       k(input) port read (key scan)
; *
         k07 k06 k05 k04 k03 k02 k01 k00(pull up)
         r00(n-ch. o.d)
; *
         r01(n-ch. o.d)
; *
; *
         key data+0(r10) <- k07 k06 k05 k04 k03 k02 k01 k00
; *
         key_data+1(r11) <- r07 k06 k05 k04 k03 k02 k01 k00
; *
input_keyscan:
       ld
                                     ;set br reg. address to Offxxh
           br,#br_io
       and
            [br:low r0d],#11111110b
                                    ;r00 key scan output
;k0x port read
            a,[br:low k0d]
       ld
       ld
            [lod key_data+0],a
                                     ;key_data save
                                                                       (2)
                                     ;key scan delay ***
       carl
            scan_delay
       and
            [br:low r0d],#11111101b
                                     ;r01 key scan output
       ld
            a,[br:low k0d]
                                     ;k0x port read
       ld
            [lod key_data+1],a
                                     ;key_data save
       carl scan_delay
                                     ;key scan delay ***
       ret
(3) Interrupt condition setting and interrupt processing for input port (K port)
; *
;*
       k(input) port read (interrupt)
; *
       kl1,10 <- /irg3 falling edge ("h" - "l") interrupt
;*
input_keywait:
       1d
           br,#br_io
                                    ;set br reg. address to Offxxh
;set pk11 and 10 to /irq3
            [br:low intr_pr1],#00000011b
       or
                                                                       (3)
           ld
       ld
```

```
ld
         [br:low r0d],#00000000b ;waiting key on r0d scan low output
         a,sc
      and a,#00111111b
          a,#10000000b
      or
      ld
         sc,a
                               ;i0 flag clear (en. /irq3 intr.)
;waiting kl1,10 interrupt
(3)
;*
     klx interrupt processing routine
; *
input_keyintr:
     push ale
     kll and 10 interrupt processing routine
;
          [br:low intr_fac1], #00100000b ;clear fk1 (k11,10) flag
      pop
     rete
      end
```

# 6 OUTPUT PORTS (R PORTS)

# I/O Map

| Address | Bit | Name  | Function                       | 1         | 0       | SR | R/W   | Comment    |
|---------|-----|-------|--------------------------------|-----------|---------|----|-------|------------|
| 00FF70  | D7  | HZR51 | R51 high impedance control     | High      | Comple- | 0  | D/W   |            |
|         | D6  | HZR50 | R50 high impedance control     | impedance | mentary | 0  | R/W   |            |
|         | D5  | HZR4H | R44–R47 high impedance control | High      | Comple- | 0  | D/W   | /          |
|         | D4  | HZR4L | R40–R43 high impedance control | impedance | mentary | 0  | R/W   | / <b> </b> |
|         | D3  | HZR1H | R14–R17 high impedance control |           |         |    |       | /          |
|         | D2  | HZR1L | R10–R13 high impedance control | High      | Comple- |    | D AV  | /          |
|         | D1  | HZR0H | R04–R07 high impedance control | impedance | mentary | 0  | R/W   | /          |
|         | D0  | HZR0L | R00–R03 high impedance control |           |         |    |       |            |
| 00FF71  | D7  | HZR27 | R27 high impedance control     |           |         |    |       |            |
|         | D6  | HZR26 | R26 high impedance control     |           |         |    |       | /          |
|         | D5  | HZR25 | R25 high impedance control     |           |         |    |       | / <b> </b> |
|         | D4  | HZR24 | R24 high impedance control     | High      | Comple- | 0  | R/W   | / <b> </b> |
|         | D3  | HZR23 | R23 high impedance control     | impedance | mentary | 0  | K/W   | /          |
|         | D2  | HZR22 | R22 high impedance control     |           |         |    |       | /          |
|         | D1  | HZR21 | R21 high impedance control     |           |         |    |       | /          |
|         | D0  | HZR20 | R20 high impedance control     |           |         |    |       |            |
| 00FF72  | D7  | HZR37 | R37 high impedance control     |           |         |    |       |            |
|         | D6  | HZR36 | R36 high impedance control     |           |         |    |       | /          |
|         | D5  | HZR35 | R35 high impedance control     |           |         |    |       | /          |
|         | D4  | HZR34 | R34 high impedance control     | High      | Comple- |    | D AV  | / <b> </b> |
|         | D3  | HZR33 | R33 high impedance control     | impedance | mentary | 0  | R/W   | /          |
|         | D2  | HZR32 | R32 high impedance control     |           |         |    |       | /          |
|         | D1  | HZR31 | R31 high impedance control     |           |         |    |       | /          |
|         | D0  | HZR30 | R30 high impedance control     |           |         |    |       | / I        |
| 00FF73  | D7  | R07D  | R07 output port data           |           |         |    |       |            |
|         | D6  | R06D  | R06 output port data           |           |         |    |       |            |
|         | D5  | R05D  | R05 output port data           |           |         |    |       | / <b> </b> |
|         | D4  | R04D  | R04 output port data           | TT: -1-   | T       | 1  | R/W   | / <b> </b> |
|         | D3  | R03D  | R03 output port data           | High      | Low     | 1  | K/W   | /          |
|         | D2  | R02D  | R02 output port data           |           |         |    |       | /          |
|         | D1  | R01D  | R01 output port data           |           |         |    |       | /          |
|         | D0  | R00D  | R00 output port data           |           |         |    |       |            |
| 00FF74  | D7  | R17D  | R17 output port data           |           |         |    |       |            |
|         | D6  | R16D  | R16 output port data           |           |         |    |       |            |
|         | D5  | R15D  | R15 output port data           |           |         |    |       | / <b> </b> |
|         | D4  | R14D  | R14 output port data           | High      | Low     | 1  | R/W   | / <b> </b> |
|         | D3  | R13D  | R13 output port data           | High      | Low     | 1  | IN/ W | /          |
|         | D2  | R12D  | R12 output port data           |           |         |    |       | /          |
|         | D1  | R11D  | R11 output port data           |           |         |    |       | /          |
|         | D0  | R10D  | R10 output port data           |           |         |    |       |            |
| 00FF75  | D7  | R27D  | R27 output port data           |           |         |    |       |            |
|         | D6  | R26D  | R26 output port data           |           |         |    |       |            |
|         | D5  | R25D  | R25 output port data           |           |         |    |       | / <b> </b> |
|         | D4  | R24D  | R24 output port data           | High      | Low     | 1  | R/W   | / <b> </b> |
|         | D3  | R23D  | R23 output port data           | High      | LOW     | 1  | IX/ W | / <b> </b> |
|         | D2  | R22D  | R22 output port data           |           |         |    |       | / <b> </b> |
|         | D1  | R21D  | R21 output port data           |           |         |    |       | / <b> </b> |
|         | D0  | R20D  | R20 output port data           |           |         |    |       | <u>/</u>   |
| -       |     |       |                                |           |         |    |       |            |

# I/O Map

| Address | Bit           | Name   | Function                                  | 1               | 0                     | SR | R/W   | Comment             |
|---------|---------------|--------|-------------------------------------------|-----------------|-----------------------|----|-------|---------------------|
| 00FF76  | D7            | R37D   | R37 output port data                      |                 |                       |    |       | /                   |
|         | D6            | R36D   | R36 output port data                      |                 |                       |    |       |                     |
|         | D5            | R35D   | R35 output port data                      |                 |                       |    |       | /                   |
|         | D4            | R34D   | R34 output port data                      |                 | _                     |    | D 411 | /                   |
|         | D3            | R33D   | R33 output port data                      | High            | Low                   | 1  | R/W   |                     |
|         | D2            | R32D   | R32 output port data                      |                 |                       |    |       |                     |
|         | D1            | R31D   | R31 output port data                      |                 |                       |    |       |                     |
|         | D0            | R30D   | R30 output port data                      |                 |                       |    |       |                     |
| 00FF77  | D7            | R47D   | R47 output port data                      |                 |                       |    |       | /                   |
|         | D6            | R46D   | R46 output port data                      |                 |                       |    |       |                     |
|         | D5            | R45D   | R45 output port data                      |                 |                       |    |       | /                   |
|         | D4            | R44D   | R44 output port data                      |                 |                       |    |       | /                   |
|         | D3            | R43D   | R43 output port data                      | High            | Low                   | 1  | R/W   |                     |
|         | D2            | R42D   | R42 output port data                      |                 |                       |    |       |                     |
|         | D1            | R41D   | R41 output port data                      |                 |                       |    |       |                     |
|         | D0            | R40D   | R40 output port data                      |                 |                       |    |       |                     |
| 00FF78  | D7            | _      | _                                         | -               | _                     | _  | _     |                     |
|         | D6            | _      | _                                         | _               | _                     | _  | _     |                     |
|         | D5            | _      | _                                         | -               | _                     | _  | _     | Constantly "0" when |
|         | D4            | _      | _                                         | _               | _                     | _  | _     | being read          |
|         | D3            | _      | _                                         | _               | _                     | _  | _     |                     |
|         | D2            | _      | _                                         | _               | _                     | _  | _     |                     |
|         | D1            | R51D   | R51 output port data                      | High            | Low                   | 1  | R/W   |                     |
|         | D0            | R50D   | R50 output port data                      | High            | Low                   | 0  | R/W   |                     |
| 00FF10  | D7            | _      | _                                         | -               | -                     | _  | -     |                     |
|         | D6            | _      | =                                         | -               | -                     | _  | -     | Constantry "0" when |
|         | D5            | _      | _                                         | -               | -                     | -  | _     | being read          |
|         | D4            | LCCLK  | CL output control for expanded LCD driver | On              | Off                   | 0  | R/W   |                     |
|         | D3            | LCFRM  | FR output control for expanded LCD driver | On              | Off                   | 0  | R/W   |                     |
|         | D2            | DTFNT  | R/W register                              | -               | -                     | 0  | R/W   |                     |
|         | D1            | LDUTY  | R/W register                              | -               | _                     | 0  | R/W   |                     |
|         | D0            | SGOUT  | R/W register                              | -               | -                     | 0  | R/W   |                     |
| 00FF30  | D7            | _      | -                                         | -               | -                     | -  | _     | Constantry "0" when |
|         | D6            | _      | _                                         | -               | _                     | _  | _     | being read          |
|         | D5            | _      | =                                         | -               | -                     | _  | _     |                     |
|         | D4            | MODE16 | 8/16-bit mode selection                   | 16-bit x 1      | 8-bit x 2             | 0  | R/W   |                     |
|         | D3            | CHSEL  | TOUT output channel selection             | Timer 1         | Timer 0               | 0  | R/W   |                     |
|         | D2            | PTOUT  | TOUT output control                       | On              | Off                   | 0  | R/W   |                     |
|         | D1            | CKSEL1 | Prescaler 1 source clock selection        | fosc3           | fosci                 | 0  | R/W   |                     |
|         | D0            | CKSEL0 | Prescaler 0 source clock selection        | fosc3           | foscı                 | 0  | R/W   |                     |
| 00FF44  | D7            | _      | _                                         | -               | -                     | _  | _     | Constantry "0" when |
|         | D6            | BZSTP  | One-shot buzzer forcibly stop             | Forcibly stop   | No operation          | _  | W     | being read          |
|         | D5            | BZSHT  | One-shot buzzer trigger/status R          | Busy<br>Trigger | Ready<br>No operation | 0  | R/W   |                     |
|         | D4            | SHTPW  | One-shot buzzer duration width selection  | 125 msec        | 31.25 msec            | 0  | R/W   |                     |
|         |               | ENRTM  | Envelope attenuation time                 | 1 sec           | 0.5 sec               | 0  | R/W   |                     |
|         |               | ENRST  | Envelope reset                            | Reset           | No operation          | _  | W     | "0" when being read |
|         |               | ENON   | Envelope On/Off control                   | On              | Off                   | 0  | R/W   |                     |
|         | $\overline{}$ | BZON   | Buzzer output control                     | On              | Off                   | 0  | R/W   |                     |

<sup>\*1</sup> Reset to "0" during one-shot output.

I/O Map

| Address | Bit | Name   | Function                                 |                                          | 1                                        | 0                                                                                                 | SR           | R/W | Comment |                     |                     |
|---------|-----|--------|------------------------------------------|------------------------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------|--------------|-----|---------|---------------------|---------------------|
| 00FF40  | D7  | _      | _                                        |                                          |                                          |                                                                                                   | -            | -   | _       | _                   | "0" when being read |
|         | D6  | FOUT2  | FOUT fro                                 | equency                                  | selection                                |                                                                                                   | -            | -   | 0       | R/W                 |                     |
|         |     | FOUT1  | FOUT2<br>0<br>0<br>0<br>0<br>1<br>1<br>1 | FOUT1<br>0<br>0<br>1<br>1<br>0<br>0<br>1 | FOUT0<br>0<br>1<br>0<br>1<br>0<br>1<br>0 | Frequency  fosc1 / 1  fosc1 / 2  fosc1 / 4  fosc1 / 8  fosc3 / 1  fosc3 / 2  fosc3 / 4  fosc3 / 8 | -            | -   | 0       | R/W                 |                     |
|         | D3  | FOUTON | FOUT ou                                  | itput con                                | trol                                     |                                                                                                   | On           | Off | 0       | R/W                 |                     |
|         | D2  | WDRST  | Watchdog timer reset                     |                                          |                                          | Reset                                                                                             | No operation | _   | W       | Constantly "0" when |                     |
|         | D1  | TMRST  | Clock timer reset                        |                                          |                                          | Reset                                                                                             | No operation | _   | W       | being read          |                     |
|         | D0  | TMRUN  | Clock timer Run/Stop control             |                                          |                                          | Run                                                                                               | Stop         | 0   | R/W     |                     |                     |

# **Specifications**

# Control of output port (R port)

# (1) initoutput\_normal, output\_normal: Normal DC output

Sets the R3x port to complementary output and outputs HIGH and LOW to R35–R37.

# (2) init\_hiz, output\_hiz: High impedance output control

First sets the R5x port to complementary output and then switches between high impedance output and complementary output to operate the high impedance control register.

## (3) fout init, fout control: FOUT output control

Controls the turning ON/OFF of the FOUT output.

# Notes

(1) Besides normal DC output, output port terminals are shared with the special output shown in Table 6.1, and which is used can be selected in software. When using special output, it should be noted so that the port cannot be used as output port.

For control of special output except for FOUT output (R34 terminal), see the following chapters:

| Table 6.1 Special output |                |  |  |  |  |  |
|--------------------------|----------------|--|--|--|--|--|
| Output port              | Special output |  |  |  |  |  |
| R25                      | CL output      |  |  |  |  |  |
| R26                      | FR output      |  |  |  |  |  |
| R27                      | TOUT output    |  |  |  |  |  |
| R34                      | FOUT output    |  |  |  |  |  |
| R50                      | BZ output      |  |  |  |  |  |

- TOUT output (R27) ....."12 PROGRAMMABLE TIMER"
- CL output (R25), FR output (R26) ...... "13 LCD CONTROLLER"
- BZ output (R50) ....."14 SOUND GENERATOR"
- (2) Please note that in accordance with the bus mode and system controller settings or when using bus release for DMA transfer, the following output port terminals are used for the address bus,  $\overline{\text{RD}}/\overline{\text{WR}}$  signals,  $\overline{\text{CE3}}-\overline{\text{CE0}}$  signals and  $\overline{\text{BACK}}$  outputs and cannot be used as an output port.

# Notes

|                | Table 6.2  |
|----------------|------------|
| Combined outpu | t terminal |

| Output port | Special output  |
|-------------|-----------------|
| R00-R07     | A0-A7           |
| R10–R17     | A8-A15          |
| R20-R22     | A16-A18         |
| R23         | RD signal       |
| R24         | WR signal       |
| R30-R33     | CE0-CE3 signals |
| R51         | BACK signal     |

# **Flowchart**

# (1) Normal DC output





# (2) High impedance output control





output\_hiz

At this time, output shifts from HIGH to high impedance.

At this time, output shifts from high impedance to LOW.

# (3) FOUT output control





```
Control of output port (R port)
      public
              initoutput_normal,output_normal
               init_hiz,output_hiz
      public
      public
               fout_init,fout_control
br_io
          equ
               0ffh
                                ;base reg. address (set i/o area)
hzr ex
               00ff70h
                                expand output control reg.
          equ
               00ff72h
                                ;r3x output control reg.
hzr3
          equ
                                ;r3x output data
;r5x output data
r3d
               00ff76h
          equ
r5d
              00ff78h
          equ
rtm_mode
              00ff40h
                                ;timer mode set reg.
          equ
      code
(1) Normal DC output
r(output) port control (normal) r37 <- "1" then "h
; *
                            (complementary)
;*
        r36,35 <- "h","1"
                            (complementary)
;*** initialize routine
initoutput_normal:
                                ;set br reg. address to Offxxh ;set r3x complementary output
      ld br,#br_io
          [br:low hzr3],#0000000b
      ld
      ret
;*** control routine
output_normal:
                                                              (1)
                                ;set br reg. address to Offxxh
      14
          br, #br_io
                                ;r37 <- "1" output
      and
          [br:low r3d],#01111111b
                                ir37 <- "h" output
          [br:low r3d],#10000000b
      or
      ld
          a,[br:low r3d]
                                ;r3x output port read
      and a,#10011111b
          a,#01000000b
      or
                                ;r36 <- "h" and r35 <- "l" output
      1d
          [br:low r3d],a
      ret
(2) High impedance output control
; *
;*
      r(output) port control (hi-z)
; *
       r50,51 <- "h","h"
                            (complementary at init.)
; *
; *
             <- "hi-z"
; *
             <- "1","1"
                            (complementary)
; *
;*** initialize rotine
init_hiz:
          14
         br,#br_io
      or
      and
      ret
(2)
;*** control routine
output_hiz:
          ld
      or
      and
      and
      ret.
```

```
(3) FOUT output control
;*
;*
    fout control
;*
;*** initialize rotine
fout_init:
     ld
        br,#br_io
                          ;set br reg. address to Offxxh
     and [br:low hzr3],#11101111b ;set r34 complementary output
     ld
        a,[br:low rtm_mode]
       a,#00000111b
     and
        a,#00010000b
[br:low rtm_mode],a
     or
                           ;set fout=fosc1/2
     ld
     ret
(3)
;*** control routine
fout_control:
        or
     or
;other processing
        [br:low rtm_mode],#11110111b ;fout off
     and
    ret
     end
```

# 7 I/O PORTS (P PORTS)

# I/O Map

| Address | Bit | Name  | Function                 | 1       | 0          | SR | R/W   | Comment |
|---------|-----|-------|--------------------------|---------|------------|----|-------|---------|
| 00FF60  | D7  | IOC07 | P07 I/O control register |         |            |    |       |         |
|         | D6  | IOC06 | P06 I/O control register |         |            |    |       |         |
|         | D5  | IOC05 | P05 I/O control register |         |            |    |       |         |
|         | D4  | IOC04 | P04 I/O control register | 0       | <b>T</b> . |    | R/W   |         |
|         | D3  | IOC03 | P03 I/O control register | Output  | Input      | 0  | K/W   |         |
|         | D2  | IOC02 | P02 I/O control register |         |            |    |       |         |
|         | D1  | IOC01 | P01 I/O control register |         |            |    |       |         |
|         | D0  | IOC00 | P00 I/O control register |         |            |    |       |         |
| 00FF61  | D7  | IOC17 | P17 I/O control register |         |            |    |       | /       |
|         | D6  | IOC16 | P16 I/O control register |         |            |    |       |         |
|         | D5  | IOC15 | P15 I/O control register |         |            |    |       |         |
|         | D4  | IOC14 | P14 I/O control register | 0       | <b>T</b> . | 0  | R/W   |         |
|         | D3  | IOC13 | P13 I/O control register | Output  | Input      | 0  | K/W   |         |
|         | D2  | IOC12 | P12 I/O control register |         |            |    |       |         |
|         | D1  | IOC11 | P11 I/O control register |         |            |    |       |         |
|         | D0  | IOC10 | P10 I/O control register |         |            |    |       |         |
| 00FF62  | D7  | P07D  | P07 I/O port data        |         |            |    |       | /       |
|         | D6  | P06D  | P06 I/O port data        |         |            |    |       |         |
|         | D5  | P05D  | P05 I/O port data        |         |            |    |       |         |
|         | D4  | P04D  | P04 I/O port data        | YY: -1. | Low        | 1  | R/W   |         |
|         | D3  | P03D  | P03 I/O port data        | High    | Low        | 1  | K/W   |         |
|         | D2  | P02D  | P02 I/O port data        |         |            |    |       |         |
|         | D1  | P01D  | P01 I/O port data        |         |            |    |       |         |
|         | D0  | P00D  | P00 I/O port data        |         |            |    |       |         |
| 00FF63  | D7  | P17D  | P17 I/O port data        |         |            |    |       | /       |
|         | D6  | P16D  | P16 I/O port data        |         |            |    |       |         |
|         | D5  | P15D  | P15 I/O port data        |         |            |    |       |         |
|         | D4  | P14D  | P14 I/O port data        | YY: -1. | T          | 1  | R/W   |         |
|         | D3  | P13D  | P13 I/O port data        | High    | Low        | 1  | IK/ W | /       |
|         | D2  | P12D  | P12 I/O port data        |         |            |    |       |         |
|         | D1  | P11D  | P11 I/O port data        |         |            |    |       | /       |
|         | D0  | P10D  | P10 I/O port data        |         |            |    |       | /       |

# **Specifications**

# Control of I/O port (P port)

# (1) initio\_normal, io\_normal: Normal data input/output of I/O port

Sets P0x port as input and P1x port as output, and then waits for a HIGH input to P07 port. When P07 shifts to HIGH, reads P0x input data and outputs 55H to P1x.

# (2) init\_switch, io\_switch: Scan for 2 x 2 switch matrix

Assumes the switch matrix has been configured with input and output as shown in Figure 7.1, and specifies the key pressed and then stores the data into the RAM area named switch\_data.

# <Conditions>

P10, P11 ports: Input with pull-up resistor

R51, R50 ports: Nch open drain output (software setting)

switch\_data: 1 byte





Fig. 7.1 Switch matrix

# **Flowchart**

# (1) Normal data input/output of I/O port





# Flowchart



## Notes

- (1) In the input mode, when changing the port terminal from LOW to HIGH with a pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and input gate capacity. Hence, when reading data from the input port, set an appropriate wait time (for reference, approximately 500 µsec). Care is particularly required in key scanning for key matrix configuration. (external call: switch\_delay)
- (2) Besides normal DC output, I/O port terminals are shared with the special output shown in Table 7.1, and which is used can be selected in software. When using special output, it should be noted so that the port cannot be used as I/O port.

| I/O port | Special output |  |  |  |  |  |  |
|----------|----------------|--|--|--|--|--|--|
| P10      | SIN            |  |  |  |  |  |  |
| P11      | SOUT           |  |  |  |  |  |  |
| P12      | SCLK           |  |  |  |  |  |  |
| P13      | SRDY           |  |  |  |  |  |  |
| P14      | CMPP0          |  |  |  |  |  |  |
| P15      | CMPM0          |  |  |  |  |  |  |
| P16      | CMPP1          |  |  |  |  |  |  |
| P17      | CMPM1          |  |  |  |  |  |  |

Table 7.1 Special input/output

For details of each control procedure, see the following chapters:

- SIN (P10), SOUT (P11), SCLK (P12), SRDY (P13)
  - ....." "8 SERIAL INTERFACE 1 (CLOCK SYNCHRONOUS SYSTEM)"
  - ......" "9 SERIAL INTERFACE 2 (ASYNCHRONOUS SYSTEM)"
- CMPP0 (P14), CMPM0 (P15), CMPP1 (P16), CMPM1 (P17)
  - ....."15 ANALOG COMPARATOR"
- (3) Please note that in accordance with the bus mode and system controller settings, P0x terminals are used for the data bus and cannot be used as an I/O port.

Table 7.2 Combined data bus terminal

| I/O port | Special output |
|----------|----------------|
| P00-P07  | D0-D7          |

The P00 to P07 terminals have a built-in bus holder.

```
Control of I/O port (P port)
        external
                   switch_delay
       public
                  initio_normal,io_normal
       public
                  init_switch, io_switch
       public
                   switch data
                   0ffh
br_io
             equ
                                         ;base reg. address (set i/o area)
                   00ff60h
                                         ;p0x i/o control reg.
ioc0
             equ
                                         ;plx i/o control req.
ioc1
             eau
                   00ff61h
                   00ff62h
                                         ;p0x port data
p0d
             equ
p1d
                   00ff63h
                                         ;plx port data
             equ
                   00ff70h
hzr_ex
                                         ; expand output control reg.
             eau
                   00ff78h
                                         ;r5x output data
r5d
             equ
       data
             db
                  [1]
switch_data:
        code
(1) Normal data input/output of I/O port
;************************
; *
       p(i/o) port control (normal)
; *
          p0x (input:gate direct)
          plx (output) <- p17-10 (all "h")
; *
          p07 (input) <- waits "l" to "h" then p0x data read p0x (input) <- p0x port data read
; *
;*** initialize routine
initio normal:
                                         ;set br reg. address to Offxxh
       14
             br, #br_io
             [br:low ioc0],#0000000b
        ld
                                        ;set ioc0 (p07-00=input)
        ld
             [br:low pld],#11111111b
                                         ;p17-10(output) <- "h"
             [br:low ioc1],#11111111b
                                         ;set ioc1 (p17-10=output)
       ld
       ret
;*** control routine
                                                                              (1)
io_normal:
       ld
             br,#br_io
                                         ;set br reg. address to Offxxh
io normal00:
             [br:low p0d],#10000000b
                                         ip07 = "h"?
       bit
        jrs
             z,io_normal00
        ld
             a,[br:low p0d]
                                         ;p0x input
             [br:low pld],#01010101b
       ld
                                         ;plx output
       ret
```

```
(2) Scan for 2 x 2 switch matrix
; *
;*
       p(i/o) port control (internal pull up delay)
          r51 r50(n-channel open drain)
; *
; *
          pl1(pull up)
          p10(pull up)
                                 3
                                                1
          switch data 0 0 0 0 r51/p11 r51/p10 r50/p11 r50/p10
; *
;*
;*** initialize routine
init_switch:
                                       ;set br reg. address to 0ffxxh
;set iocl (p17-10=input)
;r5x <- high impledance "hi-z"</pre>
       ld
             br,#br_io
            [br:low ioc1],#0000000b
       ld
             [br:low hzr_ex],#11000000b
       or
       and
             [br:low r5d],#11111100b
                                         ;r5x <- "1"
       ret
;*** control routine
io_switch:
       ld
             br, #br_io
                                         ;set br reg. address to Offxxh
       xor
             a,a
        ld
             b,#2
                                        ;switch scan loop counter
        ld
             hl, #lod switch_data
                                         ;switch data buffer
                                         ;clear switch data buffer
       14
             [hl],#0
             a,#00100000b
       ld
                                         ;scan init. data set
switch00:
       sll
                                        ;scan data move bit0 to 7
                                         ;escape scan data
       push
            ba
                                         ;r5x hi-z control ("hi-z" <-> "l")
       ld
             b,[br:low hzr_ex]
       and
             b,#00111111b
        or
             a,b
       1 d
             [br:low hzr_ex],a
                                        r5x scan data control with hi-z
       pop
             ba
                                                                               (2)
       push
             h1
                                         ;switch scan delay ***
             switch_delay
       carl
       pop
             hl
       bit
             [br:low pld],#00000010b
                                        compare pl1 port level
            nz.switch01
       irs
;switch (p11) on "l"
       and
            sc,#11111101b
                                         ;clear carry flag
             switch02
       irs
;switch (pll) off "h"
switch01:
             sc,#00000010b
                                         ;set carry flag
switch02:
       rl
             [hl]
                                         ;set switch data buffer
             [br:low pld],#00000001b
       bit
                                         ;compare p10 port level
            nz,switch03
       jrs
;switch (p10) on "1"
            sc,#11111101b
                                         ;clear carry flag
       and
            switch04
       jrs
;switch (p10) off "h"
switch03:
             sc,#00000010b
                                         ;set carry flag
       or
switch04:
       rl
             [h]]
                                        ;set switch data buffer
             nz,switch00
       djr
       ret
       end
```

# 8 SERIAL INTERFACE 1

# (CLOCK SYNCHRONOUS INTERFACE)

| Address | Bit | Name  | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1                                              | 0                  | SR | R/W | Comment               |
|---------|-----|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|--------------------|----|-----|-----------------------|
| 00FF48  | D7  | _     | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | -                                              | -                  | _  | -   | "0" when being read   |
|         | D6  | EPR   | Parity enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | With parity                                    | Non parity         | 0  | R/W | Only for              |
|         | D5  | PMD   | Parity mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Odd                                            | Even               | 0  | R/W | asynchronous mode     |
|         | D4  | SCS1  | Clock source selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                                              | -                  | 0  | R/W | In the clock synchro- |
|         |     |       | SCS1 SCS0 Clock source                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                |                    |    |     | nous slave mode,      |
|         |     |       | 1 1 Programmable timer                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                |                    |    | L   | external clock is     |
|         | D3  | SCS0  | 1 0 fosc1 / 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | _                                              | _                  | 0  | R/W | selected.             |
|         |     |       | 0 1 fosc1 / 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                |                    |    |     |                       |
|         |     |       | 0 0 fosc1 / 4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                |                    |    |     |                       |
|         | D2  | SMD1  | Serial I/F mode selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | _                                              | -                  | 0  | R/W |                       |
|         |     |       | SMD1 SMD0 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                |                    |    |     |                       |
|         |     |       | 1 1 Asynchronous 8-bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                |                    |    |     |                       |
|         | D1  | SMD0  | 1 0 Asynchronous 7-bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | _                                              | -                  | 0  | R/W |                       |
|         |     |       | 0 1 Clock synchronous slave                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                |                    |    |     |                       |
|         |     |       | 0 0 Clock synchronous master                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                |                    |    |     |                       |
|         | D0  | ESIF  | Serial I/F enable register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Serial I/F                                     | I/O port           | 0  | R/W |                       |
| 00FF49  | D7  | _     | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | _                                              | -                  | -  | _   | "0" when being read   |
|         | D6  | FER   | Framing error flag R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Error                                          | No error           | 0  | R/W | Only for              |
|         |     |       | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset (0)                                      | No operation       |    |     | asynchronous mode     |
|         | D5  | PER   | Parity error flag                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Error                                          | No error           | 0  | R/W |                       |
|         |     |       | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset (0)                                      | No operation       |    |     |                       |
|         | D4  | OER   | Overrun error flag R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Error                                          | No error           | 0  | R/W |                       |
|         |     |       | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Reset (0)                                      | No operation       |    |     |                       |
|         | D3  | RXTRG | Receive trigger/status R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Run                                            | Stop               | 0  | R/W |                       |
|         |     |       | W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Trigger                                        | No operation       |    |     |                       |
|         | D2  | RXEN  | Receive enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | Enable                                         | Disable            | 0  | R/W |                       |
|         | D1  | TXTRG | Transmit trigger/status R                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Run                                            | Stop               | 0  | R/W |                       |
|         |     |       | l W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Trigger                                        | No operation       |    |     |                       |
|         |     | TXEN  | Transmit enable                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Enable                                         | Disable            | 0  | R/W | /                     |
| 00FF4A  |     | TRXD7 | Transmit/Receive data D7 (MSB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                              |                    |    |     | /                     |
|         |     | TRXD6 | Transmit/Receive data D6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                              |                    |    |     |                       |
|         |     | TRXD5 | Transmit/Receive data D5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |                    |    |     |                       |
|         |     | TRXD4 | Transmit/Receive data D4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | High                                           | Low                | X  | R/W |                       |
|         |     | TRXD3 | Transmit/Receive data D3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                |                    |    |     |                       |
|         |     | TRXD2 | Transmit/Receive data D2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                              |                    |    |     |                       |
|         |     | TRXD1 | Transmit/Receive data D1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | -                                              |                    |    |     |                       |
| 005500  |     | TRXD0 | Transmit/Receive data D0 (LSB)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -                                              |                    |    | -   | /                     |
| 00FF20  |     | PK01  | K00–K07 interrupt priority register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                |                    | 0  | R/W | /                     |
|         |     | PK00  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | PK01 PK0<br>PSIF1 PSII                         |                    |    |     |                       |
|         |     | PSIF1 | Serial interface interrupt priority register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PSW1 PSW                                       | V0 Priority        | 0  | R/W |                       |
|         |     | PSIF0 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | $\frac{\text{PTM1}}{1} \frac{\text{PTN}}{1}$   |                    |    |     |                       |
|         |     | PSW1  | Stopwatch timer interrupt priority register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1 0                                            | Level 2            | 0  | R/W | /                     |
|         |     | PSW0  | The property of the property o | $\begin{bmatrix} 0 & 1 \\ 0 & 0 \end{bmatrix}$ | Level 1<br>Level 0 |    | -   | /                     |
|         |     | PTM1  | Clock timer interrupt priority register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                | LCVCI U            | 0  | R/W | /                     |
|         | DÜ  | PTM0  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                |                    |    |     | V                     |

# I/O Map

| Address | Bit | Name  | Function                                            | 1         | 0            | SR | R/W   | Comment |
|---------|-----|-------|-----------------------------------------------------|-----------|--------------|----|-------|---------|
| 00FF23  | D7  | EPT1  | Programmable timer 1 interrupt enable register      |           |              |    |       |         |
|         | D6  | EPT0  | Programmable timer 0 interrupt enable register      |           |              |    |       | /       |
|         | D5  | EK1   | K10 and K11 interrupt enable register               |           |              |    |       |         |
|         | D4  | EK0H  | K04–K07 interrupt enable register                   | Interrupt | Interrupt    | 0  | R/W   |         |
|         | D3  | EK0L  | K00-K03 interrupt enable register                   | enable    | disable      | U  | K/W   |         |
|         | D2  | ESERR | Serial I/F (error) interrupt enable register        |           |              |    |       |         |
|         | D1  | ESREC | Serial I/F (receiving) interrupt enable register    |           |              |    |       |         |
|         | D0  | ESTRA | Serial I/F (transmitting) interrupt enable register |           |              |    |       |         |
| 00FF25  | D7  | FPT1  | Programmable timer 1 interrupt factor flag          | (R)       | (R)          |    |       |         |
|         | D6  | FPT0  | Programmable timer 0 interrupt factor flag          | Interrupt | No interrupt |    |       | /       |
|         | D5  | FK1   | K10 and K11 interrupt factor flag                   | factor is | factor is    |    |       |         |
|         | D4  | FK0H  | K04–K07 interrupt factor flag                       | generated | generated    | 0  | R/W   |         |
|         | D3  | FK0L  | K00-K03 interrupt factor flag                       |           |              | U  | IN/ W |         |
|         | D2  | FSERR | Serial I/F (error) interrupt factor flag            | (W)       | (W)          |    |       |         |
|         | D1  | FSREC | Serial I/F (receiving) interrupt factor flag        | Reset     | No operation |    |       |         |
|         | D0  | FSTRA | Serial I/F (transmitting) interrupt factor flag     |           |              |    |       |         |

# **Specifications**

# Clock synchronous serial interface

## <Conditions>

P10: SIN (Input)
P11: SOUT (Output)
P12: SCLK (Output)
P13: Slave READY (Input)

Function and input/output direction of the I/O port are automatically decided when setting the serial mode.

Hand shake signal from slave side

# Vector address setting for serial interface interrupt

# (1) sio\_init: Initialization for clock synchronous serial interface (master mode)

Sets the following in order to transmit/receive in a clock synchronous system:

- Serial interface function
- Synchronous clock OSC1 x 1/1
- Clock synchronous master mode
- Transmitting/receiving interrupt enable (IRQ2)

# (2) siorv, siorv\_intr: Receiving of clock synchronous serial interface (master mode)

Checks handshake signal (P13) and stores a total of 256 bytes of received data from the slave into a built-in memory receive\_buffer one byte at a time, using the receiving interrupt (IRQ2).

# (3) siotr, siotr\_intr: Transmitting of clock synchronous serial interface (master mode)

Checks handshake signal (P13) and outputs a total of 256 bytes of transmitted data from a built-in memory trans\_buffer to the slave one byte at a time, using the transmitting interrupt (IRQ2).

## Notes

- (1) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (2) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ2 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (3) When you have written "1" for the transmitting/receiving trigger and begin transmitting/receiving, first read the data and be sure to write "1" only on the necessary bits.

  Another transmitting/receiving status (receiving status during transmitting, and transmitting status during receiving) has been allocated for reading to the same address as the transmitting/receiving triggers. For example, when directly writing to the transmitting trigger, using the OR instruction during a receiving operation (receiving status = "1"), the receiving status is read once and it is then written as the receiving trigger. It is the same as the current receiving trigger.
- (4) In this program example for serial interface 1 (clock synchronous system), the vector address setting and program have been allocated from 003000H for the sake of convenience.

## Flowchart







# **Flowchart**



```
Clock synchronous serial interface
        public
                    sio_init,siorv,siotr,siorv_intr,siotr_intr
        public
                    receive_buffer,trans_buffer,receive_flag,trans_flag
siorv vector
                    000012h
                                              ;sio receive interrupt vector offset
             equ
siotr_vector equ
siotr_vector equ
                    000014h
                                              ; sio trans interrupt vector offset
                    003000h
sio
              equ
                                              ;program start address offset
                    0ffh
br_io
              equ
                                              ;base reg. address (set i/o area)
                                              ; mode control reg.
mode
              eau
                    00ff02h
                    00ff61h
                                              ;plx i/o control reg.
ioc1
              equ
                    00ff63h
                                              ;plx port data
p1d
              equ
smd
                    00ff48h
                                              ; serial interface mode set reg.
             eau
                    00ff49h
                                              ;serial interface error and trriger reg
ser
             equ
trxd
              equ
                    00ff4ah
                                              ;trans/recive data reg.
intr_pr0
             equ
                    00ff20h
                                              ;interrupt priority reg. 0
             equ
.
                    00ff23h
intr_en1
                                              ;interrupt enable reg. 1
intr_fac1
             equ
                    00ff25h
                                              ;interrupt factor reg. 1
        data
receive_buffer:db
                   [256]
                                              ;sio receive bufffer
trans_buffer: db
                   [256]
                                              ;sio trans buffer
receive_flag:
              db
                    [1]
                                              ;trans complete flag
trans_flag:
              db
                    [1]
                                              receive complete flag
        code
Vector address setting for serial interface interrupt
intr vectors:
              intr_vectors+siorv_vector
              siorv_intr
                                              ;sio receive interrupt
        dw
;
              intr_vectors+siotr_vector
              siotr_intr
                                              isio trans interrupt
        dw
(1) Initialization for clock synchronous serial interface (master mode)
        org intr_vectors+sio
             *******************
; *
; *
        sio master mode initialize (p13=slave ready)
;*** initialize routine
sio_init:
;p17-14=programmable output,p13=slave ready,p12-10=sio terminal
             br,#br_io
                                              ;set br reg. address to Offxxh
        ld
              [br:low pld],#11110110b
                                              ;/sclk="h",sout="h"
        1 d
        ld
             [br:low ioc1],#11110110b
        ld
              [br:low ser],#01110000b
                                              ;rxen=dis.txen=dis.
;serial mode:no-parity,clock=fosc1/1,sio master mode and serial i/o select
        ld [br:low smd],#00010001b
                                             ;set serial interface mode
        ld
              a,[br:low intr_pr0]
                                              ;interrupt priority reg.
        and
            a,#11001111b
              a,#00100000b
        or
                                                                                   (1)
              [br:low intr_pr0],a
                                              ;set psif1,0 to /irq2
        ld
        ld
              a,[br:low intr_en1]
              a,#01111000b
        and
        or
              a,#00000011b
              [br:low intr_en1],a
                                              ;esrec and estra intr. en.
        ld
              a.sc
              a,#00111111b
        and
              a,#01000000b
        or
                                              ;i1 flag clear (en. /irq2 intr.)
        ld
              sc,a
        ret
```

```
(2) Receiving of clock synchronous serial interface (master mode)
; *
       sio master mode receive (p13=slave ready)
; *
;*** control routine
siorv:
       ld
            br,#br_io
                                       ;set br reg. address to Offxxh
            iy,#lod receive_buffer
       14
                                      receive data buffer
       ld
            b,#0
                                       ;set receive counter (00h=256)
       ld
            a,[br:low ser]
       and
            a,#00000001b
                                      ;rxen=0 (dis.) sio reset
       1d
            [br:low ser],a
       xor
             a,a
       ld
            [lod receive_flag],a
                                      ;sio receive interrupt flag clear
       ld
            a,[br:low ser]
       and a,#0000001b
            a,#00000100b
       or
       ld
            [br:low ser],a
                                       ;rxen=1 (en.)
;wait slave ready
siorv00:
       bit
            [br:low pld],#00001000b
                                      ;p13(slave ready)="l
       jrs nz,siorv00
       1d
            a,[br:low ser]
                                                                           (2)
           a,#00000101b
       and
            a,#00001000b
       or
       ld
            [br:low ser],a
                                       ;rxtrg=set
;wait sio receive interrupt
siorv01:
       ld
            a,[lod receive_flag]
                                       ;sio receive interrput flag
            a,#0ffh
       CP
       jrs nz,siorv01
       xor
            a,a
            [lod receive_flag],a
                                      ;clear sio receive interrupt flag
       14
       ld
            a,[br:low trxd]
                                       ;receive data read
       ld
            [iy],a
                                       ;set receive data buffer
siorv03:
            [br:low pld],#00001000b
       bit
       jrs
            z,siorv03
                                       ;receive buffer + 1
       inc
             iy
       djr
            nz,siorv00
                                       ;until buffer end (256 bytes)
siorv02:
       ld
            a,[br:low ser]
            a,#00000001b
       and
                                       ;rxen=0 (dis.) sio reset
       14
            [br:low ser],a
       ret
```

```
(3) Transmitting of clock synchronous serial interface (master mode)
; *
; *
       sio master mode trans (p13=slave ready)
; *
;*** control routine
siotr:
       ld
            br,#br_io
                                       ;set br reg. address to Offxxh
       ld
             iy,#lod trans_buffer
                                        ;trans data buffer
                                        ;set trans counter (00h=256)
       ld
            b,#0
            a,[br:low ser]
       ld
       and
             a,#00000100b
       ld
            [br:low ser],a
                                       ;txen=0 (dis.) sio reset
       xor
             a,a
       ld
            ld
            a,[br:low ser]
       and
            a,#00000100b
            a,#00000001b
       or
       ld
            [br:low ser],a
                                       ;txen=en.
;wait slave ready
siotr00:
                                       ;load trans data buffer
       1.4
             a,[iy]
       ld
             [br:low trxd],a
                                        ;set trans data
                                        ;trans buffer + 1
       inc
            iy
siotr02:
                                                                            (3)
       bit
           [br:low pld],#00001000b ;p13(slave ready)="l
           nz,siotr02
       jrs
;
            a,[br:low ser]
             a,#00000101b
       and
             a,#0000010b
       or
       ld
            [br:low ser],a
                                       ;txtrg=set
; wait sio trans interrupt
siotr01:
       ld
            a,[lod trans_flag]
                                       ;sio trans interrput flag
            a,#0ffh
       ср
       jrs
           nz,siotr01
;
       xor
             a,a
       ld
            [lod trans_flag],a
                                       ;clear sio trans interrupt flag
siotr04:
       bit
            [br:low pld],#00001000b
            z,siotr04
       jrs
                                       ;until buffer end (256 bytes)
       djr nz,siotr00
siotr03:
       ld
            a,[br:low ser]
             a,#00000100b
       and
       ld
             [br:low ser],a
                                      ;txen=0 (dis.) sio reset
       ret
```

```
(2) Receiveing interrupt
; *
     sio master mode receive interrupt processing routine
siorv_intr:
     push ale
     ld br,#br_io
                              ;set br reg. address to Offxxh
     ld a,#0ffh
     ld [lod receive_flag],a
                              ;set sio receive interrupt flag
                                                          (2)
     sio receive interrupt processing routine
     and
         [br:low intr_fac1], #00000010b ; clear fsrec flag
     pop
          ale
     rete
(3)Transmitting interrupt
; *
     sio master trans interrupt processing routine
;*
siotr_intr:
     push ale
     ld br,#br io
                              ;set br req. address to Offxxh
     ld
        a,#0ffh
         [lod trans_flag],a
     ld
                              ;set sio trans interrupt flag
                                                          (3)
     sio trans interrupt processing routine
          [br:low intr_fac1],#00000001b ;clear fstra flag
     and
     qoq
     rete
     end
```

# 9 SERIAL INTERFACE 2 (ASYNCHRONOUS INTERFACE)

| Address | Bit | Name          | Function                                     | 1                                               | 0                  | SR | R/W | Comment               |
|---------|-----|---------------|----------------------------------------------|-------------------------------------------------|--------------------|----|-----|-----------------------|
| 00FF48  | D7  | _             | _                                            | -                                               | -                  | _  | -   | "0" when being read   |
|         | D6  | EPR           | Parity enable register                       | With parity                                     | Non parity         | 0  | R/W | Only for              |
|         | D5  | PMD           | Parity mode selection                        | Odd                                             | Even               | 0  | R/W | asynchronous mode     |
|         | D4  | SCS1          | Clock source selection                       | -                                               | -                  | 0  | R/W | In the clock synchro- |
|         |     |               | SCS1 SCS0 Clock source                       |                                                 |                    |    |     | nous slave mode,      |
|         |     |               | 1 1 Programmable timer                       |                                                 |                    |    |     | external clock is     |
|         | D3  | SCS0          | 1 0 fosc1 / 1                                | _                                               | _                  | 0  | R/W | selected.             |
|         |     |               | 0 1 fosc1 / 2                                |                                                 |                    |    |     |                       |
|         |     |               | 0 0 fosc1 / 4                                |                                                 |                    |    |     |                       |
|         | D2  | SMD1          | Serial I/F mode selection                    | -                                               | _                  | 0  | R/W |                       |
|         |     |               | SMD1 SMD0 Mode                               |                                                 |                    |    |     |                       |
|         |     |               | 1 1 Asynchronous 8-bit                       |                                                 |                    |    |     |                       |
|         | D1  | SMD0          | 1 0 Asynchronous 7-bit                       | -                                               | -                  | 0  | R/W |                       |
|         |     |               | 0 1 Clock synchronous slave                  |                                                 |                    |    |     |                       |
|         |     |               | 0 0 Clock synchronous master                 |                                                 |                    |    |     |                       |
|         | D0  | ESIF          | Serial I/F enable register                   | Serial I/F                                      | I/O port           | 0  | R/W | 1/                    |
| 00FF49  | D7  | -             | _                                            | -                                               | -                  | _  | _   | "0" when being read   |
|         | D6  | FER           | Framing error flag R                         | Error                                           | No error           | 0  | R/W | Only for              |
|         |     |               | W                                            | Reset (0)                                       | No operation       |    |     | asynchronous mode     |
|         | D5  | PER           | Parity error flag R                          | Error                                           | No error           | 0  | R/W |                       |
|         |     |               | W                                            | Reset (0)                                       | No operation       |    |     |                       |
|         | D4  | OER           | Overrun error flag R                         | Error                                           | No error           | 0  | R/W |                       |
|         |     |               | W                                            | Reset (0)                                       | No operation       |    |     |                       |
|         | D3  | RXTRG         | Receive trigger/status R                     | Run                                             | Stop               | 0  | R/W |                       |
|         |     |               | W                                            | Trigger                                         | No operation       |    |     |                       |
|         |     | RXEN          | Receive enable                               | Enable                                          | Disable            | 0  | R/W |                       |
|         | D1  | TXTRG         | Transmit trigger/status R                    | Run                                             | Stop               | 0  | R/W |                       |
|         |     |               | ¦ W                                          | Trigger                                         | No operation       |    |     | . /                   |
|         |     | TXEN          | Transmit enable                              | Enable                                          | Disable            | 0  | R/W |                       |
| 00FF4A  |     | TRXD7         | Transmit/Receive data D7 (MSB)               |                                                 |                    |    |     |                       |
|         |     | TRXD6         | Transmit/Receive data D6                     |                                                 |                    |    |     |                       |
|         |     | TRXD5         | Transmit/Receive data D5                     |                                                 |                    |    |     | / /                   |
|         |     | TRXD4         | Transmit/Receive data D4                     | High                                            | Low                | X  | R/W |                       |
|         |     | TRXD3         | Transmit/Receive data D3                     | Ü                                               |                    |    |     |                       |
|         |     | TRXD2         | Transmit/Receive data D2                     |                                                 |                    |    |     |                       |
|         |     | TRXD1         | Transmit/Receive data D1                     |                                                 |                    |    |     |                       |
| 205520  |     | TRXD0         | Transmit/Receive data D0 (LSB)               |                                                 |                    |    |     |                       |
| 00FF20  |     | PK01          | K00–K07 interrupt priority register          |                                                 |                    | 0  | R/W |                       |
|         |     | PK00          |                                              | PK01 PK0<br>PSIF1 PSIF                          |                    |    |     | . /                   |
|         |     | PSIF1         | Serial interface interrupt priority register | PSW1 PSW                                        | 0 Priority         | 0  | R/W |                       |
|         |     | PSIF0<br>PSW1 |                                              | <u>PTM1</u> <u>PTM</u>                          | lo level Level 3   |    |     | · /                   |
|         |     | PSW1          | Stopwatch timer interrupt priority register  | 1 0                                             | Level 2            | 0  | R/W | /                     |
|         |     | PSW0<br>PTM1  |                                              | $\begin{array}{ccc} 0 & 1 \\ 0 & 0 \end{array}$ | Level 1<br>Level 0 |    |     | / <b> </b>            |
|         |     | PTM0          | Clock timer interrupt priority register      |                                                 |                    | 0  | R/W | /                     |
|         | D0  | 1 11110       |                                              |                                                 |                    |    |     | V                     |

| Address | Bit | Name  | Function                                            | 1         | 0            | SR | R/W   | Comment |
|---------|-----|-------|-----------------------------------------------------|-----------|--------------|----|-------|---------|
| 00FF23  | D7  | EPT1  | Programmable timer 1 interrupt enable register      |           |              |    |       | /       |
|         | D6  | EPT0  | Programmable timer 0 interrupt enable register      |           |              |    |       |         |
|         | D5  | EK1   | K10 and K11 interrupt enable register               |           |              |    |       |         |
|         | D4  | EK0H  | K04-K07 interrupt enable register                   | Interrupt | Interrupt    | 0  | R/W   |         |
|         | D3  | EK0L  | K00-K03 interrupt enable register                   | enable    | disable      | U  | K/W   |         |
|         | D2  | ESERR | Serial I/F (error) interrupt enable register        |           |              |    |       |         |
|         | D1  | ESREC | Serial I/F (receiving) interrupt enable register    |           |              |    |       |         |
|         | D0  | ESTRA | Serial I/F (transmitting) interrupt enable register |           |              |    |       |         |
| 00FF25  | D7  | FPT1  | Programmable timer 1 interrupt factor flag          | (R)       | (R)          |    |       | /       |
|         | D6  | FPT0  | Programmable timer 0 interrupt factor flag          | Interrupt | No interrupt |    |       |         |
|         | D5  | FK1   | K10 and K11 interrupt factor flag                   | factor is | factor is    |    |       |         |
|         | D4  | FK0H  | K04–K07 interrupt factor flag                       | generated | generated    | 0  | R/W   |         |
|         | D3  | FK0L  | K00-K03 interrupt factor flag                       |           |              | U  | IN/ W |         |
|         | D2  | FSERR | Serial I/F (error) interrupt factor flag            | (W)       | (W)          |    |       |         |
|         | D1  | FSREC | Serial I/F (receiving) interrupt factor flag        | Reset     | No operation |    |       |         |
|         | D0  | FSTRA | Serial I/F (transmitting) interrupt factor flag     |           |              |    |       |         |

| Specifications                                    |                                                                                                                                                                                                                                                                                                                           |    |
|---------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| Asynchronous se                                   | ial interface                                                                                                                                                                                                                                                                                                             |    |
| P11: SOUT (C<br>P12: Hand shake (C                | pput)    Function and input/output direction of the I/O port are automatical decided when setting the serial mode.   Unused                                                                                                                                                                                               |    |
| Vect                                              | or address setting for serial interface interrupt                                                                                                                                                                                                                                                                         |    |
| Sets the following  Serial interfact  Asynchronou | lization for asynchronous serial interface (8-bit mode)  ag in order to transmit/receive in an asynchronous system:  a function  • Synchronous clock = Programmable timer  • Serial mode, even parity  • Transmitting/receiving interrupt enable (IRQ2)  and rate clock has been set to 9,600 bps using 96 kHz for fosc1. |    |
| Stores a total of time, using the                 | _intr, asyncerr_intr: Receiving of asynchronous serial interface (8-bit mode 256 bytes of received data into the built-in memory receive_buffer one byte at a eceiving interrupt ( $\overline{\text{IRQ2}}$ ). At this time, if a receiving error occurs, it suspends sing at that point.                                 | ·) |
| Outputs a total                                   | atr: Transmitting of asynchronous serial interface (8-bit mode) of 256 bytes of transmitted data from a built-in memory trans_buffer one byte at a ransmitting interrupt ( $\overline{\text{IRQ2}}$ ).                                                                                                                    | ì  |
|                                                   |                                                                                                                                                                                                                                                                                                                           |    |

## Notes

- (1) The example routine does not check the handshake signal when transmitting/receiving. If this routine is used for an actual program, pay attention to the timing of transmitting/receiving, or check the timing using a handshake signal.
- (2) The 9,600 bps baud rate has been set on the condition that the 96 kHz OSC1 oscillation clock is used.
- (3) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (4) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ2 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (5) When you have written "1" for the transmitting/receiving trigger and begin transmitting/receiving, first read the data and be sure to write "1" only on the necessary bits.

  Also, when writing "1" to reset the receive error flag to "0", similar care is necessary.

  Another transmitting/receiving status (receiving status during transmitting, transmitting status during receiving, and receiving error flag) has been allocated for reading to the same address as the transmitting/receiving triggers. For example, when directly writing to the transmitting trigger, using the OR instruction during a receiving operation (receiving status = "1"), the receiving status is read once and it is then written as the receiving trigger.

  Also when the receiving error flag has been set to "1", the receiving error flag is written and reset by
- (6) In this program example for serial interface 2 (asynchronous system), the vector address setting and program have been allocated from 003000H for the sake of convenience.

an OR instruction. It is the same as setting the receiving trigger or resetting the receiving error flag.

(7) For the OSC1 oscillation circuit, the frequency can be selected from 32.768 kHz, 38.4 kHz, 76.8 kHz, 96 kHz and 153.6 kHz by mask option. This program example uses 96 kHz for fosc1 and sets the baud rate to 9,600 bps.

# Flowchart









```
Asynchronous serial interface
        public
                     async_init,asyncrv,asynctr
                     asyncerr_intr,asyncrv_intr,asynctr_intr
receive_buffer,trans_buffer,receive_flag,trans_flag
        public
        public
        public
                     error_flag
asyncerr_vectorequ
                     000010h
                                              ;async error interrupt vector offset
asyncrv_vector equ
                     000012h
                                              ;async receive interrupt vector offset
asynctr_vector equ
                     000014h
                                              ;async trans interrupt vector offset
async
              eau
                     003000h
                                              ;program start address offset
br_io
              equ
                     0ffh
                                              ;base reg. address (set i/o area)
                                             ; mode control reg.
mode
              equ
                     00ff02h
                                             ;plx i/o control reg.
ioc1
              equ
                     00ff61h
p1d
                     00ff63h
                                             ;plx port data
              eau
                                             ;serial interface mode set reg.
;serial interface error and trriger reg
smd
              equ
                     00ff48h
                     00ff49h
ser
              equ
trxd
              equ
                     00ff4ah
                                             ;trans/recive data reg.
intr_pr0
              equ
                     00ff20h
                                             ;interrupt priority reg. 0
intr_en1
              equ
                     00ff23h
                                             ;interrupt enable reg. 1
intr_fac1
               equ
                     00ff25h
                                              ;interrupt factor reg. 1
        data
receive_buffer:db
                    [256]
                                             ;async receive bufffer
trans_buffer: db
                     [256]
                                              ;async trans buffer
error_flag:
              db
                     [1]
                                              ;async error flag
receive_flag:
              db
                     [1]
                                              ;trans complete flag
trans_flag:
              db
                     [1]
                                              receive complete flag
Vector address setting for serial interface interrupt
intr vectors:
              intr_vectors+asyncerr_vector
        ora
        dw
              asyncerr intr
                                              ;async error interrupt
        org
              intr_vectors+asyncrv_vector
               asyncrv_intr
                                              ;async receive interrupt
        dw
        orq
               intr_vectors+asynctr_vector
        dw
              asynctr_intr
                                              ;async trans interrupt
(1) Initialization for asynchronous serial interface (8-bit mode)
        org intr_vectors+async
                               ; *
; *
        async 8-bit mode initialize (p13 and 12 = hand shake:not use)
;*** initialize routine
async_init:
;p17-14=programmable output,p13-12=hand shake,p11-10=async terminal
        ld
             br,#br_io
                                       ;set br reg. address to Offxxh
        ld
               [br:low pld],#11110110b
                                              ;sout="h" and no hand shake
              [br:low ioc1],#11110110b
        ld
              [br:low ser],#01110000b
        ld
                                              rxen=dis.txen=dis.
;serial mode:even parity,clock=fosc1/1,async 8-bit mode and serial i/o select
                                       ;set serial interface mode
        ld
              [br:low smd],#01010111b
        ld
              a,[br:low intr_pr0]
                                             ;interrupt priority reg.
              a,#11001111b
        and
                                                                                       (1)
              a,#00100000b
        or
              [br:low intr_pr0],a
                                             ;set psif=/irq2
        1 d
              a,[low intr_en1]
a,#11111000b
        ld
        and
               a,#00000111b
        or
        14
               [br:low intr_en1],a
                                             ;eserr esrec and estra intr. en
        ld
              a,sc
              a,#00111111b
        and
              a,#01000000b
        or
        1 d
                                              ;i1 flag clear (en. /irq2 intr.)
              sc.a
        ret.
```

```
(2) Receiving of asynchronous serial interface (8-bit mode)
; *
; *
        async 8-bit mode receive (p13 and 12 = hand shake:not use)
;*
;*** control routine
asyncrv:
             br.#br io
                                        ;set br reg. address to Offxxh
       ld
             iy,#lod receive_buffer
                                         receive data buffer;
        ld
             b,#0
                                         ;set receive counter (00h=256)
       ld
             a,[br:low ser]
             a,#00000001b
        and
       ld
             [br:low ser],a
                                         ;rxen=0 (dis.) async reset
       xor
             a,a
             [lod receive_flag],a
                                        async receive interrpt flag clear
       ld
       ld
             [lod error_flag],a
                                         ;async receive error flag clear
        ld
             a,[br:low ser]
       and
             a,#00000001b
             a,#00000100b
       or
       ld
             [br:low ser],a
                                        ;rxen=1 (en.)
;no hand shake
asvncrv00:
       1 d
             a,[br:low ser]
       and
             a,#00000101b
             a,#00001000b
       or
             [br:low ser],a
                                        ;rxtrg=set and error reset
       1 d
;wait async receive interrupt
asyncrv01:
             a,[lod receive_flag]
       14
                                        async receive interrput flag
       ср
             a,#0ffh
       jrs z,asyncrv02
;
                                                                              (2)
       ld
            a,[lod error_flag]
                                    async error interrupt flag
             a,#00h
       ср
        jrs
             z,asyncrv01
receive error occurrs
       async receive error processing
;
;
;
       xor
            a,a
             [lod error_flag],a
                                      clear error interrupt flag;
       ld
        jrs
            asyncrv03
;receive no error
asyncrv02:
       xor
             [lod receive_flag],a
        ld
                                      ;clear async receive interrupt flag
;receive data read
             a,[br:low trxd]
       1 d
       ld
             [iy],a
                                        ;set receive data buffer
       inc
                                         ;receive buffer + 1
             iv
             nz,asyncrv00
                                         ;until buffer end (256 bytes)
       djr
asyncrv03:
       ld
             a,[br:low ser]
             a,#0000001b
       and
        ld
             [br:low ser],a
                                        ;rxen=0 (dis.) async reset
       ret
```

```
(3) Transmitting of asynchronous serial interface (8-bit mode)
; *
       async 8-bit mode trans (p13 and 12 = hand shake:not use)
; *
;*** control routine
asynctr:
           br.#br io
                                     ;set br reg. address to Offxxh
            iy,#lod trans_buffer
       ld
                                    trans data buffer;
       ld
            b,#0
                                     ;set trans counter (00h=256)
       ld
            a,[br:low ser]
       and a,#00000100b
                                     ;txen=0 (dis.) async reset
       ld
            [br:low ser],a
       xor
            a,a
       1d
            [lod trans_flag],a
                                     ;async trans interrupt flag clear
       ld
            a,[br:low ser]
       and a,#00000100b
       or
           a,#00000001b
                                     ;txen=en.
       ld
            [br:low ser],a
ino hand shake
asynctr00:
                                    ;load trans data buffer
       ld
            a,[iy]
       1.d
            [br:low trxd],a
                                     ;set trans data
                                                                        (3)
           iy
       inc
                                     ;trans buffer + 1
            a,[br:low ser]
       ld
           a,#00000101b
       and
       or
            a,#0000010b
           [br:low ser],a
      ld
                                    ;txtrq=set
;wait async trans interrupt
asynctr01:
      ld
           a,[lod trans_flag]
                                    async trans interrpu flag
           a,#0ffh
       Cρ
           nz,asynctr01
       jrs
       xor
           a,a
            [lod trans_flag],a
                                     ;clear async trans interrupt flag
       ld
       djr
            nz,asynctr00
                                     ;until buffer end (256 bytes)
asynctr02:
       ld
           a,[br:low ser]
       and
            a,#00000100b
       ld
            [br:low ser],a
                                    ;txen=0 (dis.) async reset
       ret
(2) Receiving error interrupt
; *
; *
      async 8-bit mode error interrupt processing routine
asyncerr_intr:
      push ale
       ld br,#br_io
                                     ;set br reg. address to Offxxh
       ld a,[br:low ser] and a.#01110101
            [br:low ser],a
       ld
                                     receive error status reset;
       and a,#01110000b
                                    ;ignore bits clear
;set async error interrupt flag
                                                                        (2)
            [lod error_flag],a
       1.d
      async error interrupt processing routine
            [br:low intr_fac1],#00000100b ;clear fserr flag
       and
       pop
            ale
       rete
```

```
(2) Receiving interrupt
;*
; *
     async 8-bit mode receive interrupt processing routine
;*
asyncrv_intr:
     push ale
     ld
          br,#br_io
                               ;set br reg. address to Offxxh
     ld a,#0ffh
     ld [lod receive_flag],a
                               ;set async receive interrupt flag
                                                            (2)
     async receive interrupt processing routine
          [br:low intr_fac1], #00000010b ; clear fsrec flag
     and
      pop
          ale
      rete
(3) Transmitting interrupt
; *
     async 8-bit mode trans interrupt processing routine
; *
asynctr_intr:
     push ale
     ld br, #br io
                               ;set br req. address to Offxxh
;
      ld
        a,#0ffh
          [lod trans_flag],a
     ld
                               ;set async trans interrupt flag
                                                            (3)
     async trans interrupt processing routine
      and
          [br:low intr_fac1],#00000001b ;clear fstra flag
     qoq
      rete
      end
```

# 10 CLOCK TIMER

| Address | Bit | Name   | Function                                         | 1                                                | 0                  | SR | R/W    | Comment             |
|---------|-----|--------|--------------------------------------------------|--------------------------------------------------|--------------------|----|--------|---------------------|
| 00FF40  | D7  | _      | _                                                | _                                                | -                  | _  | _      | "0" when being read |
|         | D6  | FOUT2  | FOUT frequency selection                         | _                                                | _                  | 0  | R/W    | /                   |
|         |     |        | FOUT2 FOUT1 FOUT0 Frequency                      |                                                  |                    |    |        | /                   |
|         |     |        | 0 $0$ $0$ fosci / 1                              |                                                  |                    |    |        |                     |
|         | D5  | FOUT1  | 0 0 1 fosc1/2                                    | _                                                | _                  | 0  | R/W    |                     |
|         |     |        | 0 1 0 fosc1/4<br>0 1 1 fosc1/8                   |                                                  |                    |    |        |                     |
|         |     |        | 1 0 0 fosc3/1                                    |                                                  |                    |    |        |                     |
|         | D4  | FOUT0  | 1 0 1 fosc3/2                                    | _                                                | _                  | 0  | R/W    |                     |
|         |     |        | 1 1 0 fosc3 / 4                                  |                                                  |                    |    |        |                     |
|         |     |        | 1 1 1 fosc3 / 8                                  |                                                  |                    |    |        |                     |
|         | D3  | FOUTON | FOUT output control                              | On                                               | Off                | 0  | R/W    | V                   |
|         | D2  | WDRST  | Watchdog timer reset                             | Reset                                            | No operation       | _  | W      | Constantly "0" when |
|         | D1  | TMRST  | Clock timer reset                                | Reset                                            | No operation       | -  | W      | being read          |
|         | D0  | TMRUN  | Clock timer Run/Stop control                     | Run                                              | Stop               | 0  | R/W    |                     |
| 00FF41  | D7  | TMD7   | Clock timer data 1 Hz                            |                                                  |                    |    |        |                     |
|         | D6  | TMD6   | Clock timer data 2 Hz                            |                                                  |                    |    |        | /                   |
|         | D5  | TMD5   | Clock timer data 4 Hz                            |                                                  |                    |    |        |                     |
|         | D4  | TMD4   | Clock timer data 8 Hz                            | High                                             | Low                | 0  | R      |                     |
|         | D3  | TMD3   | Clock timer data 16 Hz                           | nigii                                            | Low                | U  | K      |                     |
|         | D2  | TMD2   | Clock timer data 32 Hz                           |                                                  |                    |    |        |                     |
|         | D1  | TMD1   | Clock timer data 64 Hz                           |                                                  |                    |    |        |                     |
|         | D0  | TMD0   | Clock timer data 128 Hz                          |                                                  |                    |    |        |                     |
| 00FF20  | D7  | PK01   | K00–K07 interrupt priority register              |                                                  |                    | 0  | R/W    |                     |
|         |     | PK00   | Koo-Ko/ interrupt priority register              | PK01 PK0                                         |                    |    | 10, 11 | /                   |
|         |     | PSIF1  | Serial interface interrupt priority register     | PSIF1 PSIF<br>PSW1 PSW                           |                    | 0  | R/W    |                     |
|         |     | PSIF0  | Serial interface interrupt priority register     | PTM1 PTM                                         | 10 <u>level</u>    |    | 10, 11 |                     |
|         | D3  | PSW1   | Stopwatch timer interrupt priority register      | $\begin{array}{cccc} 1 & 1 \\ 1 & 0 \end{array}$ | Level 3<br>Level 2 | 0  | R/W    |                     |
|         | D2  | PSW0   | Stopwater timer interrupt priority register      | 0 1                                              | Level 1            |    | 10, 11 | /                   |
|         | D1  | PTM1   | Clock timer interrupt priority register          | 0 0                                              | Level 0            | 0  | R/W    |                     |
|         | D0  | PTM0   | cross times interrupt priority register          |                                                  |                    |    |        | /                   |
| 00FF22  | D7  | _      | -                                                | -                                                | -                  | _  | _      | "0" when being read |
|         |     |        | Stopwatch timer 100 Hz interrupt enable register |                                                  |                    |    |        | /                   |
|         |     | ESW10  | Stopwatch timer 10 Hz interrupt enable register  |                                                  |                    |    |        |                     |
|         |     | ESW1   | Stopwatch timer 1 Hz interrupt enable register   | Interrupt                                        | Interrupt          |    |        |                     |
|         |     | ETM1M  | Clock timer 1/60 Hz interrupt enable register    | enable                                           | disable            | 0  | R/W    |                     |
|         |     | ETM8   | Clock timer 8 Hz interrupt enable register       |                                                  |                    |    |        |                     |
|         |     | ETM2   | Clock timer 2 Hz interrupt enable register       |                                                  |                    |    |        |                     |
|         | -   | ETM1   | Clock timer 1 Hz interrupt enable register       |                                                  |                    |    |        |                     |
| 00FF24  | D7  | -<br>- | -<br>                                            | -                                                | -                  | _  | _      | "0" when being read |
|         |     |        | Stopwatch timer 100 Hz interrupt factor flag     | (R)                                              | (R)                |    |        | /                   |
|         |     | FSW10  | Stopwatch timer 10 Hz interrupt factor flag      | Interrupt                                        | No interrupt       |    |        | /                   |
|         |     | FSW1   | Stopwatch timer 1 Hz interrupt factor flag       | factor is                                        | factor is          |    | D 411  | /                   |
|         |     | FTM1M  | Clock timer 1/60 Hz interrupt factor flag        | generated                                        | generated          | 0  | R/W    | /                   |
|         |     | FTM8   | Clock timer 8 Hz interrupt factor flag           | (W)                                              | (W)                |    |        | /                   |
|         |     | FTM2   | Clock timer 2 Hz interrupt factor flag           | Reset                                            | No operation       |    |        | /                   |
|         | טט  | FTM1   | Clock timer 1 Hz interrupt factor flag           |                                                  |                    |    |        | V                   |

# **Specifications**

# Control of clock timer

Vector address setting for clock timer interrupt

# (1) rtm\_init: Initialization for clock timer

Enables the respective 8 Hz, 2 Hz and 1 Hz interrupts of the clock timer, clears the timer data and starts the clock timer. The interrupt level has been set at  $\overline{IRQ1}$ .

(2) rtm8\_intr, rtm2\_intr, rtm1\_intr: Clock timer interrupt processing

## Flowchart



# (2) 2 Hz clock timer interrupt processing



# (2) 1 Hz clock timer interrupt processing



## Notes

- (1) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (2) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ1 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (3) When stopping the clock timer by writing "0" into the RUN/STOP control register for the clock timer, the clock timer count actually stops when it advances one count with the timing synchronized to the 256 Hz input clock. For this reason, when the clock timer stops, if the 8 Hz, 2 Hz and 1 Hz interrupt factors are generated, the respective interrupt factor flags are set and if interrupt is enabled, an interrupt is generated. Thus, you should add an interrupt processing and interrupt factor flag resetting, if necessary.
- (4) In this program example for the clock timer, the vector address setting and program have been allocated from 003000H for the sake of convenience.

## Source List

# Control of clock timer

```
public
                    clock_init,clock8_intr,clock2_intr,clock1_intr
clock8_vector equ
                    00001eh
                                                ;clock8hz interrupt vector offset
clock2_vector equ
                    000020h
                                                ;clock2hz interrupt vector offset
clock1_vector equ
                                                ;clock1hz interrupt vector offset
                    000022h
clock
                    003000h
                                               ;program start address offset
              equ
br_io
              equ
                    0ffh
                                                ;base reg. address (set i/o area)
clock_mode
                    00ff40h
                                               ;timer mode set reg.
              equ
clockd
              equ
                    00ff41h
                                               ;timer data
intr_pr0
              equ
                    00ff20h
                                               ;interrupt priority reg. 0
intr_en0
                    00ff22h
                                               ;interrupt enable reg. 0
              eau
intr_fac0
                    00ff24h
              equ
                                               ;interrupt factor flag reg.
```

# Vector address setting for clock timer interrupt

```
intr_vectors:
               intr_vectors+clock8_vector
        org
               clock8_intr
                                                  ;clock 8hz interrupt
        dw
               intr_vectors+clock2_vector
        ora
        dw
               clock2_intr
                                                  ;clock 2hz interrupt
        orq
               intr_vectors+clock1_vector
                                                  ; clock 1hz interrupt
        dw
               clock1 intr
```

```
(1) Initialization for clock timer
       org intr_vectors+clock
; *
; *
      clock timer initialize (8,2 and 1hz interrupt enable)
;*** initialize routine
clock_init:
       ld
           br,#br_io
                                      ;set br reg. address to Offxxh
           a,[br:low intr_pr0]
       14
                                      ;interrupt priority reg.
       and a,#11111100b
           a,#00000001b
      or
      1d
           [br:low intr_pr0],a
                                      ;set ptm=/irq1
;etm8,etm2 and etm1 (en. /irq1) intr.
      or [br:low intr_en0],#00000111b
                                                                      (1)
           [br:low clock_mode],#00000010b ;clock timer counter reset
      or
           [br:low clock_mode],#00000001b ;clock timer start
      or
       and
           sc,#00111111b
                                      ;il and i0 flag clear
               *****************
;*** start clock timer interrupt
      jrl user_program
(2) 8 Hz clock timer interrupt processing
; *
      clock timer 8hz interrupt processing routine
;*
;************************************
clock8_intr:
      push ale
      ld br, #br io
                                      ;set br req. address to Offxxh
      clock timer 8hz processing routine
           [br:low intr_fac0],#00000100b ;clear etm8 flag
       and
       pop
            ale
       rete
(2) 2 Hz clock timer interrupt processing
; *
                                                                      (2)
;*
      clock timer 2hz interrupt processing routine
clock2_intr:
      push ale
      ld br,#br_io
                                      ;set br reg. address to Offxxh
;
      clock timer 2hz processing routine
           [br:low intr_fac0],#00000010b ;clear etm2 flag
       and
       pop
            ale
       rete
```

```
Source List
 (2) 1 Hz clock timer interrupt processing
 ; *
      clock timer 1hz interrupt processing routine
 clock1_intr:
       push ale
                                      ;set br reg. address to Offxxh
       ld br,#br_io
                                                                    (2)
       clock timer 1hz processing routine
       and
            [br:low intr_fac0],#00000001b ;clear etm1 flag
       pop
       rete
       end
```

# 11 STOPWATCH TIMER

| Address I | Bit | Name   | Function                                         | 1                                               | 0                             | SR | R/W | Comment             |
|-----------|-----|--------|--------------------------------------------------|-------------------------------------------------|-------------------------------|----|-----|---------------------|
| 00FF42 [  | D7  | _      | _                                                | -                                               | _                             | _  | _   |                     |
| [         | D6  | _      | _                                                | -                                               | -                             | _  | -   |                     |
| [         | D5  | _      | _                                                | -                                               | -                             | _  | -   | Constantly "O" when |
| [         | D4  | _      | _                                                | -                                               | -                             | _  | -   | Constantly "0" when |
| [         | D3  | _      | _                                                | -                                               | _                             | -  | _   | being read          |
| <u> </u>  | D2  | _      | _                                                | -                                               | _                             | -  | _   |                     |
| [         | D1  | SWRST  | Stopwatch timer reset                            | Reset                                           | No operation                  | _  | W   |                     |
| _ [r      | D0  | SWRUN  | Stopwatch timer Run/Stop control                 | Run                                             | Stop                          | 0  | R/W |                     |
| 00FF43 [  | D7  | SWD7   | Stopwatch timer data                             |                                                 |                               |    |     | /                   |
| [i        | D6  | SWD6   |                                                  |                                                 |                               |    |     |                     |
| [i        | D5  | SWD5   | BCD (1/10 sec)                                   |                                                 |                               |    |     |                     |
| [         | D4  | SWD4   |                                                  |                                                 |                               |    | _   |                     |
| [         | D3  | SWD3   | Stopwatch timer data                             |                                                 |                               | 0  | R   |                     |
| l fi      | D2  | SWD2   | -                                                |                                                 |                               |    |     |                     |
| l fi      | D1  | SWD1   | BCD (1/100 sec)                                  |                                                 |                               |    |     |                     |
| l fi      | D0  | SWD0   |                                                  |                                                 |                               |    |     |                     |
| 00FF20 [  | D7  | PK01   |                                                  |                                                 |                               | _  |     | /                   |
|           | D6  | PK00   | K00–K07 interrupt priority register              | PK01 PK0                                        | 0                             | 0  | R/W | /                   |
|           | D5  | PSIF1  |                                                  | PSIF1 PSIF                                      | 0                             |    |     |                     |
| l i       | D4  | PSIF0  | Serial interface interrupt priority register     | PSW1 PSW<br>PTM1 PTM                            |                               | 0  | R/W |                     |
| l Ti      | _   | PSW1   |                                                  | 1 1                                             | Level 3                       |    |     |                     |
| F-        |     | PSW0   | Stopwatch timer interrupt priority register      | $\begin{array}{ccc} 1 & 0 \\ 0 & 1 \end{array}$ | Level 2<br>Level 1<br>Level 0 | 0  | R/W |                     |
|           | D1  | PTM1   |                                                  | 0 0                                             |                               |    |     |                     |
| l i       | D0  | PTM0   | Clock timer interrupt priority register          |                                                 |                               | 0  | R/W | /                   |
| 00FF22 [  | D7  | _      | _                                                | _                                               | _                             | _  |     | "0" when being read |
|           | D6  | ESW100 | Stopwatch timer 100 Hz interrupt enable register |                                                 |                               |    |     | /                   |
| F:        |     | ESW10  | Stopwatch timer 10 Hz interrupt enable register  |                                                 |                               |    |     |                     |
| F-        |     | ESW1   | Stopwatch timer 1 Hz interrupt enable register   |                                                 |                               |    |     |                     |
|           | D3  | ETM1M  | Clock timer 1/60 Hz interrupt enable register    | Interrupt                                       | Interrupt                     | 0  | R/W |                     |
| l j       | D2  | ETM8   | Clock timer 8 Hz interrupt enable register       | enable                                          | disable                       |    |     |                     |
|           |     | ETM2   | Clock timer 2 Hz interrupt enable register       |                                                 |                               |    |     |                     |
| ti        | D0  | ETM1   | Clock timer 1 Hz interrupt enable register       |                                                 |                               |    |     |                     |
| 00FF24 [  | D7  | _      | _                                                | _                                               | _                             | _  | _   | "0" when being read |
|           | D6  | FSW100 | Stopwatch timer 100 Hz interrupt factor flag     | (R)                                             | (R)                           |    |     | /                   |
| F         |     | FSW10  | Stopwatch timer 10 Hz interrupt factor flag      | Interrupt                                       | No interrupt                  |    |     | /                   |
| F-        |     | FSW1   | Stopwatch timer 1 Hz interrupt factor flag       | factor is                                       | factor is                     |    |     |                     |
| <u>-</u>  |     | FTM1M  | Clock timer 1/60 Hz interrupt factor flag        | generated                                       | generated                     | 0  | R/W |                     |
| l li      | D2  | FTM8   | Clock timer 8 Hz interrupt factor flag           |                                                 |                               |    |     |                     |
|           |     | FTM2   | Clock timer 2 Hz interrupt factor flag           | (W)                                             | (W)                           |    |     |                     |
|           |     | FTM1   | Clock timer 1 Hz interrupt factor flag           | Reset                                           | No operation                  |    |     |                     |

# **Specifications**

# Control of stopwatch timer

Vector address setting for stopwatch timer interrupt

# (1) sw\_init: Initialization for stopwatch timer

Enables the respective 100 Hz, 10 Hz and 1 Hz interrupts of the stopwatch timer, clears the timer data and starts the stopwatch timer. The interrupt level has been set at  $\overline{\text{IRQ1}}$ .

(2) sw100\_intr, sw10\_intr, sw1\_intr: Stopwatch timer interrupt processing

## Flowchart



## Notes

- (1) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (2) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ1 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (3) When stopping the stopwatch timer by writing "0" into the RUN/STOP control register for the stopwatch timer, the stopwatch timer count actually stops when it advances one count with the timing synchronized to the 256 Hz input clock. For this reason, when the stopwatch timer stops, if the 100 Hz, 10 Hz, and 1 Hz interrupt factors are generated, the respective interrupt factor flags are set and if interrupt is enabled, an interrupt is generated. Thus, you should add an interrupt processing and interrupt factor flag resetting, if necessary.
- (4) In this program example for the stopwatch timer, the vector address setting and program have been allocated from 003000H for the sake of convenience.

## Source List

# Control of stopwatch timer

```
sw_init,sw100_intr,sw10_intr,sw1_intr
         public
sw100_vector
                     000016h
                                                  ;sw100hz interrupt vector offset
               equ
                     000018h
sw10_vector
                                                  ;sw10hz interrupt vector offset
               eau
sw1_vector
               equ
                     00001ah
                                                  ;swlhz interrupt vector offset
                     003000h
                                                  ;program start address offset
               equ
                                                  ;base reg. address (set i/o area)
br_io
                     0ffh
               equ
sw_mode
                     00ff42h
               equ
                                                  ;stopwatch mode set reg.
swd
                     00ff43h
                                                 ;stopwatch data
               equ
intr_pr0
                     00ff20h
                                                  ;interrupt priority reg. 0
               ean
intr en0
               equ
                     00ff22h
                                                  ;interrupt enable reg. 0
intr_fac0
                     00ff24h
                                                 ;interrupt factor flag reg.
               equ
```

# Vector address setting for stopwatch timer interrupt

```
intr vectors:
               intr_vectors+sw100_vector
         org
        dw
               sw100_intr
                                                  ;sw 100hz interrupt
;
        ora
               intr_vectors+sw10_vector
               sw10_intr
                                                  ;sw 10hz interrupt
        dw
               intr_vectors+sw1_vector
        ora
               sw1_intr
                                                  ;sw 1hz interrupt
        dw
```

```
(1) Initialization for stopwatch timer
   org intr_vectors+sw
                     *************
; *
; *
      stopwatch initialize (100,10 and 1hz interrupt enable)
;*** initialize routine
sw_init:
      ld
          br,#br_io
                                  ;set br reg. address to Offxxh
          a,[br:low intr_pr0]
      14
                                  ;interrupt priority reg.
      and a,#11110011b
          a,#00000100b
      or
      ld
          [br:low intr_pr0],a
                                  ;set sw=/irq1
;sw100,sw10 and sw1 (en. /irq1) intr.
      or [br:low intr_en0],#01110000b
                                                               (1)
                                 stopwatch counter reset
      or
          [br:low sw_mode],#0000010b
      or
          [br:low sw_mode],#0000001b
                                  ;stopwatch start
      and sc,#00111111b
                                  ;i1 and i0 flag clear
;*** start stopwatch interrupt
     (user program)
; *** end processing
          [br:low sw_mode],#11111110b ;stopwatch stop
      and
      ret.
(2) 100 Hz stopwatch timer interrupt processing
; *
      stopwatch 100hz interrupt processing routine
sw100_intr:
     push ale
      ld br, #br_io
                                  ;set br reg. address to Offxxh
                                                               (2)
      stopwatch 100hz processing routine
      and
          [br:low intr_fac0],#01000000b
                                  ;clear sw100 flag
      ana
          ale
      rete
(2) 10 Hz stopwatch timer interrupt processing
;*
;*
      stopwatch 10hz interrupt processing routine
sw10_intr:
     push ale
      ld
          br, #br_io
                                   ;set br reg. address to Offxxh
                                                               (2)
      stopwatch 10hz processing routine
          [br:low intr_fac0],#00100000b ;clear sw10 flag
      and
      gog
          ale
      rete
```

```
(2) 1 Hz stopwatch timer interrupt processing
;************************
;*
     stopwatch 1hz interrupt processing routine
;*
sw1_intr:
     push ale
     ld br,#br_io
                                 ;set br reg. address to Offxxh
                                                            (2)
     stopwatch 1hz processing routine
;
;
     and
         [br:low intr_fac0],#00010000b ;clear sw1 flag
     pop
     rete
      end
```

# 12 PROGRAMMABLE TIMER

| Address | Bit | Name   | Fui                     | nction                   | 1                         | 0                        | SR | R/W | Comment             |
|---------|-----|--------|-------------------------|--------------------------|---------------------------|--------------------------|----|-----|---------------------|
| 00FF30  | D7  | _      | _                       |                          | -                         | -                        | _  | -   | Constantry "0" when |
|         | D6  | _      | _                       |                          | -                         | -                        | _  | _   | being read          |
|         | D5  | -      | _                       |                          | -                         | -                        | _  | _   |                     |
|         | D4  | MODE16 | 8/16-bit mode selection | on                       | 16-bit x 1                | 8-bit x 2                | 0  | R/W |                     |
|         | D3  | CHSEL  | TOUT output channe      | l selection              | Timer 1                   | Timer 0                  | 0  | R/W |                     |
|         | D2  | PTOUT  | TOUT output control     |                          | On                        | Off                      | 0  | R/W |                     |
|         | D1  | CKSEL1 | Prescaler 1 source clo  | ock selection            | fosc3                     | foscı                    | 0  | R/W |                     |
|         | D0  |        | Prescaler 0 source clo  | ock selection            | fosc3                     | foscı                    | 0  | R/W |                     |
| 00FF31  | D7  | EVCNT  | Timer 0 counter mode    | e selection              | Event counter             | Timer                    | 0  | R/W | ] /                 |
|         | D6  | FCSEL  | Timer 0                 | In timer mode            | Pulse width               | Normal                   | 0  | R/W | /                   |
|         |     |        | function selection      |                          | measurement               | mode                     |    |     | /                   |
|         |     |        |                         | In event counter mode    | With                      | Without                  |    |     | /                   |
|         |     |        |                         |                          | noise rejector            | noise rejector           |    |     |                     |
|         | D5  | PLPOL  | Timer 0                 | Down count timing        | Rising edge               | Falling edge             | 0  | R/W | /                   |
|         |     |        | pulse polarity          | in event counter mode    | of K10 input              | of K10 input             |    |     | /                   |
|         |     |        | selection               | In pulse width           | High level<br>measurement | Low level<br>measurement |    |     | /                   |
|         |     |        |                         | measurement mode         |                           | for K10 input            |    |     | /                   |
|         | D4  | PSC01  | Timer 0 prescaler div   | •                        | -                         | -                        | 0  | R/W | /                   |
|         |     |        |                         | Prescaler dividing ratio |                           |                          |    |     |                     |
|         |     |        | 1 1                     | Source clock / 64        |                           |                          |    |     |                     |
|         | D3  | PSC00  | 1 0                     | Source clock / 16        | -                         | -                        | 0  | R/W | /                   |
|         |     |        | 0 1                     | Source clock / 4         |                           |                          |    |     | /                   |
|         |     |        | 0 0                     | Source clock / 1         |                           |                          |    |     | /                   |
|         |     | CONT0  |                         | ne-shot mode selection   | Continuous                | One-shot                 | 0  | R/W | /                   |
|         |     | PSET0  | Timer 0 preset          |                          | Preset                    | No operation             | _  | W   | "0" when being read |
|         | D0  | PRUN0  | Timer 0 Run/Stop cor    | ntrol                    | Run                       | Stop                     | 0  | R/W |                     |
| 00FF32  | D7  | _      | _                       |                          | -                         | -                        | _  | _   | Constantry "0" when |
|         | D6  | _      | _                       |                          | -                         | -                        | _  | _   | being read          |
|         | D5  | _      | _                       |                          | -                         | -                        | _  | _   | ,                   |
|         | D4  | PSC11  | Timer 1 prescaler div   | _                        | -                         | -                        | 0  | R/W | /                   |
|         |     |        |                         | Prescaler dividing ratio |                           |                          |    |     |                     |
|         | -=  |        | 1 1                     | Source clock / 64        |                           |                          |    |     |                     |
|         | D3  | PSC10  | 1 0                     | Source clock / 16        | -                         | -                        | 0  | R/W |                     |
|         |     |        | 0 1                     | Source clock / 4         |                           |                          |    |     |                     |
|         |     |        | 0 0                     | Source clock / 1         |                           |                          |    |     |                     |
| ]       |     | CONT1  |                         | ne-shot mode selection   | Continuous                | One-shot                 | 0  | R/W | /                   |
|         | D1  | PSET1  | Timer 1 preset          |                          | Preset                    | No operation             | -  | W   | "0" when being read |
|         | D0  | PRUN1  | Timer 1 Run/Stop cor    | ntrol                    | Run                       | Stop                     | 0  | R/W |                     |

| Address | Bit | Name  | Function                      | 1      | 0   | SR | R/W    | Comment |
|---------|-----|-------|-------------------------------|--------|-----|----|--------|---------|
| 00FF33  | D7  | RLD07 | Timer 0 reload data D7 (MSB)  |        |     |    |        | /       |
|         | D6  | RLD06 | Timer 0 reload data D6        |        |     |    |        | /       |
|         | D5  | RLD05 | Timer 0 reload data D5        |        |     |    |        |         |
|         | D4  | RLD04 | Timer 0 reload data D4        | High   | Low | 1  | R/W    |         |
|         | D3  | RLD03 | Timer 0 reload data D3        | High   | Low | 1  | K/W    |         |
|         | D2  | RLD02 | Timer 0 reload data D2        |        |     |    |        |         |
|         | D1  | RLD01 | Timer 0 reload data D1        |        |     |    |        |         |
|         | D0  | RLD00 | Timer 0 reload data D0 (LSB)  |        |     |    |        | /       |
| 00FF34  | D7  | RLD17 | Timer 1 reload data D7 (MSB)  |        |     |    |        | /       |
|         | D6  | RLD16 | Timer 1 reload data D6        |        |     |    |        |         |
|         | D5  | RLD15 | Timer 1 reload data D5        |        |     |    |        |         |
|         | D4  | RLD14 | Timer 1 reload data D4        | High   | Low | 1  | R/W    |         |
|         | D3  | RLD13 | Timer 1 reload data D3        | riigii | Low | 1  | IX/ VV |         |
|         | D2  | RLD12 | Timer 1 reload data D2        |        |     |    |        |         |
|         | D1  | RLD11 | Timer 1 reload data D1        |        |     |    |        |         |
|         | D0  | RLD10 | Timer 1 reload data D0 (LSB)  |        |     |    |        | /       |
| 00FF35  | D7  | PTD07 | Timer 0 counter data D7 (MSB) |        |     |    |        | /       |
|         | D6  | PTD06 | Timer 0 counter data D6       |        |     |    |        |         |
|         | D5  | PTD05 | Timer 0 counter data D5       |        |     |    |        |         |
|         | D4  | PTD04 | Timer 0 counter data D4       | High   | Low | 1  | R      |         |
|         | D3  | PTD03 | Timer 0 counter data D3       | High   | Low | 1  | I K    |         |
|         | D2  | PTD02 | Timer 0 counter data D2       |        |     |    |        |         |
|         | D1  | PTD01 | Timer 0 counter data D1       |        |     |    |        |         |
|         |     | PTD00 | Timer 0 counter data D0 (LSB) |        |     |    |        | /       |
| 00FF36  | D7  | PTD17 | Timer 1 counter data D7 (MSB) |        |     |    |        | /       |
|         | D6  | PTD16 | Timer 1 counter data D6       |        |     |    |        |         |
|         |     | PTD15 | Timer 1 counter data D5       |        |     |    |        | /       |
|         |     | PTD14 | Timer 1 counter data D4       | High   | Low | 1  | R      |         |
|         | D3  | PTD13 | Timer 1 counter data D3       | 111511 | Low | 1  | "      | /       |
|         | D2  | PTD12 | Timer 1 counter data D2       |        |     |    |        |         |
|         |     | PTD11 | Timer 1 counter data D1       |        |     |    |        |         |
|         | D0  | PTD10 | Timer 1 counter data D0 (LSB) |        |     |    |        | /       |

# I/O Map

| Address | Bit | Name         | Function                                            | 1                    | 0                  | SR | R/W   | Comment             |
|---------|-----|--------------|-----------------------------------------------------|----------------------|--------------------|----|-------|---------------------|
| 00FF21  | D7  | _            | _                                                   | -                    | -                  | -  | _     |                     |
|         | D6  | _            | _                                                   | -                    | -                  | ı  | -     | Constantly "0" when |
|         | D5  | _            | _                                                   | -                    | _                  | -  | -     | being read          |
|         | D4  | _            | _                                                   | -                    | _                  | -  | -     |                     |
|         |     | PPT1         | Programmable timer interrupt priority register      | PPT1 PPT<br>PK11 PK1 | 0 level            | 0  | R/W   |                     |
|         |     | PPT0         |                                                     | 1 1                  | Level 3<br>Level 2 |    |       |                     |
|         |     | PK11<br>PK10 | K10 and K11 interrupt priority register             | 0 1 0                | Level 1<br>Level 0 | 0  | R/W   |                     |
| 00FF23  | D7  | EPT1         | Programmable timer 1 interrupt enable register      |                      |                    |    |       | /                   |
|         | D6  | EPT0         | Programmable timer 0 interrupt enable register      |                      |                    |    |       |                     |
|         | D5  | EK1          | K10 and K11 interrupt enable register               |                      |                    |    |       |                     |
|         | D4  | EK0H         | K04–K07 interrupt enable register                   | Interrupt            | Interrupt          | 0  | R/W   |                     |
|         | D3  | EK0L         | K00–K03 interrupt enable register                   | enable               | disable            | U  | K/W   |                     |
|         | D2  | ESERR        | Serial I/F (error) interrupt enable register        |                      |                    |    |       |                     |
|         | D1  | ESREC        | Serial I/F (receiving) interrupt enable register    |                      |                    |    |       |                     |
|         | D0  | ESTRA        | Serial I/F (transmitting) interrupt enable register |                      |                    |    |       |                     |
| 00FF25  | D7  | FPT1         | Programmable timer 1 interrupt factor flag          | (R)                  | (R)                |    |       | /                   |
|         | D6  | FPT0         | Programmable timer 0 interrupt factor flag          | Interrupt            | No interrupt       |    |       |                     |
|         | D5  | FK1          | K10 and K11 interrupt factor flag                   | factor is            | factor is          |    |       |                     |
|         | D4  | FK0H         | K04–K07 interrupt factor flag                       | generated            | generated          | 0  | R/W   |                     |
|         | D3  | FK0L         | K00-K03 interrupt factor flag                       |                      |                    | U  | IN/ W |                     |
|         | D2  | FSERR        | Serial I/F (error) interrupt factor flag            | (W)                  | (W)                |    |       |                     |
|         | D1  | FSREC        | Serial I/F (receiving) interrupt factor flag        | Reset                | No operation       |    |       | /                   |
|         | D0  | FSTRA        | Serial I/F (transmitting) interrupt factor flag     |                      |                    |    |       | $\bigvee$           |

# **Specifications**

# Control of programmable timer

Vector address setting for programmable timer interrupt (1) timer2ch\_init, pt1\_intr, pt0\_intr: Initialization and interrupt processing for 8-bit reload timer (two channels)

This is an example of using the programmable timer as an 8-bit x 2 system and performs the following settings:

Count mode
 Pulse output channel
 Pulse external (TOUT) output
 Gebit x 2
 Timer 0
 OFF
 (Invalid)

<*Timer 0>* 

• Timer mode Programmable timer (reload mode)

• Count clock fosc3 x 1/16

• Reload data 200 (= 1.6 msec, when fosc3 is 2 MHz)

<*Timer 1>* 

• Timer mode Programmable timer (reload mode)

• Count clock fosc3 x 1/64

• Reload data 250 (= 8 msec, when fosc3 is 2 MHz)

After setting the above, it enables the timer 1 and timer 0 interrupts, and starts each timer. The interrupt level has been set at  $\overline{IRQ3}$  and the respective interrupts are generated in the cycles according to the reload data.

# **Specifications**

# Vector address setting for programmable timer interrupt

# (2) timer1ch\_init, pt0\_intr: Initialization and interrupt processing for 16-bit one-shot timer (one channel)

This is an example of using the programmable timer as a 16-bit x 1 system one-shot timer and performs the following settings:

| • Count mode                   | 16-bit x 1 |            |
|--------------------------------|------------|------------|
| • Pulse output channel         | Timer 0    | (Invalid)  |
| • Pulse external (TOUT) output | OFF _      | (inivalid) |

#### <Timer 0>

• Timer mode Programmable timer (one-shot mode)

• Count clock fosc3 x 1/4

• Reload data 33,200 (= 66.4 msec, when fosc3 is 2 MHz)

*<Timer 1>* Cannot be used

After setting the above, it enables the timer 1 interrupt, and starts the timer.

The interrupt level has been set at  $\overline{IRQ3}$  and an interrupt is generated 66.4 msec after starting.

# Vector address setting for programmable timer interrupt

# (3) evcnt\_init, pt1\_intr, evcnt\_intr: Initialization and interrupt processing for 8-bit event counter

This is an example of using the programmable timer as an 8-bit event counter and 8-bit reload timer, and performs the following settings:

| Count mode                     | 8-bit x 2 |           |
|--------------------------------|-----------|-----------|
| • Pulse output channel         | Timer 0   | (Invalid) |
| • Pulse external (TOUT) output | OFF .     |           |

# <Timer 0>

Timer mode
 Input clock
 Event counter (reload mode)
 K10 with noise rejector

• Count timing Falling edge

• Reload data 0FFH (Event counter initial value)

# <Timer 1>

• Timer mode Programmable timer (reload mode)

• Count clock fosc3 x 1/64

• Reload data 250 (= 8 msec, when fosc3 is 2 MHz)

After setting the above, it enables the the event counter and timer 1 interrupts, and starts each timer.

The interrupt level has been set at  $\overline{IRQ3}$  and an interrupt is generated by the overflow of the event counter or timer 1.

Timer 1 is programmed to generate an interrupt in 8 msec cycles. This example reads the event counter data in the interrupt processing routine and calculates the difference between it and previous count value. This difference is made to the number of clocks that had been input in the 8 msec period.



Fig. 12.1 Event counter processing

### **Specifications**

# Vector address setting for programmable timer interrupt (4) measure\_init, measure\_intr, k1x\_intr: Initialization and interrupt processing for 16-bit pulse width measurement timer

This is an example of using the programmable timer as a 16-bit pulse width measurement timer and performs the following settings:

Count mode
 Pulse output channel
 Pulse external (TOUT) output
 (Invalid)

### <Timer 0>

• Timer mode Pulse width measurement timer (reload mode)

• Measurement period During LOW input

• Count clock fosc3 x 1/1

• Reload data 0FFFFH (Pulse width measurement timer initial value)

### <Timer 1> Cannot be used

After setting the above, it enables the timer 1 and K10 input interrupts, and starts the timer. The interrupt level has been set at  $\overline{IRQ3}$  and an interrupt is generated by the overflow of the timer or K10 input.

Since the fall (count start) and rise (count completion) timings of the K10 input cannot be evaluated by programmable timer control only, a K10 input interrupt is used. Furthermore, in order to be able to generate an interrupt at both falling and rising timings, input interrupt timing is reversed by each interrupt generation in the K1x interrupt processing routine.



Fig. 12.2 Timing of K10 input interrupt generation

### Vector address setting for programmable timer interrupt

### (5) pulsout\_init: 16-bit reload timer pulse output

Outputs TOUT signal from the R27 terminal using the programmable timer as 16-bit reload timer.

Count mode
 Pulse output channel
 Pulse external (TOUT) output
 16-bit x 1
 Timer 0
 ON

(Valid)

### <*Timer 0>*

• Timer mode Programmable timer (reload mode)

• Count clock fosc3 x 1/4

• Reload data 33,200 (= 66.4 msec, when fosc3 is 2 MHz)

### <Timer 1> Cannot be used

According to the above setting, the clock cycle of the TOUT signal is set at 132.8 msec (approximately 7.5 Hz).

### (1) Initialization for 8-bit reload timer (two channels)



### (1) Interrupt processing for 8-bit reload timer (two channels)



### (2) Initialization for 16-bit one-shot timer (one channel)



### (2) Interrupt processing for 16-bit one-shot timer (one channel)













### Notes

- (1) External routines are called for switching to OSC3 and OSC1. (external call: osc1toosc3, osc3toosc1)
- (2) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (3) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than IRQ3 level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (4) The R27 terminal is the common terminal for the normal DC output port and the TOUT output. When TOUT is being output, set R27 register to "1" and control the signal ON/OFF using the TOUT register.
- (5) When the pulse output control is set to off ("0"), the setting of the pulse output channel selection becomes invalid.
- (6) When programmable timer 1 is selected as the clock source for the serial interface, pay attention to the setting value for timer 1, the mode selection for timer 1 and the interrupt setting. Be advised that in this case, it is impossible to use it as a 16-bit timer coupling both timer 0 and timer 1.
- (7) When coupling programmable timers 0 and 1 for use as a 16-bit timer, the setting of timer 0 becomes valid for timer operation and the setting of timer 1 becomes invalid. However, since an interrupt is generated by the underflow of timer 1, set the interrupt related routine with timer 1.
- (8) When stopping the programmable timer by writing "0" into the RUN/STOP control register for the programmable timer 0 and 1, the programmable timer count actually stops when it advances one count with the timing synchronized to the input clock selected with the prescaler dividing clock. For this reason, when the programmable timer stops, if the respective interrupt factors are generated, the respective interrupt factor flags are set and if interrupt is enabled, an interrupt is generated. Thus, you should add an interrupt processing and interrupt factor flag resetting, if necessary.
- (9) A noise reject circuit is not included in the input port (K06, K07, K10, K11). For this reason, when the programmable timer is used for event counter in the program example (3) or for pulse width measurement in the example (4), the following operation will occur if there is chattering in the K10 input, so, input waveform shaping or adding external noise reject processing with an external circuit and software is necessary. In case of the event counter in the program example (3), if there is chattering in the K10 input, the chattering may be counted. In the case of pulse width measurement in the program example (4), if there is chattering in the K10 input, successive interrupts may be generated in the measurement start trigger timing of the rising or falling K10 input.
- (10) When a down-counter underflow occurs, the one-shot timer mode sets the reload register value to the counter data register, to stop the count. For this reason, when you want to continue the count at the same count number, you should restart to timer. If you want to newly set a different count number, set the new value in the reload register, then set it to the count data register, and then start the timer.
- (11) In the examples of programmable timer control programs which use an interrupt, the vector address setting and program have been allocated from 003000H for the sake of convenience. For an example which does not use an interrupt, a specific address has not been allocated as in the examples in other chapters.

```
Control of programmable timer 1
        external
                    osc1toosc3,osc3toosc1
        public
                    timer2ch_init,pt1_intr,pt0_intr
pt1_vector
              equ
                    000006h
                                               ;timer 0 interrupt vector offset
pt0_vector
                    000008h
                                               ;timer 1 interrupt vector offset
              equ
                    003000h
                                               ;program start address offset
pt
              equ
br_io
                    0ffh
                                               ;base reg. address (set i/o area)
              equ
                                               ;programmable timer mode set reg. 0
pt mode0
              equ
                    00ff30h
pt_mode1
                    00ff31h
                                               ;programmable timer mode set reg. 1
              equ
pt_mode2
              equ
                    00ff32h
                                               ;programmable timer mode set reg. 2
rld0
                    00ff33h
                                               ;programmable timer 0 reload data
              equ
rld1
                    00ff34h
                                               ;programmable timer 1 reload data
              equ
intr_pr1
              equ
                    00ff21h
                                               ;interrupt priority reg. 1
                                               interrupt enable reg. 1;interrupt factor flag reg. 1
intr_en1
intr_fac1
                    00ff23h
              equ
              eau
                    00ff25h
        code
Vector address setting for programmable timer interrupt
intr vectors:
        orq
              intr_vectors+pt1_vector
        dw
              pt1_intr
                                               ;programmable timer 1 interrupt
              intr_vectors+pt0_vector
        ora
                                               ;programmable timer 0 interrupt
        dw
              pt0_intr
(1) Initialization for 8-bit reload timer (two systems)
              intr_vectors+pt
        org
timerdata8_0: db
                    200
                                               ;timer 0 reload data (1.6ms at 2mhz/16)
timerdata8_1: db
                                               ;timer 1 reload data ( 8ms at 2mhz/64)
                    250
; *
;*
        8-bit * 2-channel reload timer
;*** initialize routine
timer2ch_init:
        ld
              br.#br io
                                               ;set br reg. address to Offxxh
        carl oscltoosc3
                                               ; change osc1 to osc3 ***
;mode16=8bit*2,chsel=timer0,ptout=off,cksel1&0=fosc3
              [br:low pt mode0], #00000011b
        ld
              a,[loc timerdata8_0]
        1 d
        1d
              [br:low rld0],a
                                               ;set reload data (timer 0)
              a,[loc timerdata8_1]
        ld
        ld
              [br:low rld1],a
                                              ;set reload data (timer 1)
;pt0:evcnt=timer,fcsel=normal timer,plpol=don't care,psc=fosc3/16,rlmd0=reload
;pset0=preset
        ld
              [br:low pt_model], #00010110b
;pt1:psc=fosc3/64,rlmd1=reload,pset1=preset
        ld
              [br:low pt_mode2],#00011110b
        or
              [br:low intr_pr1], #00001100b
                                              ;set pt=/irq3
                                              ;ept1&0 intr. en.
              [br:low intr_en1],#11000000b
        or
        or
              [br:low pt_mode1],#00000001b
                                               ;start timer 0
              [br:low pt_mode2],#0000001b
                                               ;start timer 1
        or
        ld
              a.sc
              a,#00111111b
        and
        or
              a,#10000000b
        ld
              sc,a
                                               ;i0 flag clear (en. /irq3 intr.)
```

```
;*** start programmable timer 0 & 1 interrupt
     (user program)
;*** end processing
         [br:low pt_model],#11111110b ;stop timer 0 [br:low pt_mode2],#11111110b ;stop timer 1
      and
      and
      ret.
(1) Interrupt processing for 8-bit reload timer (two systems)
; *
   programmable timer 1 interrupt processing routine (reload mode)
;*
pt1_intr:
     push ale
     ld br,#br_io
                                 ;set br reg. address to Offxxh
     programmable timer 1 processing
          [br:low intr_fac1],#10000000b ;clear fpt1 interrupt flag
      and
     pop
     rete
;*
; *
    programmable timer 0 interrupt processing routine (reload mode)
; *
pt0_intr:
     push ale
     ld br,#br_io
                                 ;set br reg. address to Offxxh
     programmable timer 0 processing
          [br:low intr_fac1],#01000000b ;clear fpt0 interrupt flag
      and
      pop
          ale
      rete
      end
```

```
Control of programmable timer 2
                   osc1toosc3,osc3toosc1
                   timer1ch_init,pt0_intr
        public
        public
                   timeup
pt1_vector
            equ
                   000006h
                                              ;timer 1 interrupt vector offset
             equ
                   003000h
                                              ;program start address offset
pt.
                   0ffh
br_io
              equ
                                             ;base reg. address (set i/o area)
pt_mode0
                    00ff30h
                                              ;programmable timer mode set reg. 0
              equ
pt mode1
                   00ff31h
                                              ;programmable timer mode set reg. 1
              equ
rld0
                    00ff33h
                                              ;programmable timer 0 reload data
              equ
rld1
              equ
                   00ff34h
                                              ;programmable timer 1 reload data
intr_pr1
                   00ff21h
                                             ;interrupt priority reg. 1
             equ
                   nnff23h
intr_en1
              equ
                                             ;interrupt enable reg. 1
intr_fac1
                   00ff25h
                                             ;interrupt factor flag reg. 1
              equ
        data
timeup:
              db
                   [1]
                                             ;timeup flag
        code
Vector address setting for programmable timer interrupt
intr vectors:
        org
              intr_vectors+pt1_vector
        dw
             pt1_intr
                                             ;programmable timer 0 interrupt
;
(2) Initialization for 16-bit one-shot timer (one system)
              intr_vectors+pt
;timer16 reload data (66.4ms at 2mhz/4)
; *
;*
        16-bit * 1-channel one shot timer
;*
;*** initialize routine
timer1ch_init:
        ld
                                             ;set br reg. address to Offxxh
                                             ; change osc1 to osc3 ***
        carl osc1toosc3
;mode16=16-bit,chsel=timer0,ptout=off,cksel1=dont't care,ckse0=fosc3
        ld [br:low pt_mode0],#00010001b
        ld
              ba,[loc timerdata16]
                                             ;set 16-bit reload data (timer 0 & 1)
             [lod rld0],ba
        14
;pt0:evcnt=timer,fcsel=normal timer,plpol=don't care,psc=fosc3/4,rlmd0=oneshot
;pset0=preset
              [br:low pt_mode1],#00001010b
        1 d
        or
              [br:low intr_pr1],#00001100b
                                             ;set pt=/irq3
                                             ;ept1 intr. en.
;start timer 0
              [br:low intr_en1],#10000000b
        or
        or
              [br:low pt_mode1], #00000001b
        14
              a,sc
        and
              a,#00111111b
              a,#10000000b
        or
                                             ;i0 flag clear (en. /irq3 intr.)
        14
              sc.a
        xor
              a,a
        ld
             [lod timeup],a
```

```
Source List
;*** start programmable timer 0 (16-bit) interrupt
timer1ch_init01:
     ld a,[lod timeup]
;*** end processing
      ret.
(2) Interrupt processing for 16-bit one-shot timer (one system)
programmable timer 1 interrupt processing routine (one-shot mode) *
;*
pt0_intr:
     push ale
      ld
         br,#br_io
                              ;set br reg. address to Offxxh
      ld
         a,#0ffh
         [lod timeup],a
                              ;timeup flag set
      ld
     programmable timer 0 processing
     and
         [br:low intr_fac1],#10000000b ;clear fpt1 interrupt flag
      pop
      rete
      end
```

```
Control of programmable timer 3
        external
                    osc1toosc3,osc3toosc1
        public
                    evcnt_init,evcnt_intr,pt1_intr
        public
                   pre count, count, ovf flag
pt1_vector
              equ
                    000006h
                                              ;timer 1 interrupt vector offset
                    000008h
                                              ; event counter interrupt vector offset
evcnt_vector
             equ
                    003000h
                                              ;program start address offset
event.
              eau
br_io
              equ
                    Offh
                                              ;base reg. address (set i/o area)
pt_mode0
                    00ff30h
                                              ; event counter timer mode set reg. 0
              equ
pt_mode1
                                              ; event counter mode set reg. 1
                    00ff31h
              equ
pt_mode2
              equ
                    00ff32h
                                              ;programmable timer mode set reg. 2
rld0
              equ
                    00ff33h
                                              ; event counter reload data
rld1
                    00ff34h
                                              ;programmable timer 1 reload data
              ean
ptd0
                    00ff35h
                                              ; event counter counting data
              equ
ptd1
              equ
                    00ff36h
                                              ;programmable timer 1 counter data
                    00ff21h
intr_pr1
              eau
                                              ;interrupt priority reg. 1
                    00ff23h
intr_en1
              equ
                                              ;interrupt enable reg. 1
intr_fac1
              equ
                    00ff25h
                                              ;interrupt factor flag reg. 1
       data
pre_count:
              db
                    [1]
                                              ;previous event counter data
              db
                    [1]
                                              ;present event counter data
count:
ovf_flag:
                    [1]
                                              event counter overflow flag
              db
        code
Vector address setting for 8-bit event counter interrupt
intr_vectors:
        org
              intr_vectors+pt1_vector
              pt1_intr
;
        orq
              intr_vectors+evcnt_vector
        dw
              evcnt_intr
                                              ; event counter overflow interrupt
(3) Initialization for 8-bit event counter
              intr vectors+evcnt
        orq
;timer 1 reload data ( 4msec at 4mhz/64)
;*
;* 8-bit event counter (timer 0) counting between 4msec (reload timer 1) *
;*** initialize routine
evcnt_init:
              br, #br_io
                                              ;set br reg. address to Offxxh
        carl osc1toosc3
                                              ; change osc1 to osc3 ***
;mode16=8-bit,chsel=timer 0,pulse output=off,cksel1=fosc3,cksel0=don't care
        ld
              [br:low pt_mode0], #00000011b
              a,#0ffh
        1 d
        ld
              [br:low rld0],a
                                              ;set event counter init data (max.)
        ld
              [lod pre_count],a
                                              ;pre event counter data set
        ld
             a,[loc timerdata8_2]
        ld
             [br:low rld1],a
                                              ;set reload data (timer 1)
;pt0:evcnt=event counter,fcsel=with noise rejector,plpol=falling edge
;psc1&0=don't care,rlmd0=reload,pset0=preset,prrun0=stop
              [br:low pt_model], #11000110b
        ld
;pt1:psc=fosc3/64,rlmd1=reload,pset1=preset
            [br:low pt_mode2],#00011110b
```

```
or
      or
      or
      or
      ld
          a,sc
          a,#00111111b
      and
          a,#10000000b
      or
      ld
                                   ;i0 flag clear (en. /irq3 intr.)
          sc.a
      xor
          a.a
      ld
          [lod ovf_flag],a
                                   ;overflow flag clear
;*** start event counter (timer 0) and programmable timer 1 interrupt
;
      (user program)
100p:
      ld
         a,[lod ovf_flag]
          a,#0ffh
                                   ; event counter overflow ?
      ср
         nz,evcnt_init00
                                   ;--> normal
      jrs
;*** event counter overflow processing
     (user program)
;
;*** normal processing
evcnt_init00:
     (user program)
event_init02:
jrs loop ;-->
;*** end processing
      and [br:low pt_mode1],#11111110b ;stop event counter and [br:low pt_mode2],#11111110b ;stop timer 1
      ret
(3) Interrupt processing for 8-bit event counter
; *
   programmable timer 1 interrupt processing routine (reload mode)
; *
pt1_intr:
     push ale
      ld br, #br_io
                                   ;set br reg. address to Offxxh
      ld
         a,[br:low ptd0]
                                   ;read event counter counting data
          [lod count],a
[br:low pt_model],#11111110b
[br:low pt_model],#00000010b
;set event counter next data (max.)
      ld
      and
      or
      ld
          a,[lod pre_count]
         a,[lod count]
      sub
                                   ;a-reg. = input count number (4 msec)
;
      programmable timer 1 processing (based on event counter counting data)
          a,[lod count]
      1d
          1 d
      and
      ana
          ale
      rete
```

```
;* event counter (timer 0) interrupt processing routine (counter overflow) *
evcnt_intr:
    push ale
       br,#br_io
                          ;set br reg. address to Offxxh
    ld
       a,#0ffh
    ld
       [lod ovf_flag],a
    ld
    and
    event counter overflow processing
       [br:low intr_fac1],#01000000b ;clear fpt0 interrupt flag
    and
    pop
    rete
    end
```

### Control of programmable timer 4

```
external
                       osc1toosc3,osc3toosc1
         public
                       measure_init,measure_intr
         public
                       count, ovf flag, klx intr
measure_vector equ
                       000006h
                                                     ;measure interrupt vector offset
                       00000ah
                                                     ;klx interrupt vector offset
k1x_vector
                equ
pm
                       003000h
                                                     ;program start address offset
                eau
br_io
                equ
                       Offh
                                                     ;base reg. address (set i/o area)
pt_mode0
                       00ff30h
                                                     ;pulse width measure mode set reg. 0
                equ
pt mode1
                       00ff31h
                                                     ;pulse width measure mode set req. 1
                equ
rldO
                equ
                       00ff33h
                                                     ;pulse width measure (low) reload data
rld1
                       00ff34h
                                                     ;pulse width measure (high) reload data
                equ
ptd0
                       00ff35h
                                                     ipulse width measure (low) count data
ipulse width measure (high) count data
                ean
ptd1
                       00ff36h
                equ
sik1
                equ
                       00ff51h
                                                     ;interrupt selection reg. for klx
kcp1
                equ
                       00ff53h
                                                     ;interrupt comparison reg. for klx
k1d
                       00ff55h
                                                     ;input data from klx
                eau
intr_pr1
                equ
                       00ff21h
                                                     ;interrupt priority reg. 1
intr_en1
intr_fac1
                                                     ;interrupt enable reg. 1;interrupt factor flag reg. 1
                       00ff23h
                eau
                       00ff25h
                equ
         data
                dw
                                                     ;pulse width measured data
count:
                       [1]
ovf_flag:
                db
                       [1]
                                                     ; event counter overflow flag
         code
```

### Vector address setting for 16-bit pulse width measurement timer interrupt

### (4) Initialization for 16-bit pulse width measurement timer

```
intr_vectors+pm
                           .
***********************
; *
;* 16-bit pulse width measurement (timer 0) between k10 "low" input term *
;*** initialize routine
measure_init:
        14
             br, #br_io
                                             ;set br reg. address to Offxxh
        carl oscltoosc3
                                             ; change osc1 to osc3 ***
;mode16=16-bit,chsel=timer 0,pulse output=off,cksel1=don't care,cksel0=fosc3
        ld
             [br:low pt_mode0],#00011001b
             ba,#0ffffh
        1d
             [lod rld0],ba
        ld
                                             ;set measure counter init data (max.)
;pt0:evcnt=timer,fcsel=pulse width measurement,plpol=low level measurement
;psc=fosc3/1,rlmd0=reload,pset0=preset,prrun0=stop
             [br:low pt_mode1],#01000110b
        ld
        ld
              [br:low kcp1],#0000001b
                                             ;k10 falling edge ("h" -> "l")
        14
             [br:low sik1],#0000001b
                                            ;k10 interrupt enable
             [br:low intr_pr1],#00001111b
                                            ;set pt & pkl=/irq3
;eptl & ekl intr. en.
        or
        or
             [br:low intr_en1],#10100000b
             [br:low pt_model], #00000001b
                                            ;start pulse measurement
```

```
ld
          a,sc
         a,#00111111b
      and
      or
          a,#10000000b
                                 ;i0 flag clear (en. /irq3 intr.)
      ld
         sc,a
      xor
         a,a
         [lod ovf_flag],a
     ld
                                overflow flag clear;
;*** start measure counter (16-bit timer 0)
     (user program)
wait_loop:
     ld a,[lod ovf_flag]
;measure counter overflow ?
;*** measure counter overflow processing
;
   (user program)
         measure_init02
     jrs
;*** normal processing
measure_init00:
     (user program)
measure_init02:
jrs wait_loop;*********
                                 ;-->
                ********
;*** end processing
     and
         [br:low pt_model],#11111110b ;stop measure counter
      ret
(4) Interrupt processing for 16-bit pulse width measurement timer
;* measure counter (16-bit timer 0) interrupt processing routine (overflow) *
measure_intr:
     push ale
     ld br, #br_io
                                 ;set br reg. address to Offxxh
      ld
         a,#0ffh
          [lod ovf_flag],a
     ld
                                ; event counter overflow flag set
     and [br:low pt_model],#11111110b
                                ;measure counter stop
     measure counter overflow processing
         [br:low intr_fac1],#1000000b
                                ;clear fpt1 interrupt flag
      and
      pop
          ale
      rete
;*
;*
     klx interrupt processing routine
klx_intr:
     push ale
                                 ;set br reg. address to Offxxh
     ld br,#br_io
```

```
bit
               [br:low kcp1],#0000001b
                                                  ;kcp setting ?
         jrs
               z,k1x_intr01
;falling edge -> rising edge
              [br:low kcp1],#11111110b
                                                  ;set rising edge
         and
         jrs
              k1x_intr00
;rising edge -> falling edge
klx_intr01:
               [br:low kcp1],#00000001b
ba,[lod ptd0]
                                                  ;set falling edge
         or
         ld
         ld
               [lod count],ba
                                                  ;read measure count data
               [br:low pt_model],#00000010b
         or
                                                  ;set measure counter init data (max.)
k1x_intr00:
         and
               [br:low intr_fac1],#00100000b
                                                 ;clear fk1 interrupt flag
         pop
         rete
         end
```

```
Control of programmable timer 5
       external
                 osc1toosc3,osc3toosc1
       public
                 pulsout_init
br_io
                 Offh
                                       ;base reg. address (set i/o area)
           equ
        equ
pt_mode0
                 00ff30h
                                       ;programmable timer mode set reg. 0
pt_mode1
                 00ff31h
                                       ;programmable timer mode set reg. 1
           equ
                                       ;programmable timer 0 reload data
rld0
                 00ff33h
           equ
                 nnff34h
rld1
           equ
                                       ;programmable timer 1 reload data
hzr2
                 00ff71h
                                       ;r2x output control reg.
            equ
r2d
                 00ff75h
                                       ;r2x output data
           ean
intr_pr1
           equ
                 00ff21h
                                       ;interrupt priority reg. 1
intr_en1
           equ
                 00ff23h
                                       ;interrupt enable reg. 1
                 00ff25h
                                       ;interrupt factor flag reg. 1
           equ
intr_fac1
(5) 16-bit reload timer pulse output
;pulse output=66.4ms(approx. 15hz)
;timer16 reload data (66.4ms at 2mhz/4)
;*
      pulse out (16-bit) control
; *
;*** initialize routine
pulsout_init:
       1d
            br, #br_io
                                       ;set br reg. address to Offxxh
       carl osc1toosc3
                                       ; change osc1 to osc3 ***
                                       ;r27="h" (enable ptout)
;r27=complementary output
       or
            [br:low r2d],#10000000b
           [br:low hzr2],#01111111b
       and
;mode16=16-bit,chsel=timer0,ptout=off,cksel1=don't care,cksel0=fosc3
       ld
            [br:low pt_mode0],#00011001b
            ba,[loc timerdata16]
       ld
                                       ;set 16-bit counter data (timer 0 & 1)
       ld
           [lod rld0],ba
;pt0:evcnt=timer,fcsel=normal timer,plpol=don't care,psc=fosc3/4,rlmd0=reload
;pset0=preset
       ld
            [br:low pt_model],#00001110b
            [br:low pt_mode1],#0000001b
       or
                                       ;start timer 0
          [br:low pt_mode0],#00000100b
                                       ;start ptout
       or
;*** start pulse out (16-bit)
      (user program)
;*** end processing
            and
       and
       end
```

## 13 LCD CONTROLLER

### I/O Map

| Address | Bit | Name  | Function                                  | 1              | 0              | SR | R/W | Comment              |
|---------|-----|-------|-------------------------------------------|----------------|----------------|----|-----|----------------------|
| 00FF10  | D7  | _     | _                                         | -              | -              | _  | -   | Constantry "0" when  |
|         | D6  | _     | _                                         | -              | -              | _  | _   |                      |
|         | D5  | _     | _                                         | -              | -              | _  | -   | being read           |
|         | D4  | LCCLK | CL output control for expanded LCD driver | On             | Off            | 0  | R/W |                      |
|         | D3  | LCFRM | FR output control for expanded LCD driver | On             | Off            | 0  | R/W |                      |
|         | D2  | DTFNT | R/W register                              | -              | -              | 0  | R/W |                      |
|         | D1  | LDUTY | R/W register                              | -              | -              | 0  | R/W |                      |
|         | D0  | SGOUT | R/W register                              | -              | -              | 0  | R/W |                      |
| 00FF11  | D7  | _     | _                                         | _              | -              | _  | _   | "0" when being read  |
|         | D6  | DSPAR | LCD display memory area selection         | Display area 1 | Display area 0 | 0  | R/W |                      |
|         | D5  | LCDC1 | LCD display control                       | _              | -              | 0  | R/W |                      |
|         |     |       | LCDC1 LCDC0 LCD display                   |                |                |    |     | These bits are reset |
|         |     |       | 1 1 All LCDs lit                          |                |                |    |     | to (0, 0) when       |
|         | D4  | LCDC0 | 1 0 All LCDs out                          | _              | -              | 0  | R/W | SLP instruction      |
|         |     |       | 0 1 Normal display                        |                |                |    |     | is executed.         |
|         |     |       | 0 0 Drive off                             |                |                |    |     |                      |
|         | D3  | LC3   | LCD contrast adjustment                   |                |                | 0  | R/W |                      |
|         | D2  | LC2   | LC3 LC2 LC1 LC0 Contrast  1 1 1 Dark      | _              | _              | 0  | R/W |                      |
|         | D1  | LC1   | 1 1 1 0 :                                 | _              | _              | 0  | R/W |                      |
|         | D0  | LC0   | 0 0 0 0 Light                             | _              | _              | 0  | R/W |                      |

### **Specifications**

### Control of LCD controller

### (1) Icd\_init: Initialization for LCD controller

Sets the LCD controller as follows:

LCD dot matrix typeLCD drive duty5 x 81/18

LCD display control
 Contrast
 Normal display
 Middle (8/16)

CL outputFR outputON

### (2) control\_example, display\_frame, display\_1ch: Display control

By specifying the front address of the string stored in memory and the display memory address (display position), data in the character generator table are written to display memory and are shown on the LCD panel.

The message to be displayed is an ASCII code string and "00H" should be added to the end of the string as an end mark.

Display example: "s" "m" "c" "8" "8" "3" "1" "6" 00H

 $5 \times 8$ -dot character data are stored in the character generator ascii\_table in ASCII code order. A character is configured with 5 bytes of data. Consequently, data for the character code "n" should be stored in 5 bytes from ascii\_table + (n  $\times 5$ ) address.



Fig. 13.1 Configuration of character data

### Note

R26 and R25 terminals are common to the normal DC output port and CL output, and FR output. When performing CL and FR output to expand the LCD driver externally, set the R26 and R25 registers at "1" and control the signal ON/OFF using the LCCLK and LCFRM registers.



```
Control of LCD controller
       public
                 lcd_init,display_frame,display_1ch
offset
                  30h*5
                                         ;ascii code table address offset
            equ
                                         ;base reg.address (set i/o area)
br_io
                 0ffh
            equ
1cd_mode0
        equ
equ
                 00ff10h
                                         ;lcd controller mode set reg. 0
lcd_mode1
                 00ff11h
                                         ;lcd controller mode set reg. 1
            equ
                                         ;r2x output control data
hzr2
                 00ff71h
            equ
                 00ff75h
                                         ;r2x output data
r2d
            equ
        equ
equ
lcd_ram0
                 00f800h
                                        ;lcd ram line 0 top address
lcd_ram1
                 00f900h
                                         ;lcd ram line 1 top address
lcd_ram2
            equ
                 00fa00h
                                         ;lcd ram line 2 top address
1cd ram3
                 00fb00h
                                        ;lcd ram line 3 top address
            eau
       code
(1) Initialization for LCD controller
;*
       lcd display control
; *
;*** initialize routine
lcd_init:
                                        ;set br reg. address to Offxxh
;r26,r25="h" (fr,cr enable)
       14
            br,#br_io
           [br:low r2d],#01100000b
[br:low hzr2],#1001111b
       or
       and
                                        ;r26,r25=complementary output
                                                                          (1)
;lcclk,lcfrm=on
      ld [br:low lcd_mode0],#00011000b
;lcdc=normal,lc=middle contrast
       ld [br:low lcd_model],#00011000b
(2) Display control
;*** control program example routine
control_example:
       ld ix,#loc frame00
                                        ;display message
            iy,#lod lcd_ram0+1*5
                                        display address
       14
       carl display_frame
                                         display frame ***
      (user program)
dispaly frame
; *
       ix : message top address
; *
         iy : display top address
                                                                          (2)
; *********************************
;*** control routine
display_frame:
       ld a,[ix]
            a,#00h
       ср
                                         ;end mark ?
           z,display_frame00
       jrs
                                         ;exit
       cars display_1ch
                                        ;display 1 character ***
       inc
            ix
       add
            iy,#5
                                         ;display address + 5 (5*8 dots)
       jrs
           display_frame
                                         ;up end mark detect
display_frame00:
       ret
```

```
; *
; *
       display 1 character (from ascii code to 5*8 dots dot matrix)
; *
         ix : message pointer index
; *
         iy : store pointer index
; *
display_1ch:
      push ix
      push
           iу
           hĪ
      push
       push ba
       ld
           1,#5
      mlt
                                      ;hl <- a-reg*5
          hl,#loc ascii_table
                                      ;hl <- hl + ascii_table top address</pre>
      add
       ld
           ix,hl
      ld
           b,#5
                                      ;5 bytes data
display_1char00:
       1d
           [iy],[ix]
       inc
           ix
       inc
           iy
           nz,display_1char00
       djr
      pop
           ba
                                                                     (2)
           hl
      pop
      pop
           iy
       pop
           ix
      ret.
;
;*** messeage frame example
frame00:
      ascii "E0C88365"
                                      end mark;
;*** ascii character table (example)
ascii_table:
       character code 00h to 2fh have not been used in this example
           ascii_table+offset
       ora
                                      ;"0",30h
;"1",31h
            3eh,51h,49h,45h,3eh
       db
       db
            00h,42h,7fh,40h,00h
                                      ;"2",32h
      db
            42h,61h,51h,49h,46h
            (user defined)
       character generator table (5*8 dots)
           (user defined)
       end
```

## 14 SOUND GENERATOR

### I/O Map

| Address | Bit | Name  | Function                                                                     | 1             | 0            | SR | R/W | Comment             |  |
|---------|-----|-------|------------------------------------------------------------------------------|---------------|--------------|----|-----|---------------------|--|
| 00FF44  | D7  | _     | _                                                                            | -             | -            | _  | _   | Constantry "0" when |  |
|         | D6  | BZSTP | One-shot buzzer forcibly stop                                                | Forcibly stop | No operation | _  | W   | being read          |  |
|         | D5  | BZSHT | One-shot buzzer trigger/status R                                             | Busy          | Ready        | 0  | R/W |                     |  |
|         |     |       | W                                                                            | Trigger       | No operation |    |     |                     |  |
|         | D4  | SHTPW | One-shot buzzer duration width selection                                     | 125 msec      | 31.25 msec   | 0  | R/W |                     |  |
|         | D3  | ENRTM | Envelope attenuation time                                                    | 1 sec         | 0.5 sec      | 0  | R/W | "0" when being read |  |
|         | D2  | ENRST | Envelope reset                                                               | Reset         | No operation | _  | W   |                     |  |
|         | D1  | ENON  | Envelope On/Off control                                                      | On            | Off          | 0  | R/W | *1                  |  |
|         | D0  | BZON  | Buzzer output control                                                        | On            | Off          | 0  | R/W |                     |  |
| 00FF45  | D7  | _     | _                                                                            | -             | -            | _  | _   | "0" when being read |  |
|         | D6  | DUTY2 | Buzzer signal duty ratio selection                                           | -             | -            | 0  | R/W | /                   |  |
|         |     |       | DUTY2-1 Buzzer frequency (Hz)  2 1 0 fosci/8 fosci/10 fosci/12 fosci/14      |               |              |    |     | /                   |  |
|         |     |       | 2 1 0 fosci/8 fosci/10 fosci/12 fosci/14 fosci/28 fosci/26 fosci/26 fosci/28 |               |              |    |     | /                   |  |
|         | D5  | DUTY1 | 0 0 0 8/16 8/20 12/24 12/28                                                  | _             | -            | 0  | R/W |                     |  |
|         |     |       | 0 0 1 7/16 7/20 11/24 11/28<br>0 1 0 6/16 6/20 10/24 10/28                   |               |              |    |     |                     |  |
|         |     |       | 0 1 1 5/16 5/20 9/24 9/28                                                    |               |              |    |     |                     |  |
|         | D4  | DUTY0 | 1 0 0 4/16 4/20 8/24 8/28                                                    | _             | -            | 0  | R/W |                     |  |
|         |     |       | 1 0 1 3/16 3/20 7/24 7/28<br>1 1 0 2/16 2/20 6/24 6/28                       |               |              |    |     |                     |  |
|         |     |       | 1 1 1 1/16 1/20 5/24 5/28                                                    |               |              |    |     | /                   |  |
|         | D3  | _     | _                                                                            | _             | -            | _  | -   | "0" when being read |  |
|         | D2  | BZFQ2 | Buzzer frequency selection                                                   | _             | -            | 0  | R/W | /                   |  |
|         |     |       | BZFQ2 BZFQ1 BZFQ0 Frequency (Hz)                                             |               |              |    |     |                     |  |
|         |     |       | 0 0 0 fosc1/8                                                                |               |              |    |     |                     |  |
|         | D1  | BZFQ1 | 0 0 1 fosc1/10                                                               | _             | _            | 0  | R/W | /                   |  |
|         |     |       | 0 1 0 fosci/12                                                               |               |              |    |     |                     |  |
|         |     |       | 0 1 1 fosc1/14<br>1 0 0 fosc1/16                                             |               |              |    |     | /                   |  |
|         | D0  | BZFQ0 | 1 0 0 losci/10<br>1 0 1 fosci/20                                             | _             |              | 0  | R/W | /                   |  |
|         |     |       | 1 1 0 fosc1/24                                                               |               |              |    |     | /                   |  |
|         |     |       | 1 1 1 fosc1/28                                                               |               |              |    |     | /                   |  |

<sup>\*1</sup> Reset to "0" during one-shot output.

### **Specifications**

### Control of sound generator

### (1) sound\_init: Initialization for sound generator

Enables the buzzer output from R50 terminal.

### (2) normal\_init, normal\_on, normal\_off: Normal buzzer output

The normal\_init routine sets the duty ratio of the buzzer signal to maximum and the frequency to 4,096 Hz. There is buzzer output when normal\_on has been called until normal\_off is called.

### (3) envelope\_init, envelope\_on, envelope\_reset, envelope\_off: Buzzer output with digital envelope

The envelope\_init routine sets the buzzer signal frequency to 4,096 Hz and the envelope attenuation time to 1 sec and then turns the envelope ON.

There is buzzer output when envelope\_on has been called until envelope\_off is called. The envelope\_reset routine re-sets the buzzer signal frequency to 2,048 Hz and the envelope attenuation time to 0.5 sec and then resets the envelope. The envelope is reset by calling envelope reset during output period of a buzzer with envelope.

### (4) oneshot\_ready, oneshot\_on, oneshot\_off: One-shot buzzer output

The oneshot\_ready routine sets the one-shot buzzer pulse width to 125 msec and waits until the one-shot buzzer output has shifted to READY status. One-shot buzzer output is done by calling oneshot\_on. Buzzer output is 125 msec when called by oneshot\_on, but even in that time, the one-shot buzzer output can be forcibly terminated by calling oneshot\_off.





### Note

The R50 terminal is common to the normal DC output port and the buzzer output. When a buzzer circuit has been configured with the R50 terminal, set the R50 register to "1" and control the signal ON/OFF using the BZON register.

```
Control of sound generator
        public
                   sound_init
        public
                   normal_init,normal_on,normal_off
        public
                   envelope_init,envelope_on,envelope_reset,envelope_off
       public
                   oneshot_ready,oneshot_on,oneshot_off
br_io
             equ
                   0ffh
                                             ;base reg. address (set i/o area)
sound_mode0
                   00ff44h
                                             ; sound generator mode set reg. 0
             equ
                   00ff45h
sound_mode1
             equ
                                             ; sound generator mode set reg. 1
                   00ff70h
                                             ; expand output control reg.
hzr ex
             equ
r5d
             equ
                   00ff78h
                                             ;r5x output data
        code
(1) Initialization for sound generator
; *
        sound genertator control
; ***********************
sound_init:
        ld
             br, #br_io
                                            ;set br reg. address to Offxxh
             [br:low r5d],#11111110b
                                            ;r50="1" (bzon enable)
                                                                                 (1)
        and
             [br:low hzr_ex],#10111111b
                                            ;r50=complementary output
        and
        ret
(2) Normal buzzer output
   *********************
;*** sound normal
normal_init:
       ld
             [br:low sound_mode1], #00000000b
                                            ;duty=max.,bzfq=4096hz
        ret.
normal_on:
                                                                                 (2)
             [br:low sound_mode0],#0000001b
                                            ;bzon=enable
       or
       ret
; * * *
normal off:
        and
             [br:low sound_mode0],#11111110b
                                            ;bzon=disable
        ret
(3) Buzzer output with digital envelope
; *** sound envelope
envelope_init:
        ld
              [br:low sound_model], #00000000b
                                             ;duty=don't care,bzfq=4096hz
             [br:low sound_mode0],#00001010b
                                            ;enrtm=1sec,enon=on
        or
       ret
; * * *
envelope on:
                                                                                 (3)
             [br:low sound_mode0],#00000001b
                                            ;bzon=enable (with envelope)
        or
        ret
;***
; envelope reset then on (change envelope release time & buzzer frequency)
envelope_reset:
        ld
             [br:low sound_model],#00000100b ;duty=don't care,bzfq=2048hz
```

```
Source List
         ld
               a,[br:low sound_mode0]
               a,#00000011b
         and
                                                 ;enrtm=0.5sec
         or
               a,#00000100b
                                                 ;envelope reset
         ld
               [br:low sound_mode0],a
                                                                                      (3)
         ret
 ; * * *
 envelope_off:
               [br:low sound_mode0],#11111110b
                                                ;bzon=disable
         and
         ret.
 (4) One-shot buzzer output
 ;*** sound oneshot
 oneshot_ready:
               [br:low sound_mode0],#00010000b ;one shot width=125ms [br:low sound_mode0],#00100000b ;one shot ready ?
         or
         bit
              nz,oneshot_ready
         jrs
 ;
 ;***
 oneshot_on:
         ld
               a,[br:low sound_mode0]
         and
               a,#00011111b
                                                                                      (4)
               a,#00100000b
         or
         ld
               [br:low sound_mode0],a
                                                ; one shot buzzer on
         ret
 ;***
 oneshot_off:
         ld
               a,[br:low sound_mode0]
         and
               a,#00011111b
               a,#01000000b
         or
                                       ;no status read stop
               [br:low sound_mode0],a
         ld
         ret
         end
```

## 15 ANALOG COMPARATOR

### I/O Map

| Address | Bit | Name   | Function                    | 1   | 0   | SR | R/W | Comment             |
|---------|-----|--------|-----------------------------|-----|-----|----|-----|---------------------|
| 00FF13  | D7  | _      | _                           | -   | -   | _  | _   |                     |
|         | D6  | _      | _                           | -   | -   | _  | _   | Constantly "0" when |
|         | D5  | _      | _                           | -   | -   | _  | _   | being read          |
|         | D4  | _      | _                           | -   | -   | _  | _   |                     |
|         | D3  | CMP10N | Comparator 1 On/Off control | On  | Off | 0  | R/W |                     |
|         | D2  | CMP0ON | Comparator 0 On/Off control | On  | Off | 0  | R/W |                     |
|         | D1  | CMP1DT | Comparator 1 data           | +>- | +<- | 0  | R   |                     |
|         | D0  | CMP0DT | Comparator 0 data           | +>- | +<- | 0  | R   |                     |

### **Specifications**

### Control of analog comparator

### (1) comp\_init: Initialization for analog comparator

Sets I/O port P17–P14 to the input mode in order to prevent a malfunction.

### (2) comp\_control: Data reading for analog comparator

Sets the analog comparator to ON and reads the comparator data after calling a delay routine. Executes subsequent processing according to the results of the read.



### Notes

- (1) A delay routine for the operation stabilization waiting time (3 msec, maximum) of the analog comparator is not included in this program example, so it is necessary to create it using a hardware timer or software timer. (external call: comp\_delay)
- (2) P17–P14 terminals are common to the analog comparator inputs (CMPM0, CMPP0, CMPM1 and CMPP1) and the I/O port, and these are switched to I/O port terminals when the analog comparator is turned OFF. Consequently, for an I/O port which is used for an analog comparator, be sure to set in input mode.

```
Control of analog comparator
       external
                   comp delay
       public
                   comp_init,comp_control
br io
             equ
                   Offh
                                            ;base reg. address (set i/o area)
comp_mode
             equ
                   00ff13h
                                            ;analog comparator mode set reg.
ioc1
             equ
                   00ff61h
                                            ;plx i/o control reg.
p1d
                   00ff63h
                                            ;plx port data
             equ
       code
(1) Initialization for analog comparator
;*
       comparator control
; *
;***********************************
;*** initialize routine
comp_init:
       1d
             br, #br_io
                                            ;set br reg. address to Offxxh
             [br:low pld],#11110000b
                                           ;set p17-14="h"
                                                                               (1)
       or
       and
             [br:low ioc1],#00001111b
                                            ;set p17-14=input mode
       ret
(2) Data reading for analog comparator
;*** control routine
comp_control:
             [br:low comp_mode], #00001100b
       or
                                            ;comparator 0&1 on
        carl comp_delay
                                            ;comparator stable delay ***
       bit
             [br:low comp_mode],#0000001b
                                            ;comparator 0 on ?
             z,comp_control00
       jrs
 comparator 0 : + >
jrs comp_control01
; comparator 0 : + < -</pre>
comp_control00:
                                                                               (2)
comp_control01:
             [br:low comp_mode], #00000010b
                                           ;comparator 1 on ?
       bit
             z,comp_control02
       jrs
 comparator 1 : + > -
jrs comp\_control03; comparator 1 : + < -
comp_control02:
; comparator processing end
comp_control03:
             [br:low comp_mode],#00001100b
       and
       ret
        end
```

## 16 SVD (SUPPLY VOLTAGE DETECTION) CIRCUIT

### I/O Map

| Address | Bit | Name  | Function                                     | 1    | 0     | SR    | R/W | Comment             |
|---------|-----|-------|----------------------------------------------|------|-------|-------|-----|---------------------|
| 00FF12  | D7  | -     | _                                            | _    | -     | _     | -   | Constantry "0" when |
|         | D6  | 1     | _                                            | _    | -     | _     | _   | being read          |
|         | D5  | SVDSP | SVD auto-sampling control                    | On   | Off   | 0     | R/W | These registers are |
|         |     |       |                                              |      |       |       |     | reset to "0" when   |
|         | D4  | SVDON | SVD continuous sampling control/status R     | Busy | Ready | 1→0*1 | R/W | SLP instruction     |
|         |     |       | W                                            | On   | Off   | 0     |     | is executed.        |
|         | D3  | SVD3  | SVD detection level                          |      |       | X     | R   | *2                  |
|         | D2  | SVD2  | SVD3 SVD2 SVD1 SVD0 Detection level Level 15 |      |       | X     | R   |                     |
|         | D1  | SVD1  | 1 1 1 0 Level 14                             |      |       | X     | R   |                     |
|         | D0  | SVD0  | 0 0 0 0 Level 0                              | -    | _     | X     | R   |                     |

<sup>\*1</sup> After initial reset, this status is set "1" until conclusion of hardware first sampling.

### Specifications

### **Control of SVD circuit**

### (1) svd\_auto: Supply voltage detection in 1/4 Hz auto sampling mode

After setting the  $1/4~\rm{Hz}$  auto-sampling mode to turn the SVD circuit ON, reads out SVD detection data into the A register.

### (2) SVD\_continue: Supply voltage detection in continuously sampling mode

Sets the continuous sampling mode (cancels the 1/4 Hz auto-sampling mode) to turn the SVD circuit ON, and reads out SVD detection data into A register after calling a delay routine.



<sup>\*2</sup> Initial values are set according to the supply voltage detected at first sampling by hardware. Until conclusion of first sampling, SVD0–SVD3 data are undefined.

### Notes

- (1) A delay routine that waits data decision time (approximately 7.8 msec or more) for the SVD circuit has not been included in this program example, so it is necessary to create a separate routine using a hardware timer or software timer. (external call: svd\_delay)
- (2) In the continuous sampling mode, when reading the detection data without waiting the data decision time (approximately 7.8 msec or more), previous data that has not been updated will be read.

```
Control of SVD circuit
       external
                 svd_delay
       public
                svd_auto_init,svd_contine
br_io
            equ
                 Offh
                                         ;base reg. address (set i/o area)
svd_mode
            equ
                  00ff12h
                                         ; supply voltage detector mode set reg.
      code
(1) Supply voltage detection in 1/4 Hz auto sampling mode
;*
;*
       svd control
; *
;*** auto sampling mode
svd_auto_init:
            [br:low svd_mode],#00100000b
       or
                                        ;auto sampling
       ret
                                                                          (1)
;
       ld
            a,[br:low svd_mode]
                                         ;read svd data
       and
            a,#0fh
       ret
(2) Supply voltage detection in continuously sampling mode
;*** continuos mode
svd_continue:
            a,[br:low svd_mode]
       ld
       and
            a,#00011111b
                                         ;auto sampling off
            a,#00010000b
                                         ;svd on
       or
       ld
            [br:low svd_mode],a
                                                                          (2)
       carl svd_delay
                                         ;svd stable delay
;
                                         read svd data
       ld
            a,[br:low svd_mode]
            a,#0fh
       and
            [br:low svd_mode],#00001111b
       and
                                        ;svd off
       ret
       end
```

# 17 INTERRUPT (EXCEPTION) PROCESSING

I/O Map

| Address | Bit | Name   | Function                                            | 1                |           | 0                  | SR  | R/W    | Comment             |
|---------|-----|--------|-----------------------------------------------------|------------------|-----------|--------------------|-----|--------|---------------------|
| 00FF20  | D7  | PK01   | V00 V07 interment majority and sister               |                  | PK01 PK00 |                    | 0   | R/W    |                     |
|         | D6  | PK00   | K00–K07 interrupt priority register                 |                  |           |                    | 0   | K/W    |                     |
|         | D5  | PSIF1  | Social intenfers into mount majority assisted       | PSIF1<br>PSW1    |           | ) Priority         | 0   | R/W    |                     |
|         | D4  | PSIF0  | Serial interface interrupt priority register        | PTM1             |           |                    | U   | K/W    |                     |
|         | D3  | PSW1   | Stonwatch times interment priority register         | 1<br>1           | 1         | Level 3<br>Level 2 | 0   | R/W    | /                   |
|         | D2  | PSW0   | Stopwatch timer interrupt priority register         | 0                | 1         | Level 2            | U   | K/W    |                     |
|         | D1  | PTM1   | Clock timer interrupt priority register             | 0                | 0         | Level 0            | 0   | R/W    | /                   |
|         | D0  | PTM0   | Clock timer interrupt priority register             |                  |           |                    | U   | K/W    |                     |
| 00FF21  | D7  | -      | _                                                   | -                |           | _                  | _   | _      |                     |
|         | D6  | _      | _                                                   | -                |           | _                  | _   | _      | Constantly "0" when |
|         | D5  | _      | _                                                   | -                |           | _                  | _   | _      | being read          |
|         | D4  | _      | _                                                   | -                |           | -                  | _   | _      |                     |
|         | D3  | PPT1   | Programmable timer interrupt priority register      | PPT1<br>PK11     | PPT       |                    | 0   | R/W    |                     |
|         | D2  | PPT0   | Trogrammable unier interrupt priority register      | 1                | 1         | Level 3            | U   | IX/ VV |                     |
|         | D1  | PK11   | K10 and K11 interrupt priority register             | 1                | 0         | Level 2<br>Level 1 | 0   | R/W    |                     |
|         | D0  | PK10   | KTO and KTT interrupt priority register             | 0                | 0         | Level 0            | 0   | IX/ VV |                     |
| 00FF22  | D7  | _      | _                                                   | -                |           | -                  | _   | _      | "0" when being read |
|         | D6  | ESW100 | Stopwatch timer 100 Hz interrupt enable register    |                  |           |                    |     |        |                     |
|         | D5  | ESW10  | Stopwatch timer 10 Hz interrupt enable register     | Interrupt enable | Interrupt | 0                  |     |        |                     |
|         | D4  | ESW1   | Stopwatch timer 1 Hz interrupt enable register      |                  |           |                    |     |        |                     |
|         | D3  | ETM1M  | Clock timer 1/60 Hz interrupt enable register       |                  |           |                    | R/W |        |                     |
|         | D2  | ETM8   | Clock timer 8 Hz interrupt enable register          | enabi            | ie        | disable            |     |        |                     |
|         | D1  | ETM2   | Clock timer 2 Hz interrupt enable register          |                  |           |                    |     |        | /                   |
|         | D0  | ETM1   | Clock timer 1 Hz interrupt enable register          |                  |           |                    |     |        |                     |
| 00FF23  | D7  | EPT1   | Programmable timer 1 interrupt enable register      |                  |           |                    |     |        |                     |
|         | D6  | EPT0   | Programmable timer 0 interrupt enable register      |                  |           |                    |     |        |                     |
|         | D5  | EK1    | K10 and K11 interrupt enable register               |                  |           |                    |     |        |                     |
|         | D4  | EK0H   | K04–K07 interrupt enable register                   | Interru          | rrupt     | Interrupt          | 0   | R/W    |                     |
|         | D3  | EK0L   | K00-K03 interrupt enable register                   | enabl            | le        | disable            | U   | K/W    | /                   |
|         | D2  | ESERR  | Serial I/F (error) interrupt enable register        |                  |           |                    |     |        |                     |
|         | D1  | ESREC  | Serial I/F (receiving) interrupt enable register    |                  |           |                    |     |        | /                   |
|         | D0  | ESTRA  | Serial I/F (transmitting) interrupt enable register |                  |           |                    |     |        |                     |
| 00FF24  | D7  | _      | _                                                   | -                |           | _                  | _   | _      | "0" when being read |
|         | D6  | FSW100 | Stopwatch timer 100 Hz interrupt factor flag        | (R)              |           | (R)                |     |        |                     |
|         | D5  | FSW10  | Stopwatch timer 10 Hz interrupt factor flag         | Interru          | ıpt       | No interrupt       |     |        | /                   |
|         | D4  | FSW1   | Stopwatch timer 1 Hz interrupt factor flag          | factor           | is        | factor is          |     |        | / <b> </b>          |
|         | D3  | FTM1M  | Clock timer 1/60 Hz interrupt factor flag           | genera           | ted       | generated          | 0   | R/W    | / <b> </b>          |
|         | D2  | FTM8   | Clock timer 8 Hz interrupt factor flag              | (W)              |           | (W)                |     |        |                     |
|         | D1  | FTM2   | Clock timer 2 Hz interrupt factor flag              | Rese             |           | No operation       |     |        | /                   |
|         | D0  | FTM1   | Clock timer 1 Hz interrupt factor flag              | Kese             | i.        | No operation       |     |        |                     |
| 00FF25  | D7  | FPT1   | Programmable timer 1 interrupt factor flag          | (R)              |           | (R)                |     |        |                     |
|         | D6  | FPT0   | Programmable timer 0 interrupt factor flag          | Interru          | ıpt       | No interrupt       |     |        | /                   |
|         | D5  | FK1    | K10 and K11 interrupt factor flag                   | factor           | is        | factor is          |     |        | / <b> </b>          |
|         | D4  | FK0H   | K04–K07 interrupt factor flag                       | genera           | ted       | generated          | 0   | R/W    | / <b> </b>          |
|         | D3  | FK0L   | K00-K03 interrupt factor flag                       |                  | _         |                    | U   | IN/W   | / <b> </b>          |
|         | D2  | FSERR  | Serial I/F (error) interrupt factor flag            | (W)              | )         | (W)                |     |        | / <b> </b>          |
|         | D1  | FSREC  | Serial I/F (receiving) interrupt factor flag        | Rese             | et        | No operation       |     |        | / <b> </b>          |
|         | D0  | FSTRA  | Serial I/F (transmitting) interrupt factor flag     |                  |           |                    |     |        | <u>/</u>            |
|         |     |        |                                                     |                  |           |                    |     |        |                     |

### Specifications

### Interrupt (exception) processing

### Setting of interrupt vector address

### (1) main: Interrupt level setting and enables interrupt

Sets an interrupt level ( $\overline{IRQ3}$ – $\overline{IRQ1}$ ) as the below for all interrupts and enables interrupts in the initialization routine (example for 88365 single chip mode) which is executed by reset exception processing.

Programmable timer interrupt
 Input port interrupt
 Serial interface interrupt
 Stopwatch timer interrupt
 Clock timer interrupt

(2) zero\_div: Zero division exception processing

(3) watchdog: Watchdog timer (NMI) interrupt processing (4) xxx\_intr: Interrupt processing for peripheral circuit

### Notes

- (1) The interrupt level  $(\overline{IRQ3}-\overline{IRQ1})$  can be set to adapt to the system.
- (2) Be sure to initialize peripheral circuits which use an interrupt and set interrupt generation conditions beforehand to enable each interrupt.
- (3) Interrupt processing for a peripheral circuit enables all interrupts, and exception processing with an interrupt vectors is a precondition. Since an interrupt flag is set by the generation of an interrupt regardless of the interrupt enable register and interrupt flags (I1 and I0), a procedure for polling interrupt factor flags by software can also be used.
- (4) Since the watchdog timer (NMI) interrupt cannot be masked, be sure to declare the watchdog timer (NMI) interrupt processing routine and the vector address, regardless of whether or not the watchdog timer is used.
- (5) To reset the interrupt factor flag, write "1" into the corresponding flags alone, using the AND or LD instruction. When the OR logic operation instruction has been used, "1" is written for the interrupt factor flags that have been set to "1" within the same address and those flags are then clear.
- (6) The interrupt flags (I1 and I0) have not been reset in the interrupt processing routine of this program example, so an interrupt lower than the set level is disabled at the time of generation. When you wish to accept the next interrupt after an interrupt has been generated, re-setting of the interrupt flags or resetting the interrupt factor flag is necessary after due consideration for the nesting level.
- (7) When permitting interrupt nesting, be careful of the stack size.
- (8) Vector addresses for software interrupts can be set up to 109 and to optional address (two bytes which begin with an even address) from 000026H to 0000FEH.
- (9) The vector addresses 000024H and 000025H cannot be used since this is a system reserved area for the E0C88365.
- (10) In this program example for interrupt (exception) processing, the vector address setting and program have been allocated from 000100H for the sake of convenience.

#### Flowchart

### (1) Interrupt level setting and enables interrupt



### (2) Zero division exception processing



## (3) Watchdog timer (NMI) interrupt processing



## (4) Interrupt processing for peripheral circuit



```
Interrupt (exception) processing
         external
                     user_program
         public
                     main, zero_div, watch_dog
         public
                     pt1 intr,pt0 intr
         public
                     k1x_intr,k0h_intr,k0l_intr
         public
                     serr_intr,srv_intr,str_intr
         public
                     sw100_intr,sw10_intr,sw1_intr
                     clock8_intr,clock2_intr,clock1_intr
         public
br_io
                                                ;base reg. address (set i/o area)
               equ
                                                ;mcu mode system control reg.
                     00ff00h
mcu
               equ
spp
               equ
                      00ff01h
                                                ;stack pointer page address
mode
               equ
                      00ff02h
                                                ;mcu//mpu mode control address
sp 365
                      00f800h
                                               ;E0C88365 stack top address
               equ
                      00ff20h
intr_pr0
                                               ;interrupt priority reg. 0
               equ
intr_pr1
               equ
                     00ff21h
                                               ;interrupt priority reg. 1
                      00ff22h
                                               ;interrupt enable reg. 0
intr_en0
               equ
intr_en1
intr_fac0
                                               ;interrupt enable reg. 1
                      00ff23h
               eau
                     00ff24h
               equ
                                               ;interrupt factor reg. 0
intr_fac1
               equ
                      00ff25h
                                               ;interrupt factor reg. 1
                     000024h
                                               ;E0C88365 system reserve
reserve
               equ
soft_intr
                      000026h
                                               ;software interrupt vector
               equ
                      000100h
                                               ;program start address offset
offset
               equ
         code
Setting of interrupt vector address
intr vectors:
;system interrupt vectors
        dw
             main
                                               ;reset vector
         dw
               zero div
                                               ;zero divide
         dw
               watchdog
                                                ;watchdog timer(/nmi)
;E0C88365 peripheral interrupt vectors (irq levels can set by software)
        dw
               pt1_intr
                                               ;programmable timer 1 (/irq3)
               pt0 intr
         dw
                                                ;programmable timer 0 (/irg3)
         dw
               k1x_intr
                                                klx input port
                                                                    (/irq3)
         dw
               k0h_intr
                                                ;k07-04 input port
                                                                     (/irq3)
               k01 intr
                                               ;k03-00 input port
                                                                     (/irq3)
         dw
         dw
               serr_intr
                                               serial error
                                                                      (/irq2)
         dw
               srv_intr
                                               ;serial receive
                                                                      (/irq2)
         dw
               str intr
                                               ;serial transmission (/irg2)
                                               ;stopwatch 100hz
               sw100_intr
         dw
                                                                     (/irq1)
         dw
               sw10_intr
                                               stopwatch 10hz
                                                                      (/irq1)
               sw1_intr
                                               stopwatch 1hz
                                                                     (/irq1)
         dw
               clock8_intr
                                               ;clock timer 8hz
         dw
                                                                     (/ira1)
                                               ;clock timer 2hz
         dw
               clock2_intr
                                                                     (/irq1)
         dw
               clock1_intr
                                               ;clock timer 1hz
                                                                     (/irq1)
;E0C88365 system reserve
        org intr_vectors+reserve
;software intrrupt vectors (i.e bios handler and/or general purpose routine(s))
               intr_vectors+soft_intr
         ora
```

```
(1) Interrupt level setting and enables interrupt
; *
; *
      main routine (mcu single chip mode)
main:
          br,#br_io
;mcu & spp write icludes system interrupt flag reset
      ld [br:low mcu],#00110000b
      ld
           [br:low spp],#0h
      ld
          [br:low mode],#0000000b
      14
          sp,#sp_365
; ram, lcd ram clear and i/o initialize
                                                                   (1)
;pk0(/irq3),psif(/irq2),psw(/irq1),ptm(/irq1)
      ld [br:low intr_pr0],#11100101b
;ppt(/irq3),pk1(/irq3)
          [br:low intr_pr1],#00000101b
      ld
;esw100,10,1(en),etm32,8,2,1(en.)
          [br:low intr_en0],#01111111b
      ld
;ept(en.),ek1(en.)ek0b(en.),ek0a(en.),eserr(en.),esrec(en.),estra(en.)
      ld [br:low intr_en1],#11111111b
;en. /nmi,/irq3,/irq2,/irq1
      and
          sc,#00111111b
                                     ;i1 & i0 flag clear
;wait for interrupt
      jrl user_program
(2) Zero division exception processing
;*
        *************
zero div:
                                                                   (2)
(3) Watchdog timer (NMI) interrupt processing
; *
; *
      watchdog timer (/nmi)
watchdog:
      push ale
      ld br, #br_io
                                    ;set br reg. address to Offxxh
                                                                   (3)
;watchdog timer (/nmi) interrupt processing
      qoq
           ale
      rete
```

```
(4) Interrupt processing for peripheral circuit
; *
      programmable timer 1 (/irq3)
; *
pt1_intr:
      programmable timer 1 interrupt processing
;
                                                                     (4)
;
           [br:low intr_fac1],#10000000b ;clear fpt1 interrupt flag
      and
programmable timer 0 (/irq3)
;*
;************************
pt0_intr:
      push ale
      programmable timer 0 interrupt processing
                                                                     (4)
      and
           [br:low intr_fac1],#01000000b ;clear fpt0 interrupt flag
      gog
      rete
; *
; *
      klx input port (/irq3)
k1x_intr:
      push ale
      klx input port interrupt processing
                                                                     (4)
          [br:low intr_fac1], #00100000b ; clear fk1 interrupt flag
      gog
      rete
; *
; *
      k0h input port (/irq3)
k0h_intr:
      push ale
      k0h input port interrupt processing
                                                                     (4)
          [br:low intr_fac1],#00010000b ;clear fk0b interrupt flag
      and
      rete
      k0l input port 0 (/irq3)
k01_intr:
      push ale
      k0l input port interrupt processing
                                                                     (4)
           [br:low intr_fac1], #00001000b ; clear fk0a interrupt flag
      and
      qoq
           ale
      rete
```

```
serial error (/irg2)
serr_intr:
      push ale
      serial error interrupt processing
                                                                      (4)
           [br:low intr_fac1],#00000100b ;clear fserr interrupt flag
      and
      pop
           ale
; *
; *
       serial receive (/irq2)
; *
;**********************************
srv_intr:
      push ale
      serial receive interrupt processing
                                                                      (4)
           [br:low intr_fac1],#00000010b ;clear fsrec interrupt flag
      gog
           ale
      rete
; **********************************
; *
; *
       serial transmission (/irq2)
; *
; * * * * * * * * *
         ***************
str_intr:
      push ale
      serial transmission interrupt processing
                                                                      (4)
           [br:low intr_fac1],#00000001b ;clear fstra interrupt flag
      and
      pop
       rete
; *
       stopwatch 100hz (/irq1)
           ***********
sw100_intr:
      push ale
      stopwatch 100hz interrupt processing
                                                                      (4)
            [br:low intr_fac0], #01000000b ;clear fsw100 interrupt flag
       and
      qoq
           ale
      rete
;*
       stopwatch 10hz (/irq1)
; *
sw10_intr:
      push ale
      stopwatch 10hz interrupt processing
                                                                      (4)
       and
            [br:low intr_fac0],#00100000b ;clear fsw10 interrupt flag
      pop
      rete
```

```
; *
     stopwatch 1hz (/irq1)
;*
sw1_intr:
     push ale
     stopwatch 1hz interrupt processing
                                                          (4)
          [br:low intr_fac0],#00010000b ;clear fswl interrupt flag
     and
     pop
          ale
; *
;*
     clock timer 8hz (/irq1)
clock8_intr:
     push ale
     clock timer 8hz interrupt processing
                                                          (4)
         [br:low intr_fac0], #00000100b ; clear ftm8 interrupt flag
     gog
     rete
; ***********************************
; *
;*
     clock timer 2hz (/irq1)
; *
clock2_intr:
     push ale
     clock timer 2hz interrupt processing
;
                                                          (4)
          [br:low intr_fac0],#00000010b ;clear ftm2 interrupt flag
     and
     pop
      rete
;*
     clock timer 1hz (/irq1)
clock1_intr:
     push ale
     clock timer 1hz interrupt processing
                                                          (4)
;
          [br:low intr_fac0], #00000001b ; clear ftml interrupt flag
     and
     qoq
          ale
     rete
     end
```

# 18 EXPANDED MODE

## Specifications

## Memory access in expanded mode

- (1) common, common\_sub, ex\_sub: Access for program memory outside logical space
  Branches to a bank outside logical space by setting NB register.
- (2) ex\_ram, move\_data: Data block transfer between pages

By setting expand page register, copies data (64K bytes) in page 1 to page 2. (Register indirect addressing)

(3) ex\_access: Access for data outside page

Accesses a data memory area outside of the current page using expand page register.

## Flowchart





## (2) Data block transfer between pages



## (3) Access for data outside page



### **Flowchart**



### Notes

- (1) "boc" is the unary operator which calculates a bank value from the physical address.

  "loc" is the unary operator which calculates a logical address in bank from the physical address.
- (2) "pod" is the unary operator which calculates a page value from the physical address.

  "lod" is the unary operator which calculates a logical address in page from the physical address.

```
public
                 common,common_sub
       public
                 ex_sub
(1) Access for program memory outside logical space
;*****************
; *
; *
       common area (bank0 = 000000h -> 007fffh) example
;*
;******
common:
                                      ;set new bank (external area)
       ld
            nb, #boc ex_sub
       carl ex sub
                                       ;external bank sub routine call ***
; * *
; *
; *
       common sub-routine
; *
;***************
common_sub:
                                                                         (1)
       ret
; *
;*
       external area (bank1 -> 15 = 008000h -> 07ffffh) example
ex_sub:
                                      ;common bank sub routine call ***
       carl common_sub
;
       ret
;
       end
```

```
;source data (page1=010000h -> 01ffffh)
src_data
                10000h
           equ
                20000h
                                    ;destination data (page2=020000h -> 02ffffh)
dst_data
           equ
ex_work
                30000h
                                    ;external work area
           equ
work:
           dw
                [1]
      code
(2) Data block transfer between pages
; *
; *
      external ram page control
;*
ex ram:
                                  source data page address source data logical top address destination data page address
      ld
           xp,#pod src_data
      ld
           ix,#lod src_data
      ld
           yp, #pod dst_data
                                    idestination data logical top address; 0 = 65,536 (64k byte)
       ld
           iy,#lod dst_data
           hl,#0
      ld
      carl move_data
      ret
; *
                                                                     (2)
; *
move_data:
      ld
           [iy],[ix]
      inc
          iy
      inc
           ix
      dec
          hl
      jrs nz,move_data
      ret
(3) Access for data outside page
; *
; *
       external page data read and write
ex_access:
      1d
           ep, #pod ex_work
      ld
           hl, #lod ex_work
           ba,[hl]
                                                                     (3)
      ld
           ep, #pod work
      1 d
      ld
           [lod work],ba
      ret
       end
```

# Appendix A Table of E0C88365 Input/Output Port Terminals

| P17<br>CMPM1                              |                       | P17              | P17               |                      |                      |                      |                      |             |                  |              | CMPMI        |           |           |             |             |           | P17              |            |                         |            |            |             |                  |              | CMPMI        |           |            |             |             |           | P17                 |            |            |            |                           |                  |              | CMPMI        |           |           |             |             | ٦         |
|-------------------------------------------|-----------------------|------------------|-------------------|----------------------|----------------------|----------------------|----------------------|-------------|------------------|--------------|--------------|-----------|-----------|-------------|-------------|-----------|------------------|------------|-------------------------|------------|------------|-------------|------------------|--------------|--------------|-----------|------------|-------------|-------------|-----------|---------------------|------------|------------|------------|---------------------------|------------------|--------------|--------------|-----------|-----------|-------------|-------------|-----------|
| P16<br>CMPP1                              |                       | P16              | P16               |                      |                      |                      |                      |             |                  |              | CMPP1 CMPMI  |           |           |             |             |           | P16              |            |                         |            |            |             |                  |              | CMPP1 CMPMI  |           |            |             |             |           | P16                 |            |            |            |                           |                  |              | CMPP1 CMPM1  |           |           |             |             |           |
| SIN SOUT SCLK SRDY CMP0 CMPM0 CMPM CMPM   |                       |                  | P15               |                      |                      |                      |                      |             |                  | CMPP0 CMPM0  | Ĭ            |           |           |             |             |           | P15              |            |                         |            |            |             |                  | CMPP0 CMPM0  | Ĭ            |           |            |             |             |           | P15                 |            |            |            |                           |                  | CMPP0 CMPM0  |              |           |           |             |             |           |
| P14<br>CMPP0                              | Jals                  | P14              | P14               |                      |                      |                      |                      |             |                  | CMPP0        |              |           |           |             |             |           | P14              |            |                         |            |            |             |                  | CMPP0        |              |           |            |             |             |           | P14                 |            |            |            |                           |                  | CMPP0        |              |           |           |             |             |           |
| P13<br>SRDY                               | termi                 | P13              | P13               |                      |                      |                      |                      |             | SRDY             |              |              |           |           |             |             |           | P13              |            |                         |            |            |             | SRDY             |              |              |           |            |             |             |           | P13                 |            |            |            |                           | SRDY             | 1            |              |           |           |             |             |           |
| P12<br>SCLK                               | I/O port terminals    | P11 P12 P13 P14  | P12               |                      |                      |                      |                      |             | SCLK SRDY        |              |              |           |           |             |             |           | P12              |            |                         |            |            |             | SCLK SRDY        |              |              |           |            |             |             |           | P12                 |            |            |            |                           | SCLK SRDY        |              |              |           |           |             |             |           |
| P11<br>SOUT                               | -                     | P11              | P11               |                      |                      |                      |                      |             | SOUT             |              |              |           |           |             |             |           | P11              |            |                         |            |            |             | SOUT             |              |              |           |            |             |             |           | P11                 |            |            |            |                           | SOUT             |              |              |           |           |             |             |           |
|                                           |                       | P10              | P10               |                      |                      |                      |                      |             | SIN              |              |              |           |           |             |             |           | P10              |            |                         |            |            |             | SIN              |              |              |           |            |             |             |           | P10                 |            |            |            |                           | SIN              |              |              |           |           |             |             |           |
| P00~07                                    |                       | P00~07 P10       | P00~07            | ←                    | -                    | <u>-</u>             | <b>←</b>             | ←           | ←                | ←            | ←            | ←         | ←         | ←           | ←           | ←         | D0~1             | ←          | <b>←</b>                | ←          | ←          | ←           | ←                | ←            | ←            | <b>←</b>  | <b>←</b>   | ←           | ←           | ←         | D0~7                | ←          | <b>⊢</b> ← | - ←        | - ←                       |                  | ←            | ←            | ←         | ←         | <b>←</b>    | ←           | ←         |
| R51<br>BACK                               |                       | R51              | R51               |                      |                      |                      |                      | BACK        |                  |              |              |           |           |             |             |           | R51              |            |                         |            |            | BACK        |                  |              |              |           |            |             |             |           | R51                 |            |            |            | RACK                      | NOV.             |              |              |           |           |             |             |           |
| R50<br><u>BZ</u>                          |                       | R50              | R50               |                      |                      |                      |                      |             |                  |              |              |           |           |             |             | BZ        | R50              |            |                         |            |            |             |                  |              |              |           |            |             |             | BZ        | R50                 |            |            |            |                           |                  |              |              |           |           |             |             | BZ        |
| R33 R34 R35~37<br>CE3 FOUT R40~47         |                       | R35-37<br>R40-47 | R35~37<br>R40~47  | ← (                  | -                    | _                    | <b>←</b>             | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b></b>   | R35~37<br>R40~47 | 1          | <b>\</b>                | <b>—</b>   | <b>←</b>   | <b>←</b>    | <b>←</b>         | <b></b>      | <b>←</b>     | <b>+</b>  | $\uparrow$ | <b>←</b>    | <b>←</b>    | <b>—</b>  | R35~37<br>R40~47    | ←          | <b>⊢</b> ← | -          | - ←                       | -                | - ←          | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b></b>     | <b></b>     | ←         |
| R34<br>FOUT                               |                       |                  | R34               |                      |                      |                      |                      |             |                  |              |              |           |           |             | FOUT        |           | R34              |            |                         |            |            |             |                  |              |              |           |            |             | FOUT        |           | R34                 |            |            |            |                           |                  |              |              |           |           |             | FOUT        |           |
|                                           |                       |                  | R33               | ←                    | -                    | -                    | <b>←</b>             | <b>←</b>    | <b>←</b>         | ←            | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | R33              |            |                         |            | CE3        |             |                  |              |              |           |            |             |             |           | R33                 |            |            | 200        | CED                       |                  |              |              |           |           |             |             |           |
| R32<br>CE2                                |                       | R32              | R32               | ← •                  |                      | -                    | ←                    | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | R32              |            |                         | CE2        |            |             |                  |              |              |           |            |             |             |           | R32                 |            | ļ.         | CEZ        |                           |                  |              |              |           |           |             |             |           |
| R31<br>CE1                                |                       | R31              | R31               | ←                    | -                    | -                    | ←                    | ←           | ←                | ←            | ←            | ←         | ←         | ←           | ←           | ←         | R31              |            | $\overline{\text{CEI}}$ |            |            |             |                  |              |              |           |            |             |             |           | R31                 |            | CEI        |            |                           |                  |              |              |           |           |             |             |           |
| R30<br>CE0                                | inals                 | R30              | R30               | ← •                  | - 4                  | =                    | ←                    | ←           | ←                | ←            | ←            | ←         | ←         | ←           | ←           | ←         | R30              | CE0        |                         |            |            |             |                  |              |              |           |            |             |             |           | CEO                 | ← (        | ←          | - 4        | - ←                       | - ←              | - ←          | <b>←</b>     | ←         | <b>←</b>  | ←           | ←           | ←         |
| R27 R30<br>TOUT CE0                       | Output port terminals | R26 R27 R30      | R27               |                      |                      |                      |                      |             |                  |              |              |           |           | TOUT        |             |           | R27              |            |                         |            |            |             |                  |              |              |           |            | TOUT        |             |           | R27                 |            |            |            |                           |                  |              |              |           |           | TOOT        |             |           |
| R25 R26<br>CL FR                          | tput po               | R26              | R26               |                      |                      |                      |                      |             |                  |              |              |           | 퐀         |             |             |           | R26              |            |                         |            |            |             |                  |              |              |           | FR         |             |             |           | R26                 |            |            |            |                           |                  |              |              |           | 퐀         |             |             |           |
|                                           | ð                     | 14               | R25               |                      |                      |                      |                      |             |                  |              |              | 5         |           |             |             |           | R25              |            |                         |            |            |             |                  |              |              | J         |            |             |             |           | R25                 |            |            |            |                           |                  |              |              | r<br>T    |           |             |             |           |
| R24<br>WR                                 |                       |                  | R24               | ← •                  | - (                  | ⊢                    | <b>←</b>             | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | WR               | ←          | <b>←</b>                | ←          | <b>←</b>   | ←           | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>   | ←           | ←           | ←         | WR.                 | ← (        | - ←        | - 4        | - ←                       | <b>←</b>         | · ←          | <b>←</b>     | <b>←</b>  | <b>←</b>  | ←           | ←           | ←         |
| R23                                       |                       |                  | R23               | ← •                  | - (                  | -                    | <b>←</b>             | <b>←</b>    | <b>←</b>         | ←            | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | 8                | ←          | <b>←</b>                | ←          | <b>←</b>   | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | ←         | ←          | ←           | ←           | ←         | ₽.                  | <b>←</b> ( | -  ←       | -          | - ←                       | -                | <b>←</b>     | <b>←</b>     | ←         | <b>←</b>  | <b>←</b>    | ←           | <b>←</b>  |
| R20~22<br>A16~18                          |                       | R20~22           | R20~22            | ← •                  | -                    | -                    | <b>←</b>             | ←           | ←                | <b>←</b>     | <b>←</b>     | ←         | <b>←</b>  | ←           | <b>←</b>    | ←         | A16~18           | <b>←</b>   | <b>←</b>                | <b>←</b>   | ←          | ←           | <b>←</b>         | ←            | ←            | ←         | <b>←</b>   | ←           | ←           | ←         | A16~18              | ←          | <b>⊢</b> ← | - ←        | - ←                       |                  | <b>←</b>     | <b>←</b>     | ←         | <b>←</b>  | <b>←</b>    | ←           | ←         |
| R10~17<br>A8~15                           |                       | R10~17           | R10~17            | ← •                  | -                    | <u>-</u>             | ←                    | ←           | ←                | ←            | ←            | ←         | ←         | ←           | ←           | ←         | A8~15            | ←          | <b></b>                 | ←          | ←          | <b></b>     | ←                | <b>↓</b>     | ←            | ←         | ←          | <b></b>     | ←           | ←         | A8~15               | ←          | <b>⊢</b> ← | -          | - ←                       |                  | ←            | <b>←</b>     | ←         | ←         | ←           | ←           | ←         |
| R00~07<br>A0~7                            |                       | R00~07           | R00~07            | ←                    | -                    | _                    | <b>-</b>             | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | A0~7             | <b>←</b>   | <b>←</b>                | <b>-</b>   | <b>←</b>   | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>   | <b>←</b>    | <b>←</b>    | <b>←</b>  | A0~7                | ←          | <b>⊢</b>   | -          | - (                       |                  | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <u>−</u>  |
| K11<br>BREQ                               | inals                 | K11              | K11               |                      | T                    |                      |                      | BREQ        |                  |              |              |           |           |             |             |           | K11              |            |                         |            |            | BREQ        |                  |              |              |           |            |             |             |           | K11                 |            | T          |            | RREO                      | 7                |              |              |           |           |             |             |           |
| K10<br>EVIN                               | rt term               | K10              | K10               | ← •                  | -                    |                      | <b>←</b>             | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | <b>←</b>  | K10              | <b>←</b>   | <b>←</b>                | <b>←</b>   | <b>←</b>   | <b>←</b>    | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>   | <b>←</b>    | <b>←</b>    | <b>←</b>  | K10                 | ← (        | - 4        | - (        | <b>←</b>                  | <b>←</b>         | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | ←           | <b>←</b>    | ←         |
| K00~07 K10 K11<br>EVIN BREG               | Input port terminals  | K00~07 K10 K11   | K00~07 K10 K11    | ← •                  | -                    | <u>-</u>             | ←                    | <b>←</b>    | ←                | <b>←</b>     | <b>←</b>     | ←         | <b>←</b>  | ←           | <b>←</b>    | <b>←</b>  | K00~07           | <b>←</b>   | <b></b>                 | <b>←</b>   | ←          | <b>←</b>    | <b>←</b>         | <b></b>      | ←            | <b>←</b>  | <b></b>    | <b>←</b>    | ←           | ←         | K00~07              | ←          | <b>⊢</b> ← |            | - ←                       |                  | <b>←</b>     | <b>←</b>     | <b>←</b>  | <b>←</b>  | <b>←</b>    | <b>←</b>    | ←         |
| E0C88365                                  |                       | Special output   | (Initial setting) | CEO output (invalid) | CEI output (invalid) | CE2 output (invalid) | CE3 output (invalid) | Bus release | Serial interface | Comparator 0 | Comparator 1 | CL output | FR output | TOUT output | FOUT output | BZ output | utput)           | CEO output | CEI output              | CE2 output | CE3 output | Bus release | Serial interface | Comparator 0 | Comparator 1 | CL output | FR output  | TOUT output | FOUT output | BZ output | (No special output) | CE0 output | CE1 output | CE2 output | CES output<br>Bus release | Serial interface | Comparator 0 | Comparator 1 | CL output | FR output | TOUT output | FOUT output | BZ output |
| Terminal configuration depending on model | l                     | e Bus mode       | MCU Single ship   | ·                    | •                    |                      |                      |             |                  |              |              |           |           |             |             |           | Expanded 512K    | (MAX)      |                         |            |            |             |                  |              |              |           |            | ·           | •           |           | Expanded 512K       | (MAX)      | ·          | ·          |                           |                  |              |              |           |           |             | •           |           |
| Tern                                      | CPU                   | mode             | MCL               |                      |                      |                      |                      |             |                  |              |              |           |           |             |             |           |                  |            |                         |            |            |             |                  |              |              |           |            |             |             |           | MPU                 |            |            |            |                           |                  |              |              |           |           |             |             |           |

Note: • Blank items will be decided according to other special output settings in the same row.

# Appendix B Instruction List

# 8-bit Trnsfer Instructions (1/3)

| Mr | nemonic            | Machine Code  | Operation                | Cycle | Byte | SC   Comme |
|----|--------------------|---------------|--------------------------|-------|------|------------|
| LD | A,A                | 40            | A←A                      | 1     | 1    |            |
|    | A,B                | 41            | A←B                      | 1     | 1    |            |
|    | A,L                | 42            | A←L                      | 1     | 1    |            |
|    | A,H                | 43            | A←H                      | 1     | 1    |            |
|    | A,BR               | CE,C0         | A←BR                     | 2     | 2    |            |
|    | A,SC               | CE,C1         | A←SC                     | 2     | 2    |            |
|    | A,#nn              | B0,nn         | A←nn                     | 2     | 2    |            |
|    | A,[BR:11]          | 44,11         | A←[BR: <i>ll</i> ]       | 3     | 2    |            |
|    | A,[hh <i>ll</i> ]  | CE,D0,ll,hh   | A←[hh <i>ll</i> ]        | 5     | 4    |            |
|    | A,[HL]             | 45            | A←[HL]                   | 2     | 1    |            |
|    | A,[IX]             | 46            | A←[IX]                   | 2     | 1    |            |
|    | A,[IY]             | 47            | A←[IY]                   | 2     | 1    |            |
|    | A,[IX+dd]          | CE,40,dd      | $A \leftarrow [IX + dd]$ | 4     | 3    |            |
|    | A,[IY+dd]          | CE,41,dd      | $A \leftarrow [IY + dd]$ | 4     | 3    |            |
|    | A,[IX+L]           | CE,42         | $A \leftarrow [IX + L]$  | 4     | 2    |            |
|    | A,[IY+L]           | CE,43         | $A \leftarrow [IY + L]$  | 4     | 2    |            |
|    | A,NB               | CE,C8         | A←NB                     | 2     | 2    |            |
|    | A,EP               | CE,C9         | A←EP                     | 2     | 2    | MODEL2     |
|    | A,XP               | CE,CA         | A←XP                     | 2     | 2    | only       |
|    | A,YP               | CE,CB         | A←YP                     | 2     | 2    |            |
| LD | В,А                | 48            | B←A                      | 1     | 1    |            |
|    | В,В                | 49            | В←В                      | 1     | 1    |            |
|    | B,L                | 4A            | B←L                      | 1     | 1    |            |
|    | В,Н                | 4B            | A←H                      | 1     | 1    |            |
|    | B,#nn              | B1,nn         | B←nn                     | 2     | 2    |            |
|    | B,[BR: <i>ll</i> ] | 4C,ll         | $B\leftarrow[BR:ll]$     | 3     | 2    |            |
|    | B,[hh <i>ll</i> ]  | CE,D1,ll,hh   | $B\leftarrow[hhll]$      | 5     | 4    |            |
|    | B,[HL]             | 4D            | B←[HL]                   | 2     | 1    |            |
|    | B,[IX]             | 4E            | $B\leftarrow[IX]$        | 2     | 1    |            |
|    | B,[IY]             | 4F            | B←[IY]                   | 2     | 1    |            |
|    | B,[IX+dd]          | CE,48,dd      | $B\leftarrow[IX+dd]$     | 4     | 3    |            |
|    | B,[IY+dd]          | CE,49,dd      | $B\leftarrow[IY+dd]$     | 4     | 3    |            |
|    | B,[IX+L]           | CE,4A         | $B\leftarrow$ [IX+L]     | 4     | 2    |            |
|    | B,[IY+L]           | CE,4B         | $B\leftarrow[IY+L]$      | 4     | 2    |            |
| LD | L,A                | 50            | L←A                      | 1     | 1    |            |
|    | L,B                | 51            | L←B                      | 1     | 1    |            |
|    | L,L                | 52            | L←L                      | 1     | 1    |            |
|    | L,H                | 53            | L←H                      | 1     | 1    |            |
|    | L,#nn              | B2,nn         | L←nn                     | 2     | 2    |            |
|    | L,[BR: <i>ll</i> ] | 54, <i>ll</i> | L←[BR: <i>ll</i> ]       | 3     | 2    |            |
|    | L,[hh <i>ll</i> ]  | CE,D2,ll,hh   | L←[hh <i>ll</i> ]        | 5     | 4    |            |
|    | L,[HL]             | 55            | L←[HL]                   | 2     | 1    |            |
|    | L,[IX]             | 56            | L←[IX]                   | 2     | 1    |            |
|    | L,[IY]             | 57            | L←[IY]                   | 2     | 1    |            |
|    | L,[IX+dd]          | CE,50,dd      | L←[IX+dd]                | 4     | 3    |            |
|    | L,[IY+dd]          | CE,51,dd      | $L\leftarrow$ [IY+dd]    | 4     | 3    |            |
|    | L,[IX+L]           | CE,52         | L←[IX+L]                 | 4     | 2    |            |
|    | L,[IY+L]           | CE,53         | L←[IY+L]                 | 4     | 2    |            |

<sup>\*</sup> New code bank register NB and expand page registers EP/XP/YP are set only for MODEL2/3. In MODEL0/1, instructions that access these registers cannot be used.

# 8-bit Trnsfer Instructions (2/3)

|     |                       | iiisii uciioi |                       | 1             |      | Π            |          |          |          | SC       |   |          |          |          |         |
|-----|-----------------------|---------------|-----------------------|---------------|------|--------------|----------|----------|----------|----------|---|----------|----------|----------|---------|
| Mr  | nemonic               | Machine Code  | Operation             | Cycle         | Byte | 11           | 10       | U        |          | N        | ١ | /        | С        | Z        | Comment |
| LD  | H,A                   | 58            | H←A                   | 1             | 1    | _            |          | _        |          |          |   |          | _        | _        |         |
|     | H,B                   | 59            | Н←В                   | 1             | 1    | -            | _        | _        | _        | _        |   |          | _        |          |         |
|     | H,L                   | 5A            | H←L                   | 1             | 1    | <del> </del> | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | H,H                   | 5B            | Н←Н                   | 1             | 1    | <del> </del> | _        | _        | _        |          |   | _        | _        | _        |         |
|     | H,#nn                 | B3,nn         | H←nn                  | 2             | 2    |              | _        |          | _        |          |   | _        | _        |          |         |
|     | H,[BR: <i>ll</i> ]    | 5C, <i>ll</i> | H←[BR: <i>ll</i> ]    | 3             | 2    | ┢            | _        | _        | _        | _        | _ | _        | _        |          |         |
|     | H,[hh <i>ll</i> ]     | CE,D3,ll,hh   | H←[hh <i>ll</i> ]     | 5             | 4    | E            | _        | _        | _        |          | - |          | =        |          |         |
|     | H,[HL]                | 5D            | H←[HL]                | 2             | 1    | F            |          | _        |          |          |   |          |          |          |         |
|     | H,[IX]                | 5E            | H←[IX]                | 2             | 1    | -            | _        | _        |          | _        | _ | _        | _        | _        |         |
|     | H,[IY]                | 5F            | H←[IY]                | $\frac{1}{2}$ | 1    | ⊢            | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | H,[IX+dd]             |               |                       | 4             | 3    | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
|     |                       | CE,58,dd      | H←[IX+dd]             | 1             |      | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
|     | H,[IY+dd]             | CE,59,dd      | H←[IY+dd]             | 4             | 3    | -            | _        |          | _        | _        | _ | _        | _        | _        |         |
|     | H,[IX+L]              | CE,5A         | H←[IX+L]              | 4             | 2    | -            | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | H,[IY+L]              | CE,5B         | H←[IY+L]              | 4             | 2    | _            | _        | _        | _        | _        | - | _        | _        | _        |         |
| LD  | BR,A                  | CE,C2         | BR←A                  | 2             | 2    | -            | _        |          | _        | _        | - | _        | _        | _        |         |
|     | BR,#hh                | B4,hh         | BR←hh                 | 2             | 2    | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
| LD  | SC,A                  | CE,C3         | SC←A                  | 3             | 2    | <b>‡</b>     | <b>‡</b> | \$       | <b>‡</b> | <b>‡</b> |   | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|     | SC,#nn                | 9F,nn         | SC←nn                 | 3             | 2    | \$           | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b></b>  | , | <b></b>  | <b>‡</b> | <b>‡</b> |         |
| LD  | [BR: <i>ll</i> ],A    | 78, <i>ll</i> | [BR: <i>ll</i> ]←A    | 3             | 2    | _            | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | [BR: <i>ll</i> ],B    | 79, <i>ll</i> | [BR:ll]←B             | 3             | 2    | _            | _        | _        | _        | _        | - |          | _        | _        |         |
|     | [BR: <i>ll</i> ],L    | 7A,ll         | [BR:ll]←L             | 3             | 2    | _            | _        | _        | -        | _        | - | _        | _        | _        |         |
|     | [BR: <i>ll</i> ],H    | 7B, <i>ll</i> | [BR:ll]←H             | 3             | 2    | -            | _        | _        | _        | _        | - | _        | _        | -        |         |
|     | [BR: <i>ll</i> ],#nn  | DD,ll,nn      | [BR:ll]←nn            | 4             | 3    | <b>-</b>     | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | [BR: <i>ll</i> ],[HL] | 7D, <i>ll</i> | [BR:ll]←[HL]          | 4             | 2    | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
|     | [BR: <i>ll</i> ],[IX] | 7E,ll         | [BR: <i>ll</i> ]←[IX] | 4             | 2    | -            | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | [BR: <i>ll</i> ],[IY] | 7F, <i>ll</i> | [BR: <i>ll</i> ]←[IY] | 4             | 2    | _            | _        | _        | _        | _        | - | _        | _        | _        |         |
| LD  | [hh <i>ll</i> ],A     | CE,D4,ll,hh   | [hh <i>ll</i> ]←A     | 5             | 4    | -            | _        | _        | _        | _        |   | _        | _        | _        |         |
|     | [hh <i>ll</i> ],B     | CE,D5,ll,hh   | [hh <i>ll</i> ]←B     | 5             | 4    | -            | _        | _        | _        | _        |   | _        | _        | _        |         |
|     | [hh <i>ll</i> ],L     | CE,D6,ll,hh   | [hh <i>ll</i> ]←L     | 5             | 4    | -            | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | [hh <i>ll</i> ],H     | CE,D7,ll,hh   | [hh <i>ll</i> ]←H     | 5             | 4    | -            | _        | _        | _        | _        | _ | _        | _        | _        |         |
| LD  | [HL],A                | 68            | [HL]←A                | 2             | 1    | -            | _        | _        | _        | _        |   | _        | _        | _        |         |
|     | [HL],B                | 69            | [HL]←B                | 2             | 1    | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
|     | [HL],L                | 6A            | [HL]←L                | 2             | 1    | -            | _        | _        | _        | _        |   | _        | _        | _        |         |
|     | [HL],H                | 6B            | [HL]←H                | 2             | 1    | _            | _        | _        | _        | _        |   | _        | _        | _        |         |
|     | [HL],#nn              | B5,nn         | [HL]←nn               | 3             | 2    | _            | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | [HL],[BR: <i>ll</i> ] |               | [HL]←[BR: <i>ll</i> ] | 4             | 2    | -            | _        | _        | _        | _        | _ |          | _        | _        |         |
|     | [HL],[HL]             | 6D            | [HL]←[HL]             | 3             | 1    | -            | _        | _        | _        | _        | _ | _        | _        |          |         |
|     | [HL],[IX]             | 6E            | [HL]←[IX]             | 3             | 1    | <del> </del> | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | [HL],[IY]             | 6F            | [HL]←[IY]             | 3             | 1    | _            | _        | _        | _        |          |   | _        | _        | _        |         |
|     | [HL],[IX+dd]          |               | [HL]←[IX+dd]          | 5             | 3    |              |          |          |          |          |   |          |          |          |         |
|     | [HL],[IY+dd]          |               |                       | 5             | 3    | F            |          |          |          |          |   |          |          |          |         |
|     | [HL],[IX+L]           |               | [HL]←[IY+dd]          | 5             | 2    | ⊢            | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | [HL],[IY+L]           |               | [HL]←[IX+L]           | 5             | 2    | ⊢            | _        | _        | _        |          | _ | _        | _        | _        |         |
| LD. |                       |               | [HL]←[IY+L]           |               |      | F            | _        | _        | _        | _        | _ | _        | _        | _        |         |
| LD  | [IX],A                | 60            | [IX]←A                | 2             | 1    | ⊢            | _        | _        | _        | _        | _ | _        | _        | _        |         |
|     | [IX],B                | 61            | [IX]←B                | 2             | 1    | F            | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | [IX],L                | 62            | [IX]←L                | 2             | 1    | -            | _        | _        | _        | _        | _ | _        | _        | -        |         |
|     | [IX],H                | 63            | [IX]←H                | 2             | 1    | -            | _        | _        | _        | _        | - | _        | _        | _        |         |
|     | [IX],#nn              | B6,nn         | [IX]←nn               | 3             | 2    | _            | _        | _        | _        | _        | - | _        | _        | -        |         |

# 8-bit Trnsfer Instructions (3/3)

| LD   [IX], [BR:II]   64. I   [IX] = [IBR:II]   4   2         [IX], [IX]   65   [IX] = [IX]   3   1         [IX], [IX]   66   [IX] = [IX]   3   1         [IX], [IX]   67   [IX] = [IX]   3   1         [IX], [IX]   67   [IX] = [IX]   3   1         [IX], [IX]   67   [IX] = [IX]   3   1         [IX], [IX]   66   [IX] = [IX]   3   1         [IX], [IX]   66   [IX] = [IX]   3   1         [IX], [IX]   66   [IX] = [IX]   61   5   3   1         [IX], [IX]   66   [IX] = [IX]   61   5   3   1         [IX], [IX]   66   [IX] = [IX]   61   5   3   1         [IX], [IX]   66   [IX] = [IX]   61   5   3   1         [IX], [IX]   CE,68, dd   [IX] = [IX] + [IX]   5   2   1         [IX], [IX]   CE,68   [IX] = [IX] + [IX]   5   2   1         [IY], B 71   [IY] = B   3   1         [IY], B 71   [IY] = B   1   1   1   1   1   1   1   1     [IY], B 71   [IY] = B   1   1   1   1   1   1   1   1   1 | omment  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|
| [IX], [HL]   65                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| [IX], [IY]   67                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| [IX], [IX+dd]   CE,68,dd   [IX]←[IX+dd]   5   3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| [IX], [IY+dd] CE,69,dd [IX]←[IY+dd] 5 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| [IX],[IY+L] CE,6B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| LD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |         |
| [IY],B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| [IY],L 72 [IY]←L 2 1   [IY],H 73 [IY]←H 2 1   [IY],Hn B7,nn [IY]←nn 3 2   [IY],BR;II] 74,II [IY]←[BR;II] 4 2   [IY],[IX] 75 [IY]←[IX] 3 1   [IY],IX] 76 [IY]←[IX] 3 1   [IY],IX] 76 [IY]←[IX] 3 1   [IY],IX] 77 [IY]←[IX] 3 1   [IY],IX+dd] CE,78,dd [IY]←[IY+dd] 5 3   [IY],IX+dd] CE,79,dd [IY]←[IY+dd] 5 3   [IY],IX+L] CE,7A [IY]←[IX+L] 5 2   [IY],IX+L] CE,7B [IY]←[IY+L] 5 2   [IX+dd],A CE,44,dd [IX+dd]←A 4 3   [IX+dd],B CE,4C,dd [IX+dd]←B 4 3   [IX+dd],L CE,54,dd [IX+dd]←B 4 3   [IX+dd],A CE,45,dd [IY+dd]←A 4 3   [IY+dd],A CE,45,dd [IY+dd]←A 4 3   [IY+dd],B CE,4C,dd [IY+dd]←B 4 3   [IY+dd],B CE,55,dd [IY+dd]←B 4 3   [IY+dd],C CE,55,dd [IY+dd]←B 4 3   [IY+dd],C CE,55,dd [IY+dd]←B 4 3   [IY+dd],C CE,55,dd [IY+dd]←B 4 2    LD [IX+L],B CE,4E [IX+L]←B 4 2   [IX+L],B CE,4E [IX+L]←B 4 2   [IX+L],B CE,4F [IY+L]←B 4 2   [IY+L],B CE,4F [IY+L]←B 4 2   [IY+L],B CE,4F [IY+L]←B 4 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| [IY],H 73                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |
| [IY],#nn B7,nn [IY]←nn 3 2 2   [IY],[BR:II] 74,II [IY]←[BR:II] 4 2   [IY],[IL] 75 [IY]←[IL] 3 1   [IY],[IX] 76 [IY]←[IX] 3 1   [IY],[IY] 77 [IY]←[IY] 3 1   [IY],[IY] 77 [IY]←[IY] 5 3   [IY],[IY+dd] CE,78,dd [IY]←[IX+dd] 5 3   [IY],[IY+dd] CE,79,dd [IY]←[IY+dd] 5 3   [IY],[IY+L] CE,7A [IY]←[IX+L] 5 2   [IY],[IY+L] CE,7B [IY]←[IY+L] 5 2   [IX+dd],A CE,44,dd [IX+dd]←A 4 3   [IX+dd],B CE,4C,dd [IX+dd]←A 4 3   [IX+dd],L CE,54,dd [IX+dd]←B 4 3   [IX+dd],H CE,5C,dd [IX+dd]←H 4 3   [IY+dd],A CE,45,dd [IY+dd]←A 4 3   [IY+dd],B CE,4D,dd [IY+dd]←B 4 3   [IY+dd],B CE,4D,dd [IY+dd]←B 4 3   [IY+dd],H CE,5S,dd [IY+dd]←B 4 3   [IY+dd],H CE,5S,dd [IY+dd]←B 4 3   [IY+dd],H CE,5D,dd [IY+dd]←B 4 2   [IX+L],A CE,46 [IX+L]←A 4 2   [IX+L],A CE,46 [IX+L]←B 4 2   [IX+L],H CE,5E [IX+L]←B 4 2   [IX+L],H CE,5E [IX+L]←B 4 2   [IY+L],A CE,47 [IY+L]←A 4 2   [IY+L],B CE,4F [IY+L]←B 4 2   [IY+L],B CE,4F [IY+L]←B 4 2   [IY+L],L CE,57 [IY+L]←L 4 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |         |
| [IY], [BR:II]   74,       [IY]← [BR:II]   4   2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| [IY],[HL] 75                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |
| [IY], [IX]   76   [IY]←[IX]   3   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |
| [IY],[IY] 77 [IY]←[IY] 3 1 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |         |
| [IY],[IX+dd] CE,78,dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |         |
| [IY],[IY+dd] CE,79,dd [IY]←[IY+dd] 5 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| [IY],[IX+L] CE,7A [IY]←[IX+L] 5 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| [IY], [IY+L] CE, 7B [IY]←[IY+L] 5 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| [IX+dd],B       CE,4C,dd       [IX+dd]←B       4       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| [IX+dd],H       CE,5C,dd       [IX+dd]←H       4       3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| [IY+L],B CE,4F [IY+L]←B 4 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| [IY+L],L CE,57 [IY+L]←L 4 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |
| $[IY+L],H$   CE,5F   $[IY+L]\leftarrow H$   4   2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| LD NB,A CE,CC NB←A 3 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| NB,#bb CE,C4,bb NB←bb 4 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |         |
| LD EP,A CE,CD EP←A 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| EP,#pp CE,C5,pp EP←pp 3 3 3 MO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | DDEL2/3 |
| LD $XP,A$ CE,CE $XP\leftarrow A$ 2 2 $$ only                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | y       |
| XP,#pp CE,C6,pp XP←pp 3 3 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| LD YP,A CE,CF YP←A 2 2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |         |
| YP,#pp CE,C7,pp YP←pp 3 3 3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |         |
| EX A,B CC A↔B 2 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |         |
| A,[HL] CD A↔[HL] 3 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |         |
| SWAP A F6 $A_{(H)} \leftrightarrow A_{(L)}$ 2 1 $    -$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |         |
| [HL] F7 [HL](H) 3 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |         |

<sup>\*</sup> New code bank register NB and expand page registers EP/XP/YP are set only for MODEL2/3. In MODEL0/1, instructions that access these registers cannot be used.

# 16-bit Trnsfer Instructions (1/2)

|    |                    |                   |                                                        |       |      | Γ            |    |   | - 5 | SC |   |     |     | Τ       |
|----|--------------------|-------------------|--------------------------------------------------------|-------|------|--------------|----|---|-----|----|---|-----|-----|---------|
| M  | nemonic            | Machine Code      | Operation                                              | Cycle | Byte | 11           | 10 | U |     |    | _ | / C | , z | Comment |
| LD | BA,BA              | CF,E0             | BA←BA                                                  | 2     | 2    |              |    | _ |     |    |   |     | -   |         |
|    | BA,HL              | CF,E1             | BA←HL                                                  | 2     | 2    | _            | _  | _ | _   | _  |   |     |     |         |
|    | BA,IX              | CF,E2             | BA←IX                                                  | 2     | 2    | -            | _  | _ | _   | _  | _ |     |     |         |
|    | BA,IY              | CF,E3             | BA←IY                                                  | 2     | 2    | _            | _  | _ | _   | _  | _ |     |     |         |
|    | BA,SP              | CF,F8             | BA←SP                                                  | 2     | 2    | -            | _  | _ | _   | _  |   |     |     |         |
|    | BA.PC              | CF,F9             | BA←PC+2                                                | 2     | 2    | _            | _  | _ | _   | _  | _ |     |     |         |
|    | BA,#mmnn           |                   | BA←mmnn                                                | 3     | 3    | <del> </del> | _  | _ | _   | _  | - |     |     |         |
|    | BA,[hh <i>ll</i> ] | B8, <i>ll</i> ,hh | $A \leftarrow [hhll], B \leftarrow [hhll+1]$           | 5     | 3    |              | _  | _ | _   | _  | _ | _   |     |         |
|    | BA,[HL]            | CF,C0             | $A \leftarrow [HL], B \leftarrow [HL+1]$               | 5     | 2    | <del> </del> | _  | _ | _   | _  | - |     |     |         |
|    | BA,[IX]            | CF,D0             | $A \leftarrow [IX], B \leftarrow [IX+1]$               | 5     | 2    |              | _  | _ | _   | _  | _ |     |     |         |
|    | BA,[IY]            | CF,D8             | $A \leftarrow [IY], B \leftarrow [IY+1]$               | 5     | 2    |              | =  | _ | =   | _  | - |     |     |         |
|    | BA,[SP+dd]         |                   | $A \leftarrow [SP+dd], B \leftarrow [SP+dd+1]$         | 6     | 3    | F            |    |   |     |    |   |     |     |         |
| LD | HL,BA              | CF,E4             | HL←BA                                                  | 2     | 2    | F            | _  | _ | _   | _  | _ |     | _   |         |
| LD | HL,HL              |                   | HL←HL                                                  | 2     | 2    | F            | _  | _ | _   | _  | _ |     | _   |         |
|    |                    | CF,E5             |                                                        | 2     | 2    | -            | _  | _ | _   | _  | _ |     | _   |         |
|    | HL,IX              | CF,E6             | HL←IX                                                  |       |      | F            |    | _ | _   | _  | _ |     | _   |         |
|    | HL,IY              | CF,E7             | HL-IY                                                  | 2     | 2    | -            | _  | _ | _   | _  | _ |     | _   |         |
|    | HL,SP              | CF,F4             | HL←SP                                                  | 2     | 2    | _            | _  | _ | _   | _  | _ |     | _   |         |
|    | HL,PC              | CF,F5             | HL←PC+2                                                | 2     | 2    | -            | _  | _ | _   | _  | - |     | _   |         |
|    | HL,#mmnn           |                   | HL←mmnn                                                | 3     | 3    | _            | _  | _ | _   | _  | _ |     | _   |         |
|    | HL,[hh <i>ll</i> ] | B9, <i>ll</i> ,hh | L←[hh <i>ll</i> ], H←[hh <i>ll</i> +1]                 | 5     | 3    | _            | _  | _ | _   |    | _ |     | -   | -       |
|    | HL,[HL]            | CF,C1             | $L\leftarrow$ [HL], H $\leftarrow$ [HL+1]              | 5     | 2    | -            | _  | _ | _   | _  | _ |     | -   |         |
|    | HL,[IX]            | CF,D1             | L←[IX], H←[IX+1]                                       | 5     | 2    | _            | _  | _ | _   | _  | - |     | _   |         |
|    | HL,[IY]            | CF,D9             | $L\leftarrow$ [IY], $H\leftarrow$ [IY+1]               | 5     | 2    | -            | _  | _ | _   | _  | _ |     |     |         |
|    | HL,[SP+dd]         |                   | $L\leftarrow[SP+dd], H\leftarrow[SP+dd+1]$             | 6     | 3    | _            | _  | _ | _   | _  | - |     | -   |         |
| LD | IX,BA              | CF,E8             | IX←BA                                                  | 2     | 2    | _            | _  | - | _   | -  | - |     | -   |         |
|    | IX,HL              | CF,E9             | IX←HL                                                  | 2     | 2    | _            | _  | _ | _   | -  | - |     |     |         |
|    | IX,IX              | CF,EA             | IX←IX                                                  | 2     | 2    | _            | _  | _ | _   | -  | - |     |     |         |
|    | IX,IY              | CF,EB             | IX←IY                                                  | 2     | 2    | _            | _  | - | _   | -  | - |     | -   |         |
|    | IX,SP              | CF,FA             | IX←SP                                                  | 2     | 2    | _            | _  | - | _   | -  | - |     | -   |         |
|    | IX,#mmnn           | C6,nn,mm          | IX←mmnn                                                | 3     | 3    | -            | -  | _ | -   | -  | - |     | -   |         |
|    | IX,[hh <i>ll</i> ] | BA,ll,hh          | $IX(L)\leftarrow[hhll],\ IX(H)\leftarrow[hhll+1]$      | 5     | 3    | _            | -  | - | -   | _  | - |     | -   |         |
|    | IX,[HL]            | CF,C2             | $IX(L) \leftarrow [HL], \ IX(H) \leftarrow [HL+1]$     | 5     | 2    | -            | -  | - | -   | -  | - |     | -   |         |
|    | IX,[IX]            | CF,D2             | $IX(L)\leftarrow [IX], IX(H)\leftarrow [IX+1]$         | 5     | 2    | -            | -  | - | -   | -  | - |     | -   |         |
|    | IX,[IY]            | CF,DA             | $IX(L)\leftarrow [IY], IX(H)\leftarrow [IY+1]$         | 5     | 2    | _            | _  | - | _   | _  | - |     |     |         |
|    | IX,[SP+dd]         | CF,72,dd          | $IX(L)\leftarrow[SP+dd], IX(H)\leftarrow[SP+dd+1]$     | 6     | 3    | _            | _  | _ | _   | _  | - |     | -   |         |
| LD | IY,BA              | CF,EC             | IY←BA                                                  | 2     | 2    | -            | -  | _ | -   | _  | - |     | -   |         |
|    | IY,HL              | CF,ED             | IY←HL                                                  | 2     | 2    | -            | -  | _ | -   | _  | - |     | -   |         |
|    | IY,IX              | CF,EE             | IY←IX                                                  | 2     | 2    | -            | _  | _ | _   | _  | - |     |     |         |
|    | IY,IY              | CF,EF             | IY←IY                                                  | 2     | 2    | -            | _  | _ | _   | _  | - |     |     |         |
|    | IY,SP              | CF,FE             | IY←SP                                                  | 2     | 2    | <u> </u>     | _  | - | _   | -  | - |     | _   |         |
|    | IY,#mmnn           | C7,nn,mm          | IY←mmnn                                                | 3     | 3    | -            | _  | _ | _   | _  | - |     |     |         |
|    | IY,[hh <i>ll</i> ] | BB, <i>ll</i> ,hh | $IY(L)\leftarrow[hhll], IY(H)\leftarrow[hhll+1]$       | 5     | 3    | <u> </u>     | _  | _ | _   | _  | _ |     |     |         |
|    | IY,[HL]            | CF,C3             | $IY(L)\leftarrow[HL], IY(H)\leftarrow[HL+1]$           | 5     | 2    | _            | _  | _ | _   | _  | _ |     |     |         |
|    | IY,[IX]            | CF,D3             | $IY(L) \leftarrow [IX], IY(H) \leftarrow [IX+1]$       | 5     | 2    | -            | _  | _ | _   | _  | _ |     |     |         |
|    | IY,[IY]            | CF,DB             | $IY(L) \leftarrow [IY], IY(H) \leftarrow [IY+1]$       | 5     | 2    | _            | _  | _ | _   | _  | _ |     | _   |         |
|    | IY,[SP+dd]         | CF,73,dd          | $IY(L) \leftarrow [SP+dd], IY(H) \leftarrow [SP+dd+1]$ | 6     | 3    | <del> </del> | _  | _ | _   | _  | _ |     |     |         |
|    | [,[5, 144]         | 01,70,00          | 11(2) (D1 (00), 11(11) (D1 (01))                       | J     | J    |              |    |   | _   |    |   |     |     |         |

# 16-bit Trnsfer Instructions (2/2)

| Mr   | nemonic            | Machine Code   | Operation                                                                  | Cycle | Byte |    |    |   | S | С |   |   |   | Comment |
|------|--------------------|----------------|----------------------------------------------------------------------------|-------|------|----|----|---|---|---|---|---|---|---------|
| 1011 | ICITIOTIIC         | Macrillic Code | Орстаноп                                                                   | Cycle | Dyte | 11 | 10 | U | D | Ν | ٧ | С | Z | Comment |
| LD   | SP,BA              | CF,F0          | SP←BA                                                                      | 2     | 2    | _  | -  | _ | - | - | - | _ | - |         |
|      | SP,[hh/l/]         | CF,78,11,hh    | $SP(L)\leftarrow[hhll], SP(H)\leftarrow[hhll+1]$                           | 6     | 4    | _  | _  | _ | - | _ | _ | _ | _ |         |
|      | SP,HL              | CF,F1          | SP←HL                                                                      | 2     | 2    | _  | -  | _ | _ | _ | - | _ | - |         |
|      | SP,IX              | CF,F2          | SP←IX                                                                      | 2     | 2    | _  | -  | - | - | - | - | _ | - |         |
|      | SP,IY              | CF,F3          | SP←IY                                                                      | 2     | 2    | _  | -  | - | - | - | - | _ | - |         |
|      | SP,#mmnn           | CF,6E,nn,mm    | SP←mmnn                                                                    | 4     | 4    | _  | -  | - | - | - | - | _ | - |         |
| LD   | [hh <i>ll</i> ],BA | BC,ll,hh       | $[hhll]\leftarrow A, [hhll+1]\leftarrow B$                                 | 5     | 3    | _  | -  | - | - | - | - | _ | - |         |
|      | [hh <i>ll</i> ],HL | BD,ll,hh       | $[hhll]\leftarrow L, [hhll+1]\leftarrow H$                                 | 5     | 3    | _  | -  | - | - | - | - | _ | - |         |
|      | [hh <i>ll</i> ],IX | BE,ll,hh       | $[hh\mathit{ll}] \leftarrow IX(L), \ [hh\mathit{ll} + 1] \leftarrow IX(H)$ | 5     | 3    | _  | -  | - | - | - | - | _ | - |         |
|      | [hh <i>ll</i> ],IY | BF,ll,hh       | $[hh\mathit{ll}] \leftarrow IY(L), \ [hh\mathit{ll} + 1] \leftarrow IY(H)$ | 5     | 3    | _  | -  | - | - | - | - | _ | - |         |
|      | [hh <i>ll</i> ],SP | CF,7C,ll,hh    | $[hhll] \leftarrow SP(L), [hhll+1] \leftarrow SP(H)$                       | 6     | 4    | -  | -  | - | - | _ | - | _ | - |         |
| LD   | [HL],BA            | CF,C4          | [HL]←A, [HL+1]←B                                                           | 5     | 2    | _  | -  | _ | - | - | - | - | - |         |
|      | [HL],HL            | CF,C5          | [HL]←L, [HL+1]←H                                                           | 5     | 2    | -  | -  | _ | - | - | - | _ | - |         |
|      | [HL],IX            | CF,C6          | $[HL] \leftarrow IX(L), \ [HL+1] \leftarrow IX(H)$                         | 5     | 2    | -  | -  | _ | - | - | - | _ | - |         |
|      | [HL],IY            | CF,C7          | $[HL] \leftarrow IY_{(L)}, \ [HL+1] \leftarrow IY_{(H)}$                   | 5     | 2    | _  | -  | _ | - | - | - | _ | - |         |
| LD   | [IX],BA            | CF,D4          | $[IX]\leftarrow A, [IX+1]\leftarrow B$                                     | 5     | 2    | -  | -  | - | - | _ | - | _ | - |         |
|      | [IX],HL            | CF,D5          | $[IX]\leftarrow L, [IX+1]\leftarrow H$                                     | 5     | 2    | _  | -  | _ | - | - | - | - | - |         |
|      | [IX],IX            | CF,D6          | $[IX] \leftarrow IX_{(L)}, \ [IX+1] \leftarrow IX_{(H)}$                   | 5     | 2    | _  | -  | - | - | - | - | _ | - |         |
|      | [IX],IY            | CF,D7          | $[IX] \leftarrow IY_{(L)}, \ [IX+1] \leftarrow IY_{(H)}$                   | 5     | 2    | _  | -  | - | - | - | - | _ | - |         |
| LD   | [IY],BA            | CF,DC          | $[IY]\leftarrow A, [IY+1]\leftarrow B$                                     | 5     | 2    | _  | -  | - | - | - | - | _ | - |         |
|      | [IY],HL            | CF,DD          | [IY]←L, [IY+1]←H                                                           | 5     | 2    | -  | -  | _ | - | - | - | - | - |         |
|      | [IY],IX            | CF,DE          | $[IY] \leftarrow IX(L), [IY+1] \leftarrow IX(H)$                           | 5     | 2    | -  | -  | _ | - | - | - | - | - |         |
|      | [IY],IY            | CF,DF          | $[IY] \leftarrow IY(L), \ [IY+1] \leftarrow IY(H)$                         | 5     | 2    | _  | -  | _ | - | - | - | _ | - |         |
| LD   | [SP+dd],BA         | CF,74,dd       | $[SP+dd]\leftarrow A, [SP+dd+1]\leftarrow B$                               | 6     | 3    | -  | -  | _ | - | - | - | - | - |         |
|      | [SP+dd],HL         | CF,75,dd       | $[SP+dd]\leftarrow L, [SP+dd+1]\leftarrow H$                               | 6     | 3    | -  | -  | _ | - | - | - | _ | - |         |
|      | [SP+dd],IX         | CF,76,dd       | $[SP+dd] \leftarrow IX(L), \ [SP+dd+1] \leftarrow IX(H)$                   | 6     | 3    | -  | -  | _ | - | - | - | _ | - |         |
|      | [SP+dd],IY         | CF,77,dd       | $[SP+dd]\leftarrow IY(L), [SP+dd+1]\leftarrow IY(H)$                       | 6     | 3    | _  | _  | _ | _ | _ | _ | _ | _ |         |
| EX   | BA,HL              | C8             | BA↔HL                                                                      | 3     | 1    | _  | -  | _ | - | _ | _ | _ | - |         |
|      | BA,IX              | C9             | BA↔IX                                                                      | 3     | 1    | _  | _  | _ | _ | _ | _ | _ | _ |         |
|      | BA,IY              | CA             | BA⇔IY                                                                      | 3     | 1    | -  | -  | - | - | - | - | - | - |         |
|      | BA,SP              | СВ             | BA↔SP                                                                      | 3     | 1    | _  | -  | - | - | - | - | - | - |         |

# 8-bit Arithmetic and Logic Operation Instructions (1/4)

| Mr   | nemonic            | Machine Code      | Operation                         | Cycle | Byte |    |    |   | 5 | SC       |          |   |   | Comment |
|------|--------------------|-------------------|-----------------------------------|-------|------|----|----|---|---|----------|----------|---|---|---------|
| IVII | lemonic            | Machine Code      | Operation                         | Сусіє | Буце | 11 | 10 | U | D | Ν        | ٧        | C | Z | Comment |
| ADD  | A,A                | 00                | $A \leftarrow A + A$              | 2     | 1    | -  | _  | * | * | \$       | <b>‡</b> | 1 | ‡ |         |
|      | A,B                | 01                | $A \leftarrow A + B$              | 2     | 1    | ı  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,#nn              | 02,nn             | $A \leftarrow A + nn$             | 2     | 2    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[BR:11]          | 04,11             | $A \leftarrow A + [BR: ll]$       | 3     | 2    | -  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | A,[hh <i>ll</i> ]  | 05, <i>ll</i> ,hh | $A \leftarrow A + [hhll]$         | 4     | 3    | ı  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | A,[HL]             | 03                | $A\leftarrow A+[HL]$              | 2     | 1    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IX]             | 06                | $A \leftarrow A + [IX]$           | 2     | 1    | -  | -  | * | * | <b>‡</b> | \$       |   |   |         |
|      | A,[IY]             | 07                | $A \leftarrow A + [IY]$           | 2     | 1    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IX+dd]          | CE,00,dd          | $A \leftarrow A + [IX + dd]$      | 4     | 3    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[IY+dd]          | CE,01,dd          | $A \leftarrow A + [IY + dd]$      | 4     | 3    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IX+L]           | CE,02             | $A \leftarrow A + [IX + L]$       | 4     | 2    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IY+L]           | CE,03             | $A \leftarrow A + [IY + L]$       | 4     | 2    | -  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | [HL],A             | CE,04             | [HL]←[HL]+A                       | 4     | 2    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | [HL],#nn           | CE,05,nn          | [HL]←[HL]+nn                      | 5     | 3    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | [HL],[IX]          | CE,06             | [HL]←[HL]+[IX]                    | 5     | 2    | Ŀ  | _  | * | * | <b>‡</b> | <b>‡</b> | 1 |   |         |
|      | [HL],[IY]          | CE,07             | [HL]←[HL]+[IY]                    | 5     | 2    | _  | _  | * | * | <b>‡</b> | <b>‡</b> | 1 |   |         |
| ADC  | A,A                | 08                | $A \leftarrow A + A + C$          | 2     | 1    | _  | -  | * | * | \$       | <b>‡</b> | 1 | ‡ |         |
|      | A,B                | 09                | $A \leftarrow A + B + C$          | 2     | 1    | _  | -  | * | * | \$       | ‡        | 1 |   |         |
|      | A,#nn              | 0A,nn             | $A\leftarrow A+nn+C$              | 2     | 2    | ı  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | A,[BR: <i>ll</i> ] | 0C, <i>ll</i>     | $A\leftarrow A+[BR:ll]+C$         | 3     | 2    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[hh <i>ll</i> ]  | 0D, <i>ll</i> ,hh | $A \leftarrow A + [hhll] + C$     | 4     | 3    | -  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[HL]             | 0B                | $A\leftarrow A+[HL]+C$            | 2     | 1    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[IX]             | 0E                | $A \leftarrow A + [IX] + C$       | 2     | 1    | ı  | -  | * | * | \$       | <b>‡</b> | 1 | ‡ |         |
|      | A,[IY]             | 0F                | $A \leftarrow A + [IY] + C$       | 2     | 1    | ı  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | A,[IX+dd]          | CE,08,dd          | $A\leftarrow A+[IX+dd]+C$         | 4     | 3    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IY+dd]          | CE,09,dd          | $A \leftarrow A + [IY + dd] + C$  | 4     | 3    | -  | -  | * | * | <b>‡</b> | \$       | 1 | ‡ |         |
|      | A,[IX+L]           | CE,0A             | $A\leftarrow A+[IX+L]+C$          | 4     | 2    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | A,[IY+L]           | CE,0B             | $A \leftarrow A + [IY + L] + C$   | 4     | 2    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | [HL],A             | CE,0C             | $[HL]\leftarrow [HL]+A+C$         | 4     | 2    | -  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | [HL],#nn           | CE,0D,nn          | $[HL]\leftarrow [HL]+nn+C$        | 5     | 3    | _  | -  | * | * | \$       | \$       | 1 | ‡ |         |
|      | [HL],[IX]          | CE,0E             | $[HL]\leftarrow [HL]+[IX]+C$      | 5     | 2    | _  | -  | * |   |          | <b>‡</b> | 1 | ‡ |         |
|      | [HL],[IY]          | CE,0F             | $[HL] \leftarrow [HL] + [IY] + C$ | 5     | 2    | _  | -  | * | * | \$       | \$       | 1 |   |         |
| SUB  | A,A                | 10                | A←A-A                             | 2     | 1    | -  | -  | * | * | ‡        | <b>‡</b> | 1 | ‡ |         |
|      | A,B                | 11                | A←A-B                             | 2     | 1    | _  | -  |   | * |          | <b>‡</b> |   |   |         |
|      | A,#nn              | 12,nn             | A←A-nn                            | 2     | 2    | _  | -  | * | * | \$       | <b>‡</b> | 1 |   |         |
|      | A,[BR: <i>ll</i> ] | 14, <i>ll</i>     | $A \leftarrow A - [BR:ll]$        | 3     | 2    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[hh <i>ll</i> ]  | 15, <i>ll</i> ,hh | $A \leftarrow A-[hhll]$           | 4     | 3    | _  | _  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[HL]             | 13                | $A\leftarrow A-[HL]$              | 2     | 1    | _  | -  | * | * | \$       | <b>‡</b> | 1 | ‡ |         |
|      | A,[IX]             | 16                | $A \leftarrow A - [IX]$           | 2     | 1    | _  | _  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[IY]             | 17                | A←A-[IY]                          | 2     | 1    | _  | _  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |
|      | A,[IX+dd]          | CE,10,dd          | $A \leftarrow A - [IX + dd]$      | 4     | 3    | _  | -  | * | * | <b>‡</b> | ‡        |   |   |         |
|      | A,[IY+dd]          | CE,11,dd          | $A \leftarrow A - [IY + dd]$      | 4     | 3    | Ŀ  | _  | * | * | <b>‡</b> | <b></b>  |   |   |         |
|      | A,[IX+L]           | CE,12             | $A \leftarrow A - [IX + L]$       | 4     | 2    | _  | -  | * | * | <b>‡</b> | <b>‡</b> |   |   |         |
|      | A,[IY+L]           | CE,13             | $A \leftarrow A - [IY + L]$       | 4     | 2    | _  | _  | * | * | <b>‡</b> | <b>‡</b> |   |   |         |
|      | [HL],A             | CE,14             | [HL]←[HL]-A                       | 4     | 2    | _  | -  | * | * | <b>‡</b> | <b>‡</b> |   |   |         |
|      | [HL],#nn           | CE,15,nn          | [HL]←[HL]-nn                      | 5     | 3    | _  | _  | * | * | <b>‡</b> | ‡        | 1 | ‡ |         |
|      | [HL],[IX]          | CE,16             | [HL]←[HL]-[IX]                    | 5     | 2    | _  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 |   |         |
|      | [HL],[IY]          | CE,17             | $[HL] \leftarrow [HL] - [IY]$     | 5     | 2    | -  | -  | * | * | <b>‡</b> | <b>‡</b> | 1 | ‡ |         |

# 8-bit Arithmetic and Logic Operation Instructions (2/4)

| Mn  | emonic               | Machine Code      | Operation                               | Cycle | Byte |          | _ | 10           |              |   | SC         |   | .,           | _            | Z            | Comment |
|-----|----------------------|-------------------|-----------------------------------------|-------|------|----------|---|--------------|--------------|---|------------|---|--------------|--------------|--------------|---------|
| SBC | A,A                  | 18                | A←A-A-C                                 | 2     | 1    | -        |   |              |              |   | ) N        |   | v<br>↓       | <b>∵</b>     | <u>∠</u>     |         |
|     | A,B                  | 19                | A←A-B-C                                 | 2     | 1    | ⊢        |   |              |              |   | <u> </u>   |   | <del>*</del> | <b>†</b>     | <b>‡</b>     |         |
|     | A,#nn                | 1A,nn             | A←A-nn-C                                | 2     | 2    | ⊢        | _ | _            |              | _ | <b>k</b> ( |   | <del>*</del> | <u>†</u>     | <b>†</b>     |         |
|     | A,[BR: <i>ll</i> ]   | 1C, <i>ll</i>     | A←A-[BR: <i>ll</i> ]-C                  | 3     | 2    | ⊢        |   |              | *            |   |            |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[hh <i>ll</i> ]    | 1D, <i>ll</i> ,hh | A←A-[hh <i>ll</i> ]-C                   | 4     | 3    | ļ -      | _ | _            | *            | 7 |            |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[HL]               | 1B                | A←A-[HL]-C                              | 2     | 1    | t-       | _ | _            | *            | , | <b>k</b> ( |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IX]               | 1E                | A←A-[IX]-C                              | 2     | 1    | t-       | _ | _            | *            | 7 | <b>k</b> ( |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IY]               | 1F                | A←A-[IY]-C                              | 2     | 1    | ļ-       | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IX+dd]            | CE,18,dd          | A←A-[IX+dd]-C                           | 4     | 3    | -        | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IY+dd]            | CE,19,dd          | A←A-[IY+dd]-C                           | 4     | 3    | -        |   | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IX+L]             | CE,1A             | A←A-[IX+L]-C                            | 4     | 2    | 1-       | _ | _            | *            | 7 | <b>k</b> ( |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | A,[IY+L]             | CE,1B             | A←A-[IY+L]-C                            | 4     | 2    | -        | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | [HL],A               | CE,1C             | [HL]←[HL]-A-C                           | 4     | 2    | -        | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | [HL],#nn             | CE,1D,nn          | [HL]←[HL]-nn-C                          | 5     | 3    | -        | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | [HL],[IX]            | CE,1E             | [HL]←[HL]-[IX]-C                        | 5     | 2    | Ī-       | _ | _            | *            | 7 | <b>k</b> ( | , | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
|     | [HL],[IY]            | CE,1F             | [HL]←[HL]-[IY]-C                        | 5     | 2    | -        |   |              | *            |   |            |   | <b>‡</b>     | <b>‡</b>     | <b>‡</b>     |         |
| AND | A,A                  | 20                | A←A∧A                                   | 2     | 1    | T-       | _ | _            | _            | - | - (        | , | _            | _            | <b>‡</b>     |         |
|     | A,B                  | 21                | A←A∧B                                   | 2     | 1    | -        | _ | -            | _            | - | - 1        | , | _            | _            | <b>‡</b>     |         |
|     | A,#nn                | 22,nn             | A←A∧nn                                  | 2     | 2    | -        | _ | _            | _            | - | - (        | , | -            | _            | <b>‡</b>     |         |
|     | A,[BR: <i>ll</i> ]   | 24, <i>ll</i>     | A←A∧[BR: <i>ll</i> ]                    | 3     | 2    | -        | _ | _            | _            | - | - (        | , | -            | _            | <b>‡</b>     |         |
|     | A,[hh/l/]            | 25, <i>ll</i> ,hh | $A \leftarrow A \wedge [hhll]$          | 4     | 3    | -        | _ | _            | _            | - | - 1        | , | _            | _            | <b>‡</b>     |         |
|     | A,[HL]               | 23                | A←A∧[HL]                                | 2     | 1    | -        | _ | _            | _            | - | - (        | , | _            | _            | <b>‡</b>     |         |
|     | A,[IX]               | 26                | $A \leftarrow A \wedge [IX]$            | 2     | 1    | Ī-       | _ | -            | _            | - | - (        | - | _            | _            | <b>‡</b>     |         |
|     | A,[IY]               | 27                | $A \leftarrow A \wedge [IY]$            | 2     | 1    | -        | _ | _            | _            | - | - (        | , | _            | _            | <b>‡</b>     |         |
|     | A,[IX+dd]            | CE,20,dd          | $A \leftarrow A \wedge [IX + dd]$       | 4     | 3    | -        | - | _            | -            | - | - (        | - | _            | _            | <b>‡</b>     |         |
|     | A,[IY+dd]            | CE,21,dd          | $A \leftarrow A \land [IY + dd]$        | 4     | 3    | <u> </u> | _ | _            | _            | - | - (        | - | _            | _            | <b>‡</b>     |         |
|     | A,[IX+L]             | CE,22             | $A \leftarrow A \wedge [IX + L]$        | 4     | 2    | ŀ        | _ | _            | _            | - | - (        | ) | _            | _            | <b>‡</b>     |         |
|     | A,[IY+L]             | CE,23             | $A \leftarrow A \wedge [IY + L]$        | 4     | 2    | ŀ        | _ | _            | _            | - | - (        | - | _            | _            | <b>‡</b>     |         |
|     | B,#nn                | CE,B0,nn          | B←B∧nn                                  | 3     | 3    | -        | - | -            | -            | - | - 1        | , | _            | -            | <b>‡</b>     |         |
|     | L,#nn                | CE,B1,nn          | L←L∧nn                                  | 3     | 3    | Ŀ        | _ | _            | _            | _ | - 1        | - | _            | _            | <b>‡</b>     |         |
|     | H,#nn                | CE,B2,nn          | H←H∧nn                                  | 3     | 3    | ŀ        | _ | -            | _            | - | - 1        | - | _            | _            | <b>‡</b>     |         |
|     | SC,#nn               | 9C,nn             | SC←SC∧nn                                | 3     | 2    | 1        | l | $\downarrow$ | $\downarrow$ | , | 1          | , | $\downarrow$ | $\downarrow$ | $\downarrow$ |         |
|     | [BR: <i>ll</i> ],#nn | D8,ll,nn          | $[BR: ll] \leftarrow [BR: ll] \land nn$ | 5     | 3    | -        | _ | _            | _            | - | - 1        | , | _            | _            | <b>‡</b>     |         |
|     | [HL],A               | CE,24             | [HL]←[HL]∧A                             | 4     | 2    | -        | - | -            | _            | - | - 1        |   | _            | _            | <b>‡</b>     |         |
|     | [HL],#nn             | CE,25,nn          | [HL]←[HL]∧nn                            | 5     | 3    | Ŀ        | _ | _            | _            | _ | - (        | , | _            | _            | <b>‡</b>     |         |
|     | [HL],[IX]            | CE,26             | [HL]←[HL]∧[IX]                          | 5     | 2    | Ŀ        | _ | _            | _            | - | - 1        | - | _            | _            | <b>‡</b>     |         |
|     | [HL],[IY]            | CE,27             | [HL]←[HL]∧[IY]                          | 5     | 2    | ŀ        | - | -            | _            | - |            |   | _            |              | <b>‡</b>     |         |
| OR  | A,A                  | 28                | A←A∨A                                   | 2     | 1    | Ŀ        | _ | _            | _            | _ | - 1        | _ | _            | _            | <b>‡</b>     |         |
|     | A,B                  | 29                | A←A∨B                                   | 2     | 1    | Ŀ        | _ | -            | _            | - | - 1        | , | _            | _            | <b>‡</b>     |         |
|     | A,#nn                | 2A,nn             | A←A∨nn                                  | 2     | 2    | Ŀ        | _ | _            | -            | - | - 1        | _ | _            | _            | <b>‡</b>     |         |
|     | A,[BR: <i>ll</i> ]   | 2C,ll             | $A \leftarrow A \lor [BR:ll]$           | 3     | 2    | -        | - | -            | _            | - | - 1        | , | _            | _            | <b>‡</b>     |         |
|     | A,[hh <i>ll</i> ]    | 2D, <i>ll</i> ,hh | $A \leftarrow A \lor [hhll]$            | 4     | 3    | Ŀ        | _ | _            | _            | - | _          | _ | _            |              | <b>‡</b>     |         |
|     | A,[HL]               | 2B                | A←A∨[HL]                                | 2     | 1    | Ŀ        | - | _            | _            | - |            | _ | _            |              | <b>‡</b>     |         |
|     | A,[IX]               | 2E                | $A \leftarrow A \lor [IX]$              | 2     | 1    | ŀ        | _ | _            | _            | _ | _          | _ | _            |              | <b>‡</b>     |         |
|     | A,[IY]               | 2F                | $A \leftarrow A \lor [IY]$              | 2     | 1    | ŀ        | - | _            | _            | - | - (        | , | _            | _            | <b>‡</b>     |         |
|     | A,[IX+dd]            | CE,28,dd          | $A \leftarrow A \lor [IX + dd]$         | 4     | 3    | ŀ        | _ | _            | _            | _ | _          | _ | _            |              | <b>‡</b>     |         |
|     | A,[IY+dd]            | CE,29,dd          | $A \leftarrow A \lor [IY + dd]$         | 4     | 3    | Ŀ        | _ | _            | _            | - |            |   | _            |              | <b>‡</b>     |         |
|     | A,[IX+L]             | CE,2A             | $A \leftarrow A \lor [IX + L]$          | 4     | 2    | -        | _ | _            | _            | _ | - (        | , | _            | _            | <b>‡</b>     |         |

# 8-bit Arithmetic and Logic Operation Instructions (3/4)

| N 4 - |                      | Mashina Cada      | Onenation                            | C 1   | ъ.   |          |          |          | 5        | SC       |          |     |     | Comment |
|-------|----------------------|-------------------|--------------------------------------|-------|------|----------|----------|----------|----------|----------|----------|-----|-----|---------|
| IVII  | nemonic              | Machine Code      | Operation                            | Cycle | Вуте | 11       | 10       | U        | D        | Ν        | ٧        | ′ ( | ) Z | Comment |
| OR    | A,[IY+L]             | CE,2B             | $A \leftarrow A \lor [IY + L]$       | 4     | 2    | _        | _        | -        | _        | <b>‡</b> | _        |     | - ( |         |
|       | B,#nn                | CE,B4,nn          | B←B∨nn                               | 3     | 3    | -        | _        | _        | -        | <b>‡</b> | _        | -   | - ( |         |
|       | L,#nn                | CE,B5,nn          | L←L∨nn                               | 3     | 3    | <u> </u> | _        | _        | -        | <b>‡</b> | _        | -   | - ( |         |
|       | H,#nn                | CE,B6,nn          | H←H∨nn                               | 3     | 3    | -        | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | SC,#nn               | 9D,nn             | SC←SC∨nn                             | 3     | 2    | 1        | 1        | 1        | 1        | 1        | 1        | •   | 1   |         |
|       | [BR: <i>ll</i> ],#nn | D9,ll,nn          | [BR: <i>ll</i> ]←[BR: <i>ll</i> ]∨nn | 5     | 3    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | [HL],A               | CE,2C             | [HL]←[HL]∨A                          | 4     | 2    | <u> </u> | _        | _        | -        | <b>‡</b> | _        | -   | - ( |         |
|       | [HL],#nn             | CE,2D,nn          | [HL]←[HL]∨nn                         | 5     | 3    | <b> </b> | _        | _        | -        | <b>‡</b> | _        | -   | - ( |         |
|       | [HL],[IX]            | CE,2E             | [HL]←[HL]∨[IX]                       | 5     | 2    | -        | _        | _        | -        | <b>‡</b> | _        | -   | - ( |         |
|       | [HL],[IY]            | CE,2F             | [HL]←[HL]∨[IY]                       | 5     | 2    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
| XOR   | A,A                  | 38                | $A \leftarrow A \forall A$           | 2     | 1    | -        | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | A,B                  | 39                | $A \leftarrow A \forall B$           | 2     | 1    | -        | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | A,#nn                | 3A,nn             | A←A∀nn                               | 2     | 2    | -        | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | A,[BR:11]            | 3C, <i>ll</i>     | $A \leftarrow A \forall [BR: ll]$    | 3     | 2    | -        | _        | _        | _        | <b>‡</b> | -        | -   | - ( |         |
|       | A,[hh <i>ll</i> ]    | 3D, <i>ll</i> ,hh | $A \leftarrow A \forall [hhll]$      | 4     | 3    | <u> </u> | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | A,[HL]               | 3B                | A←A∀[HL]                             | 2     | 1    | <u> </u> | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | A,[IX]               | 3E                | A←A∀[IX]                             | 2     | 1    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | A,[IY]               | 3F                | A←A∀[IY]                             | 2     | 1    | -        | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | A,[IX+dd]            | CE,38,dd          | $A \leftarrow A \forall [IX + dd]$   | 4     | 3    | -        | _        | _        | _        | <b></b>  | _        |     | - ( |         |
|       | A,[IY+dd]            | CE,39,dd          | $A \leftarrow A \forall [IY + dd]$   | 4     | 3    | <b> </b> | _        | _        | _        | <b></b>  |          |     |     |         |
|       | A,[IX+L]             | CE,3A             | $A \leftarrow A \forall [IX+L]$      | 4     | 2    | <u> </u> | _        | _        | _        | <b>‡</b> | _        | -   | - ( |         |
|       | A,[IY+L]             | CE,3B             | A←A∀[IY+L]                           | 4     | 2    | <u> </u> | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | B,#nn                | CE,B8,nn          | B←B∀nn                               | 3     | 3    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | L,#nn                | CE,B9,nn          | L←L∀nn                               | 3     | 3    | -        |          | _        |          |          |          |     | - ( |         |
|       | H,#nn                | CE,BA,nn          | H←H∀nn                               | 3     | 3    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | SC,#nn               | 9E,nn             | SC←SC∀nn                             | 3     | 2    | \$       | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | [BR: <i>ll</i> ],#nn | DA,ll,nn          | [BR: <i>ll</i> ]←[BR: <i>ll</i> ]∀nn | 5     | 3    | <u> </u> | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | [HL],A               | CE,3C             | [HL]←[HL]∀A                          | 4     | 2    | <u> </u> | _        | _        | _        | <b>‡</b> | _        | -   | _   |         |
|       | [HL],#nn             | CE,3D,nn          | [HL]←[HL]∀nn                         | 5     | 3    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | [HL],[IX]            | CE,3E             | [HL]←[HL]∀[IX]                       | 5     | 2    | -        | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
|       | [HL],[IY]            | CE,3F             | [HL]←[HL]∀[IY]                       | 5     | 2    | <u> </u> | _        | _        | _        | <b>‡</b> | _        |     | - ( |         |
| СР    | A,A                  | 30                | A-A                                  | 2     | 1    | <u> </u> | _        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | A,B                  | 31                | A-B                                  | 2     | 1    | <u> </u> | _        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | A,#nn                | 32,nn             | A-nn                                 | 2     | 2    | -        | -        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | A,[BR:11]            | 34, <i>ll</i>     | A-[BR: <i>ll</i> ]                   | 3     | 2    | -        | _        | _        | -        | <b>‡</b> | <b>‡</b> | ;   | 1   |         |
|       | A,[hh <i>ll</i> ]    | 35, <i>ll</i> ,hh | A-[hh <i>ll</i> ]                    | 4     | 3    | -        | _        | -        | _        | <b>‡</b> |          |     | 1   |         |
|       | A,[HL]               | 33                | A-[HL]                               | 2     | 1    | -        | _        | _        | -        | -        | <b>‡</b> |     | 1   |         |
|       | A,[IX]               | 36                | A-[IX]                               | 2     | 1    | _        | _        | _        | -        | <b>‡</b> | <b>‡</b> |     | ; ; |         |
|       | A,[IY]               | 37                | A-[IY]                               | 2     | 1    | -        | _        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | A,[IX+dd]            | CE,30,dd          | A-[IX+dd]                            | 4     | 3    | -        | _        | _        | _        | <b>‡</b> | <b>1</b> |     | 1   |         |
|       | A,[IY+dd]            | CE,31,dd          | A-[IY+dd]                            | 4     | 3    | -        | _        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | A,[IX+L]             | CE,32             | A-[IX+L]                             | 4     | 2    | -        | -        | -        | -        | _        | <b>‡</b> |     | 1   |         |
|       | A,[IY+L]             | CE,33             | A-[IY+L]                             | 4     | 2    | -        | _        | -        | _        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | B,#nn                | CE,BC,nn          | B-nn                                 | 3     | 3    | -        | _        | _        | _        | <b>‡</b> | <b>‡</b> |     | 1   | _       |
|       | L,#nn                | CE,BD,nn          | L-nn                                 | 3     | 3    | -        |          | _        |          |          | <b>‡</b> |     | 1   | _       |
|       | H,#nn                | CE,BE,nn          | H-nn                                 | 3     | 3    | -        | _        | -        | -        | <b>‡</b> | <b>‡</b> |     | 1   |         |
|       | BR,#hh               | CE,BF,hh          | BR-hh                                | 3     | 3    | -        | _        | -        | _        | <b>‡</b> | <b>‡</b> |     |     |         |
|       | [BR: <i>ll</i> ],#nn | DB,ll,nn          | [BR:ll]-nn                           | 4     | 3    | -        | _        | _        | _        | <b>‡</b> | <b></b>  |     | 1   |         |

# 8-bit Arithmetic and Logic Operation Instructions (4/4)

| Mr  | nemonic              | Machine Code  | Operation                               | Cycle    | Byte | SC Comment                                           |
|-----|----------------------|---------------|-----------------------------------------|----------|------|------------------------------------------------------|
|     | _                    |               | •                                       | <u> </u> |      | 11 10 U D N V C Z                                    |
| СР  | [HL],A               | CE,34         | [HL]-A                                  | 3        | 2    | 1 1 1                                                |
|     | [HL],#nn             | CE,35,nn      | [HL]-nn                                 | 4        | 3    |                                                      |
|     | [HL],[IX]            | CE,36         | [HL]-[IX]                               | 4        | 2    | $   \updownarrow$ $\updownarrow$ $\updownarrow$      |
|     | [HL],[IY]            | CE,37         | [HL]-[IY]                               | 4        | 2    | $   \updownarrow$ $\updownarrow$ $\updownarrow$      |
| BIT | A,B                  | 94            | A∧B                                     | 2        | 1    |                                                      |
|     | A,#nn                | 96,nn         | A∧nn                                    | 2        | 2    | \ \ \ \                                              |
|     | B,#nn                | 97,nn         | B∧nn                                    | 2        | 2    | $   \updownarrow$ $  \updownarrow$                   |
|     | [BR: <i>ll</i> ],#nn | DC,ll,nn      | [BR:ll]∧nn                              | 4        | 3    | $   \updownarrow$ $  \updownarrow$                   |
|     | [HL],#nn             | 95,nn         | [HL]^nn                                 | 3        | 2    | $   \updownarrow$ $  \updownarrow$                   |
| INC | Α                    | 80            | A←A+1                                   | 2        | 1    | <b>↓</b>                                             |
|     | В                    | 81            | B←B+1                                   | 2        | 1    |                                                      |
|     | L                    | 82            | L←L+1                                   | 2        | 1    |                                                      |
|     | Н                    | 83            | H←H+1                                   | 2        | 1    |                                                      |
|     | BR                   | 84            | BR←BR+1                                 | 2        | 1    |                                                      |
|     | [BR: <i>ll</i> ]     | 85, <i>ll</i> | [BR: <i>ll</i> ]←[BR: <i>ll</i> ]+1     | 4        | 2    |                                                      |
|     | [HL]                 | 86            | [HL]←[HL]+1                             | 3        | 1    |                                                      |
| DEC | Α                    | 88            | A←A-1                                   | 2        | 1    |                                                      |
|     | В                    | 89            | B←B-1                                   | 2        | 1    |                                                      |
|     | L                    | 8A            | L←L-1                                   | 2        | 1    |                                                      |
|     | Н                    | 8B            | H←H-1                                   | 2        | 1    |                                                      |
|     | BR                   | 8C            | BR←BR-1                                 | 2        | 1    |                                                      |
|     | [BR: <i>ll</i> ]     | 8D, <i>ll</i> | [BR: <i>ll</i> ]←[BR: <i>ll</i> ]-1     | 4        | 2    |                                                      |
|     | [HL]                 | 8E            | [HL]←[HL]-1                             | 3        | 1    |                                                      |
| CPL | Α                    | CE,A0         | $A \leftarrow \overline{A}$             | 3        | 2    |                                                      |
|     | В                    | CE,A1         | $B\leftarrow\overline{B}$               | 3        | 2    |                                                      |
|     | [BR: <i>ll</i> ]     | CE,A2,ll      | $[BR:ll] \leftarrow \overline{[BR:ll]}$ | 5        | 3    | \$ \$                                                |
|     | [HL]                 | CE,A3         | [HL]←[HL]                               | 4        | 2    |                                                      |
| NEG | Α                    | CE,A4         | A←0-A                                   | 3        | 2    | <b>★ ★</b> ↑ ↑ ↑ ↑                                   |
|     | В                    | CE,A5         | B←0-B                                   | 3        | 2    | <b>★ ★</b> ↓ ↓ ↓ ↓                                   |
|     | [BR: <i>ll</i> ]     | CE,A6,ll      | [BR: <i>ll</i> ]←0-[BR: <i>ll</i> ]     | 5        | 3    | <b>★ ★</b> ↓ ↓ ↓ ↓                                   |
|     | [HL]                 | CE,A7         | [HL]←0-[HL]                             | 4        | 2    | <b>★ ★</b> ↓ ↓ ↓ ↓                                   |
| MLT |                      | CE,D8         | HL←L*A                                  | 12       | 2    | $   \updownarrow$ 0 0 $\updownarrow$ <i>MODEL1/3</i> |
| DIV |                      | CE,D9         | L←HL/A, H←Remainder                     | 13       | 2    | $   \uparrow$ $\uparrow$ $\downarrow$ only           |

<sup>\*</sup> Multiplication and division instructions are set only for MODEL1/3. In MODEL0/2, these instructions cannot be used.

# 16-bit Arithmetic Operation Instructions (1/2)

| ADD BA,BA CF,00 BA,HA CF,01 BA,HA CF,01 BA,HA CF,01 BA,HA CF,01 BA,HA CF,03 BA,HA H,C BA,IY CF,03 BA,HA BA,HY H,C                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Mr   | nemonic   | Machine Code   | Operation    | Cycle | Byte |          |   |   |   | 5 | SC       |   |          |          |          | Comment |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-----------|----------------|--------------|-------|------|----------|---|---|---|---|----------|---|----------|----------|----------|---------|
| BA,HL   CE,01   BA-BA+HL   4   2   1   1   1   1   1   1   1   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1011 | icitionic | Wacriirie Oode | Орстаноп     | Cycle | Dyte | 11       | I | 0 | U | D | Ν        | ١ | /        | С        | Z        | Comment |
| BAJX   CE02   BA←BA+IX   4   2   3   1   1   3   BA←BA+IX   BAJY   A   2   3   1   1   3   3   BA←BA+IX   A   2   3   1   1   3   3   BA←BA+IX   A   A   A   A   A   A   A   A   A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ADD  | BA,BA     | CF,00          | BA←BA+BA     | 4     | 2    | -        |   | _ | _ | _ | <b>‡</b> | , |          |          |          |         |
| BAJY   CF.03   BA-BAHY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | BA,HL     | CF,01          | BA←BA+HL     | 4     | 2    | _        |   | _ | - | _ | <b>‡</b> | , |          |          |          |         |
| BA,#mmnn   CO,nn,mm   BA←BA+mmnn   3   3   3     1   1   1   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | BA,IX     | CF,02          | BA←BA+IX     | 4     | 2    | _        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| HL,BA   CF,20   HL←HL+BA   4   2     1   1   1     HL,HL   CF,21   HL←HL+HL   4   2     1   1   1     HL,IX   CF,22   HL←HL+IX   4   2     1   1   1     HL,IY   CF,23   HL←HL+IY   4   2     1   1   1     HL,IY   CF,23   HL←HL+IY   4   2     1   1   1     HL,IY   CF,23   HL←HL+IY   4   2     1   1   1     HL,IMTON   CI.m.num   HL←HL+IMMIN   3   3     1   1   1     IX,BA   CF,40   IX←IX+BA   4   2     1   1   1     IX,HL   CF,41   IX←IX+BL   4   2     1   1   1     IX,HL   CF,41   IX←IX+BL   4   2     1   1   1     IX,HL   CF,42   IY←IY+BA   4   2     1   1   1     IX,HL   CF,43   IY←IY+BA   4   2     1   1   1     IY,HL   CF,43   IY←IY+BA   4   2     1   1   1     IY,Hmmon   C3,n,mm   IY←IY+mmon   3   3     1   1   1     IY,Hmmon   C3,n,mm   IY←IY+mmon   3   3     1   1   1     IY,Hmmon   C5,61,m,mm   IY←IY+mmon   4   4   2     1   1   1     SP,BA   CF,44   SP←SP+BA   4   2     1   1   1     SP,HL   CF,45   SP←SP+HL   4   2     1   1   1     SP,HM   CF,65   BA←BA+BA+C   4   2     1   1   1     BA,HL   CF,05   BA←BA+HL+C   4   2     1   1   1     BA,HL   CF,05   BA←BA+HL+C   4   2     1   1   1     BA,H   CF,06   BA←BA+HL+C   4   2     1   1   1     BA,H   CF,06   BA←BA+BA+C   4   2     1   1   1     BA,Hmmon   CF,60,n,mm   BA←BA+mmon+C   4   4   2     1   1   1     HL,IX   CF,26   HL←HL+HL+C   4   2     1   1   1     HL,IX   CF,26   HL←HL+HX+C   4   2     1   1   1     HL,IX   CF,27   HL←HL+HX+C   4   2     1   1   1     BA,H   CF,09   BA←BA+BA   4   2     1   1   1     BA,H   CF,09   BA←BA+BA   4   2     1   1   1     BA,H   CF,09   BA←BA-HM   4   2     1   1   1     BA,H   CF,09   BA←BA-HM   4   2     1   1   1     BA,H   CF,28   HL←HL-HX+C   4   2     1   1   1     BA,H   CF,29   HL←HL-HX+C   4   2     1   1   1     BA,H   CF,20   HL←HL-HX   4   2     1   1   1     BA,H   CF,28   HL←HL-HX   4   2               |      | BA,IY     | CF,03          | BA←BA+IY     | 4     | 2    | _        |   | _ | _ | _ | <b>‡</b> | , |          |          |          |         |
| HL,HL   CF,21                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      | BA,#mmnn  | C0,nn,mm       | BA←BA+mmnn   | 3     | 3    | _        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| HL, IX                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           | CF,20          | HL←HL+BA     | 4     | 2    | _        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| HL,   Y                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      | ,         | CF,21          | HL←HL+HL     | 4     | 2    | _        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| HL,#mmnn   Cl.nn,mm   HL-HL+mmnn   3   3   3     1   1   1   1   1   1   1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |           | CF,22          | HL←HL+IX     | 4     | 2    | -        |   | _ | - | - | <b>‡</b> |   |          |          |          |         |
| IX,BA   CF,40   IX←IX+BA   4   2     1   1   1   1     IX,HL   CF,41   IX←IX+HI   4   2     1   1   1     IX,Hmmn   C2,nn,mm   IX←IX+mmn   3   3     1   1   1     IX,Hmmn   C2,nn,mm   IX←IX+mmn   3   3     1   1   1     IY,BA   CF,42   IY←IY+BA   4   2     1   1   1     IY,Hmmn   C3,nn,mm   IY←IY+HI   4   2     1   1   1     IY,Hmmn   C3,nn,mm   IY←IY+HI   4   2     1   1   1     IY,Hmmn   C3,nn,mm   IY←IY+HI   4   2     1   1   1     SP,BA   CF,44   SP←SP+BA   4   2     1   1   1     SP,BA   CF,44   SP←SP+BA   4   2     1   1   1     SP,BH   CF,45   SP←SP+BA   4   2     1   1   1     SP,HI   CF,45   SP←SP+HI   4   2     1   1   1     SP,HI   CF,65   BA←BA+BA+C   4   2     1   1   1     BA,HI   CF,05   BA←BA+HL+C   4   2     1   1   1     BA,HI   CF,06   BA←BA+HY+C   4   2     1   1   1     BA,HI   CF,06   BA←BA+HY+C   4   2     1   1   1     BA,HI   CF,06   BA←BA+HY+C   4   2     1   1   1     BA,HI   CF,25   HI.←HI.+BA+C   4   2     1   1   1     HI.,BA   CF,24   HI.←HI.+BI.+C   4   2     1   1   1     HI.,HI   CF,25   HI.←HI.+HI.+C   4   2     1   1   1     HI.,HI   CF,27   HI.←HI.+HI.+C   4   2     1   1   1     HI.,HI   CF,27   HI.←HI.+HI.+C   4   2     1   1   1     HI.,HI   CF,08   BA←BA-BA   4   2     1   1   1     BA,IX   CF,00   BA←BA-IX   4            |      | HL,IY     | CF,23          | HL←HL+IY     | 4     | 2    | _        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| IX,HL   CF,41   IX=IX+HL   4   2     1   1   1   1     IX,#mmnn   C2,nn,mm   IX=IX+mmnn   3   3   3     1   1   1     IY,BA   CF,42   IY=IY+BA   4   2     1   1   1     IY,HL   CF,43   IY=IY+HL   4   2     1   1   1     IY,#mmnn   C3,nn,mm   IY=IY+mmnn   3   3   3     1   1   1     IY,#mmnn   C3,nn,mm   IY=IY+mmnn   3   3   3     1   1   1     SP,BA   CF,44   SP=SP+BA   4   2     1   1   1     SP,HC   CF,65   SP=SP+HL   4   2     1   1   1     SP,#mmnn   CF,68,nn,mm   SP=SP+mmnn   4   4     1   1   1     SP,#mmnn   CF,68,nn,mm   SP=SP+mmnn   4   4     1   1   1     SP,#mmnn   CF,60,5   BA=BA+BA+C   4   2     1   1   1     BA,BA   CF,04   BA=BA+BA+C   4   2     1   1   1     BA,IL   CF,05   BA=BA+HL+C   4   2     1   1   1     BA,IY   CF,07   BA=BA+IX+C   4   2     1   1   1     BA,IY   CF,07   BA=BA+IX+C   4   2     1   1   1     BA,IF   CF,07   BA=BA+IX+C   4   2     1   1   1     BA,IF   CF,24   HL=HL+BA+C   4   2     1   1   1     HL,BA   CF,24   HL=HL+HB+C   4   2     1   1   1     HL,IX   CF,25   HL=HL+HL+C   4   2     1   1   1     HL,IY   CF,27   HL=HL+IX+C   4   2     1   1   1     HL,IY   CF,27   HL=HL+IX+C   4   2     1   1   1     HL,IF   CF,08   BA=BA=BA   4   2     1   1   1     BA,HL   CF,09   BA=BA-BA   4   2     1   1   1     BA,IX   CF,08   BA=BA-BA   4   2     1   1   1     BA,IY   CF,08   BA=BA-BA   4   2     1   1   1     BA,IY   CF,08   BA=BA-BA   4   2     1   1   1     BA,IY   CF,09   BA=BA-BA   4   2     1   1   1     BA,IY   CF,28   HL=HL-HL-HL   4   2     1   1   1     BA,IY   CF,2      |      |           | C1,nn,mm       | HL←HL+mmnn   | 3     | 3    | Ŀ        |   | _ | _ | _ |          |   |          |          |          |         |
| IX,#mmnn   C2,nn,mm   IX←IX+mmnn   3   3   3     1   1   1   1     IY,BA   CF,42   IY,←IY,BA   4   2     1   1   1     IY,HL   CF,43   IY,←IY,HL   4   2     1   1   1     IY,#mmnn   C3,nn,mm   IY,←IY,Hmnnn   3   3     1   1   1     IY,#mmnn   C3,nn,mm   IY,←IY,Hmnnn   3   3     1   1   1     IY,#mmnn   C5,nn,mm   IY,←IY,Hmnnn   3   3     1   1   1     SP,BA   CF,44   SP←SP,BA   4   2     1   1   1     SP,BA   CF,44   SP←SP,BA   4   2     1   1   1     SP,BH   CF,45   SP,←SP,HI   4   2     1   1   1     SP,#mmnn   CF,645   SP,←SP,HI   4   2     1   1   1     SP,#mmnn   CF,645   SP,←SP,HI   4   2     1   1   1     SP,#mmnn   CF,605   BA←BA,HBA-C   4   2     1   1   1     BA,H   CF,05   BA←BA,HIL+C   4   2     1   1   1     BA,IX   CF,06   BA←BA,HIL+C   4   2     1   1   1     BA,IX   CF,06   BA←BA,HIY+C   4   2     1   1   1     BA,IX   CF,06   BA,HIL+BA,HIL+BA,HIL+BA,HIL-BA   4   2     1   1   1     HL,BA   CF,24   HL,←HL,HBA,HC   4   2     1   1   1     HL,BA   CF,25   HL,←HL,HIL+C   4   2     1   1   1     HL,IX   CF,26   HL,←HL,HIX+C   4   2     1   1   1     HL,#mmnn   CF,61,nn,mm   HL,←HL,HIMMnhC   4   4   2     1   1   1     HL,#mmnn   CF,61,nn,mm   HL,←HL,HIMMnhC   4   4   2     1   1   1     BA,JH   CF,09   BA,←BA,HL   4   2     1   1   1     BA,JH   CF,08   BA,←BA,HL   4   2     1   1   1     BA,JH   CF,09   BA,←BA,HI   4   2     1   1   1     BA,JH   CF,09   BA,←BA,HI   4   2     1   1   1     BA,JH   CF,09   BA,←BA,HI   4   2     1   1   1     BA,JH   CF,08   BA,—BA,HI   4   2     1   1   1     BA,JH   CF,08   BA,—BA,HI   4   2     1   1   1     BA,JH   CF,09   BA,—BA,HI   4   2     1   1   1     B |      | IX,BA     | CF,40          | IX←IX+BA     | 4     | 2    | Ŀ        |   | _ | _ | _ | <b>‡</b> |   |          |          |          |         |
| IY,BA   CF,42   IY←IY+BA   4   2   ↑ ↑ ↑ ↑ ↑     IY,HL   CF,43   IY←IY+HL   4   2   ↑ ↑ ↑ ↑ ↑ ↑ ↑     IY,#mmnn   C3,nn,mm   IY←IY+mmn   3   3   3   ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      |           |                | IX←IX+HL     | 4     | 2    | _        |   | _ | - | _ | <b>‡</b> |   |          |          |          |         |
| IY,HL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | IX,#mmnn  | C2,nn,mm       | IX←IX+mmnn   | 3     | 3    | _        |   | _ | - | _ | <b>‡</b> |   |          |          |          |         |
| IY,#mmnn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      | IY,BA     | CF,42          | IY←IY+BA     | 4     | 2    | -        |   | _ | - | - | <b>‡</b> |   |          |          |          |         |
| SP,BA         CF,44         SP←SP+BA         4         2         ↑ ↑ ↑ ↑ ↑ ↑           SP,HL         CF,45         SP←SP+HL         4         2         ↑ ↑ ↑ ↑ ↑ ↑           SP,#mmnn         CF,68,nn,mm         SP←SP+mmnn         4         4         2         ↑ ↑ ↑ ↑ ↑ ↑           BA,BA         CF,04         BA←BA+BA+C         4         2         ↑ ↑ ↑ ↑ ↑ ↑           BA,HL         CF,05         BA←BA+HL+C         4         2         ↑ ↑ ↑ ↑ ↑           BA,IX         CF,06         BA←BA+HL+C         4         2         ↑ ↑ ↑ ↑ ↑           BA,IY         CF,06         BA←BA+HN+C         4         2         ↑ ↑ ↑ ↑ ↑           BA,#mmnn         CF,60,nn,mm         BA←BA+HNmnnh+C         4         4         2         ↑ ↑ ↑ ↑ ↑           HL,BA         CF,24         HL-HL+BA+C         4         2         ↑ ↑ ↑ ↑ ↑         ↑           HL,IX         CF,26         HL-HL+HL+IX+C         4         2         ↑ ↑ ↑ ↑ ↑         ↑           HL,IY         CF,27         HL-HL+HL+mmnn+C         4         4         2         ↑ ↑ ↑ ↑ ↑ ↑           HL,H         FF,61,nn,mm         HL-HL+HL+m                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | IY,HL     | CF,43          | IY←IY+HL     | 4     | 2    | _        |   | _ | - | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| SP,HL         CF,45         SP←SP+HL         4         2         0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | IY,#mmnn  | C3,nn,mm       | IY←IY+mmnn   | 3     | 3    | -        |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | \$       | <b>‡</b> |         |
| SP,#mmnn   CF,68,nn,mm   SP←SP+mmnn   4   4   4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      | SP,BA     | CF,44          | SP←SP+BA     | 4     | 2    | -        |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | \$       | <b>‡</b> |         |
| ADC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |      | SP,HL     | CF,45          | SP←SP+HL     | 4     | 2    | Ī –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,HL       CF,05       BA←BA+HL+C       4       2       -       -       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1       1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | SP,#mmnn  | CF,68,nn,mm    | SP←SP+mmnn   | 4     | 4    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,IX         CF,06         BA←BA+IX+C         4         2         -         -         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ADC  | BA,BA     | CF,04          | BA←BA+BA+C   | 4     | 2    | <u> </u> |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,IY       CF,07       BA←BA+IY+C       4       2       -       -       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | BA,HL     | CF,05          | BA←BA+HL+C   | 4     | 2    | Ī-       |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,#mmnn         CF,60,nn,mm         BA←BA+mmnn+C         4         4         -         -         ↑         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓         ↓ <td< td=""><td></td><td>BA,IX</td><td>CF,06</td><td>BA←BA+IX+C</td><td>4</td><td>2</td><td>-</td><td></td><td></td><td>_</td><td>_</td><td><b>‡</b></td><td>,</td><td><b>‡</b></td><td><b>‡</b></td><td><b>‡</b></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |      | BA,IX     | CF,06          | BA←BA+IX+C   | 4     | 2    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| HL,BA   CF,24                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      | BA,IY     | CF,07          | BA←BA+IY+C   | 4     | 2    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| HL,HL                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | BA,#mmnn  | CF,60,nn,mm    | BA←BA+mmnn+C | 4     | 4    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | HL,BA     | CF,24          | HL←HL+BA+C   | 4     | 2    | -        |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | HL,HL     | CF,25          | HL←HL+HL+C   | 4     | 2    | -        |   | _ | - | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| HL,#mmnn   CF,61,nn,mm   HL←HL+mmnn+C   4   4   4     ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      | HL,IX     | CF,26          | HL←HL+IX+C   | 4     | 2    | -        |   |   | - | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| SUB       BA,BA       CF,08       BA←BA-BA       4       2       ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑ ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |      | HL,IY     | CF,27          | HL←HL+IY+C   | 4     | 2    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,HL       CF,09       BA←BA-HL       4       2       -       -       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |      | HL,#mmnn  | CF,61,nn,mm    | HL←HL+mmnn+C | 4     | 4    | Ī-       |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| BA,IX       CF,0A       BA←BA-IX       4       2       -       -       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑       ↑                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | SUB  | BA,BA     | CF,08          | BA←BA-BA     | 4     | 2    | Ī-       |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | BA,HL     | CF,09          | BA←BA-HL     | 4     | 2    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | BA,IX     | CF,0A          | BA←BA-IX     | 4     | 2    | -        |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | BA,IY     | CF,0B          | BA←BA-IY     | 4     | 2    | -        |   | _ | - | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | BA,#mmnn  | D0,nn,mm       | BA←BA-mmnn   | 3     | 3    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | HL,BA     | CF,28          | HL←HL-BA     | 4     | 2    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | HL,HL     | CF,29          | HL←HL-HL     | 4     | 2    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | HL,IX     | CF,2A          | HL←HL-IX     | 4     | 2    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | HL,IY     | CF,2B          | HL←HL-IY     | 4     | 2    | -        |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | HL,#mmnn  | D1,nn,mm       | HL←HL-mmnn   | 3     | 3    | -        |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | IX,BA     | CF,48          | IX←IX-BA     | 4     | 2    | l –      |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | IX,HL     | CF,49          | IX←IX-HL     | 4     | 2    | Ī-       |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | IX,#mmnn  | D2,nn,mm       | IX←IX-mmnn   | 3     | 3    | <u> </u> |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      | IY,BA     | CF,4A          | IY←IY-BA     | 4     | 2    | <u> </u> |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | IY,HL     | CF,4B          | IY←IY-HL     | 4     | 2    | <u> </u> |   |   | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |      | IY,#mmnn  | D3,nn,mm       | IY←IY-mmnn   | 3     | 3    | <u> </u> |   | _ | _ | _ | <b>‡</b> | , | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| SP,HL CF,4D SP $\leftarrow$ SP-HL 4 2 $\uparrow$ $\uparrow$ $\uparrow$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |      |           |                |              | 4     | 2    | <u> </u> |   |   | _ | _ | <b></b>  |   |          |          | <b></b>  |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      |           |                |              | 4     | 2    | <u> </u> |   |   | _ | _ | <b></b>  |   |          |          | <b>‡</b> |         |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |      | SP,#mmnn  |                | SP←SP-mmnn   | 4     | 4    | <u> </u> |   |   | _ | _ | <b></b>  | , |          |          | <b>‡</b> |         |

# 16-bit Arithmetic Operation Instructions (2/2)

| Mr   | nemonic    | Machine Code | Operation    | Cycle | Byte |    |    |   | S | С        |          |          |          | Comment |
|------|------------|--------------|--------------|-------|------|----|----|---|---|----------|----------|----------|----------|---------|
| IVII | ICITIOTIIC | Machine Code | Орегация     | Cycle | Бую  | 11 | 10 | U | D | Ν        | ٧        | С        | Z        | Comment |
| SBC  | BA,BA      | CF,0C        | BA←BA-BA-C   | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,HL      | CF,0D        | BA←BA-HL-C   | 4     | 2    | ı  | _  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,IX      | CF,0E        | BA←BA-IX-C   | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,IY      | CF,0F        | BA←BA-IY-C   | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,#mmnn   | CF,62,nn,mm  | BA←BA-mmnn-C | 4     | 4    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,BA      | CF,2C        | HL←HL-BA-C   | 4     | 2    | -  | -  | - | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,HL      | CF,2D        | HL←HL-HL-C   | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,IX      | CF,2E        | HL←HL-IX-C   | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,IY      | CF,2F        | HL←HL-IY-C   | 4     | 2    | -  | -  | - | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,#mmnn   | CF,63,nn,mm  | HL←HL-mmnn-C | 4     | 4    | -  | -  | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| СР   | BA,BA      | CF,18        | BA-BA        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,HL      | CF,19        | BA-HL        | 4     | 2    | _  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,IX      | CF,1A        | BA-IX        | 4     | 2    | _  | _  | - | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,IY      | CF,1B        | BA-IY        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | BA,#mmnn   | D4,nn,mm     | BA-mmnn      | 3     | 3    | -  | -  | - | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,BA      | CF,38        | HL-BA        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,HL      | CF,39        | HL-HL        | 4     | 2    | _  | _  | - | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,IX      | CF,3A        | HL-IX        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,IY      | CF,3B        | HL-IY        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | HL,#mmnn   | D5,nn,mm     | HL-mmnn      | 3     | 3    | _  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | IX,#mmnn   | D6,nn,mm     | IX-mmnn      | 3     | 3    | -  | -  | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | IY,#mmnn   | D7,nn,mm     | IY-mmnn      | 3     | 3    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | SP,BA      | CF,5C        | SP-BA        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | SP,HL      | CF,5D        | SP-HL        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|      | SP,#mmnn   | CF,6C,nn,mm  | SP-mmnn      | 4     | 4    | -  | -  | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| INC  | ВА         | 90           | BA←BA+1      | 2     | 1    | -  | -  | - | - | -        | -        | -        | <b>‡</b> |         |
|      | HL         | 91           | HL←HL+1      | 2     | 1    | -  | -  | - | - | _        | -        | -        | <b>‡</b> |         |
|      | IX         | 92           | IX←IX+1      | 2     | 1    | _  | -  | - | - | _        | -        | _        | <b>‡</b> |         |
|      | ΙΥ         | 93           | IY←IY+1      | 2     | 1    | -  | -  | - | - | _        | -        | -        | <b>‡</b> |         |
|      | SP         | 87           | SP←SP+1      | 2     | 1    | -  | -  | - | - | -        | -        | -        | <b>‡</b> |         |
| DEC  | ВА         | 98           | BA←BA-1      | 2     | 1    | _  | -  | - | - | _        | -        | -        | <b>‡</b> |         |
|      | HL         | 99           | HL←HL-1      | 2     | 1    | _  | -  | - | _ | _        | -        | -        | <b>‡</b> |         |
|      | IX         | 9A           | IX←IX-1      | 2     | 1    | _  | -  | - | - | _        | -        | -        | <b>‡</b> |         |
|      | ΙΥ         | 9B           | IY←IY-1      | 2     | 1    | -  | -  | - | - | -        | -        | -        | <b>‡</b> |         |
|      | SP         | 8F           | SP←SP-1      | 2     | 1    | _  | -  | - | - | _        | -        | _        | <b>‡</b> |         |

# **Auxiliary Operation Instructions**

| Mn   | nemonic | Machine Code | Operation                                                                     | Cycle | Byte | 11 | 10 | U |   | C<br>N | V | С | Z | Comment |
|------|---------|--------------|-------------------------------------------------------------------------------|-------|------|----|----|---|---|--------|---|---|---|---------|
| PACK |         | DE           | B A A                                                                         | 2     | 1    | -  | -  | - | - | -      | - | - | - |         |
| UPCK |         | DF           | $ \begin{array}{ccc} A & B & A \\ \hline m & n & \hline \end{array} $         | 2     | 1    | -  | -  | - | - | -      | - | - | - |         |
| SEP  |         | CE,A8        | B A B A  [0*******]  → [0000000] [0******  [1*******]  → [1111111] [1*******] | 3     | 2    | _  | -  | _ | - | _      | - | _ | - |         |

# Rotate/Shift Instructions (1/2)

| Ŋ/I | nemonic          | Machine Code     | Operation                       | Cycle | Byte |    |    |   |   | С        |          |          |          | Comment |
|-----|------------------|------------------|---------------------------------|-------|------|----|----|---|---|----------|----------|----------|----------|---------|
|     |                  |                  | Орогалогі                       | Cycle | Dyte | 11 | 10 | U |   |          |          |          |          | Comment |
| RL  | A                | CE,90            | C ← 76543210 ← A                | 3     | 2    | -  | -  | - | - | \$       | -        | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,91            | C ← 76543210 ← B                | 3     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,92, <i>ll</i> | [BR: <i>ll</i> ]                | 5     | 3    | -  | -  | _ | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,93            | C - 76543210 - [HL]             | 4     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
| RLC | А                | CE,94            | C 4 76543210 4 A                | 3     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,95            | C 4 76543210 4<br>B             | 3     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,96, <i>ll</i> | C 4 76543210 4 [BR: <i>ll</i> ] | 5     | 3    | -  | -  | - | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,97            | C 4 76543210 4 [HL]             | 4     | 2    | -  | -  | _ | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
| RR  | А                | CE,98            | →76543210→C                     | 3     | 2    | 1  | _  | _ | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,99            | →76543210→C                     | 3     | 2    | 1  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,9A,ll         | →76543210→C<br>[BR: <i>ll</i> ] | 5     | 3    | -  | _  | _ | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,9B            | →76543210→C<br>[HL]             | 4     | 2    | -  | -  | _ | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
| RRC | А                | CE,9C            | →76543210 → C<br>A              | 3     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,9D            | 76543210 ►C<br>B                | 3     | 2    | -  | -  | _ | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,9E,ll         | 76543210 ►C<br>[BR://]          | 5     | 3    | -  | -  | _ | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,9F            | 76543210 → C<br>[HL]            | 4     | 2    | 1  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
| SLA | А                | CE,80            | C ← 76543210 ← 0<br>A           | 3     | 2    | -  | -  | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,81            | C ← 76543210 ← 0<br>B           | 3     | 2    | -  | -  | _ | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,82,ll         | C ← 76543210 ← 0<br>[BR://]     | 5     | 3    | -  | -  |   | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,83            | C ← 76543210 ← 0<br>[HL]        | 4     | 2    | -  | -  | - | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> |         |
| SLL | А                | CE,84            | C ← 76543210 ← 0<br>A           | 3     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | В                | CE,85            | C ← 76543210 ← 0<br>B           | 3     | 2    | -  | -  | _ | _ | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [BR: <i>ll</i> ] | CE,86,11         | C ← 76543210 ← 0<br>[BR://]     | 5     | 3    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |
|     | [HL]             | CE,87            | C ← 76543210 ← 0<br>[HL]        | 4     | 2    | -  | -  | - | - | <b>‡</b> | -        | <b>‡</b> | <b>‡</b> |         |

# Rotate/Shift Instructions (2/2)

| Mr  | nemonic | Machine Code | Operation                   | Cycle | Byte |    |    |   |   | SC       |   |          |          | Comment |
|-----|---------|--------------|-----------------------------|-------|------|----|----|---|---|----------|---|----------|----------|---------|
|     |         |              |                             | ľ     | ,    | 11 | 10 | U | D | Ν        | V | С        | Z        |         |
| SRA | А       | CE,88        | 76543210→C<br>A             | 3     | 2    | -  | -  | _ | - | \$       | 0 | <b>‡</b> | \$       |         |
|     | В       | CE,89        | 76543210→C<br>B             | 3     | 2    | -  | -  | - | - | <b>‡</b> | 0 | <b>‡</b> | \$       |         |
|     | [BR://] | CE,8A,ll     | 76543210→C<br>[BR://]       | 5     | 3    | -  | -  | - | - | \$       | 0 | <b>‡</b> | \$       |         |
|     | [HL]    | CE,8B        | 76543210→C<br>[HL]          | 4     | 2    | -  | -  | - | - | <b>‡</b> | 0 | <b>‡</b> | \$       |         |
| SRL | A       | CE,8C        | 0 → 76543210 → C<br>A       | 3     | 2    | -  | -  | - | - | 0        | - | <b>‡</b> | \$       |         |
|     | В       | CE,8D        | 0 → 76543210 → C<br>B       | 3     | 2    | -  | -  | _ | - | 0        | - | <b>‡</b> | \$       |         |
|     | [BR://] | CE,8E,ll     | 0 → 76543210 → C<br>[BR://] | 5     | 3    | -  | -  | - | - | 0        | - | <b>‡</b> | \$       |         |
|     | [HL]    | CE,8F        | 0 → 76543210 → C<br>[HL]    | 4     | 2    | ı  | -  | - | - | 0        | - | <b>‡</b> | <b>‡</b> |         |

# **Stack Control Instructions**

| Mn   | emonic     | Machine Code  | Operation                                                                | Cycle | Byte |          |          | SC SC II IO U D N V C Z |          |          | Comment  |          |    |               |
|------|------------|---------------|--------------------------------------------------------------------------|-------|------|----------|----------|-------------------------|----------|----------|----------|----------|----|---------------|
|      | .011101110 | Macrimic Gode | operation.                                                               | Cycle | Byte | 11       | 10       | U                       | D        | N        | ٧        | С        | Z  | Common        |
| PUSH | Α          | CF,B0         | [SP-1]←A, SP←SP-1                                                        | 3     | 2    | -        | -        | -                       | _        | _        | -        | _        | -  |               |
|      | В          | CF,B1         | [SP-1]←B, SP←SP-1                                                        | 3     | 2    | -        | -        | -                       | _        | -        | -        | _        | -  |               |
|      | L          | CF,B2         | [SP-1]←L, SP←SP-1                                                        | 3     | 2    | -        | -        | -                       | _        | _        | -        | -        | -  |               |
|      | Н          | CF,B3         | [SP-1]←H, SP←SP-1                                                        | 3     | 2    | -        | _        | -                       | _        | _        | -        | -        | -  |               |
|      | BR         | A4            | [SP-1]←BR, SP←SP-1                                                       | 3     | 1    | -        | -        | -                       | -        | _        | -        | -        | -  |               |
|      | SC         | A7            | [SP-1]←SC, SP←SP-1                                                       | 3     | 1    | -        | -        | -                       | _        | _        | -        | _        | -  |               |
|      | ВА         | A0            | $[SP-1]\leftarrow B, [SP-2]\leftarrow A, SP\leftarrow SP-2$              | 4     | 1    | -        | -        | -                       | _        | _        | -        | -        | -  |               |
|      | HL         | A1            | $[SP-1]\leftarrow H, [SP-2]\leftarrow L, SP\leftarrow SP-2$              | 4     | 1    | -        | _        | -                       | _        | _        | _        | _        | -  |               |
|      | IX         | A2            | $[SP-1] \leftarrow IX(H), [SP-2] \leftarrow IX(L), SP \leftarrow SP-2$   | 4     | 1    | -        | -        | -                       | _        | _        | -        | -        | -  |               |
|      | IY         | A3            | $[SP-1] \leftarrow IY(H), [SP-2] \leftarrow IY(L), SP \leftarrow SP-2$   | 4     | 1    | -        | _        | -                       | _        | _        | -        | -        | -  |               |
|      | EP         | A5            | [SP-1]←EP, SP←SP-1                                                       | 3     | 1    | -        | _        | -                       | _        | _        | _        | _        | -  |               |
|      | IP         | A6            | $[SP-1]\leftarrow XP, [SP-2]\leftarrow YP, SP\leftarrow SP-2$            | 4     | 1    | -        | -        | -                       | _        | _        | -        | -        | -  |               |
| PUSH | ALL        | CF,B8         | PUSH BA, HL, IX, IY, BR                                                  | 12    | 2    | -        | -        | -                       | _        | _        | -        | -        | -  |               |
|      | ALE        | CF,B9         | PUSH BA, HL, IX, IY, BR, EP, IP                                          | 15    | 2    | -        | _        | -                       | _        | _        | -        | -        | -  | MODEL2/3 only |
| POP  | Α          | CF,B4         | $A\leftarrow$ [SP], SP $\leftarrow$ SP+1                                 | 3     | 2    | -        | -        | -                       | _        | -        | -        | _        | -  |               |
|      | В          | CF,B5         | $B\leftarrow$ [SP], SP $\leftarrow$ SP+1                                 | 3     | 2    | -        | -        | -                       | _        | -        | -        | _        | -  |               |
|      | L          | CF,B6         | $L\leftarrow$ [SP], SP $\leftarrow$ SP+1                                 | 3     | 2    | -        | -        | -                       | _        | _        | -        | _        | -  |               |
|      | Н          | CF,B7         | H←[SP], SP←SP+1                                                          | 3     | 2    | -        | _        | -                       | _        | _        | _        | _        | -  |               |
|      | BR         | AC            | $BR\leftarrow$ [SP], SP $\leftarrow$ SP+1                                | 2     | 1    | -        | -        | -                       | _        | _        | -        | _        | -  |               |
|      | SC         | AF            | $SC\leftarrow [SP], SP\leftarrow SP+1$                                   | 2     | 1    | <b>‡</b> | <b>‡</b> | <b>‡</b>                | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | \$ |               |
|      | BA         | A8            | $A\leftarrow$ [SP], $B\leftarrow$ [SP+1], SP $\leftarrow$ SP+2           | 3     | 1    | -        | -        | -                       | -        | _        | -        | _        | -  |               |
|      | HL         | A9            | $L\leftarrow$ [SP], $H\leftarrow$ [SP+1], SP $\leftarrow$ SP+2           | 3     | 1    | ı        | -        | -                       | _        | -        | -        | _        | -  |               |
|      | IX         | AA            | $IX(L) \leftarrow [SP], \ IX(H) \leftarrow [SP+1], \ SP \leftarrow SP+2$ | 3     | 1    | -        | -        | -                       | _        | _        | -        | _        | -  |               |
|      | IY         | AB            | $IY(L) \leftarrow [SP],  IY(H) \leftarrow [SP+1],  SP \leftarrow SP+2$   | 3     | 1    | -        | -        | -                       | -        | _        | -        | _        | -  |               |
|      | EP         | AD            | $EP\leftarrow[SP], SP\leftarrow SP+1$                                    | 2     | 1    | -        | -        | -                       | -        | _        | -        | _        | -  |               |
|      | IP         | AE            | $YP\leftarrow$ [SP], $XP\leftarrow$ [SP+1], $SP\leftarrow$ SP+2          | 3     | 1    |          | =        | _                       | _        | _        | =        | Ξ        | _  |               |
| POP  | ALL        | CF,BC         | POP BR, IY, IX, HL, BA                                                   | 11    | 2    | _        | _        | _                       | _        | -        | _        | _        | _  |               |
|      | ALE        | CF,BD         | POP IP, EP, BR, IY, IX, HL, BA                                           | 14    | 2    | -        | _        | _                       | _        | _        | _        | -        | _  | MODEL2/3 only |

<sup>\*</sup> Expand page registers EP/XP/YP are set only for MODEL2/3. In MODEL0/1, instructions that access these registers cannot be used.

# **Branch Instructions (1/4)**

|     | Inemonic | Machine  | Condition                  | Operation                                                                                                                 | C1    | D-4- |    |    |   |   | SC |   |   |          |
|-----|----------|----------|----------------------------|---------------------------------------------------------------------------------------------------------------------------|-------|------|----|----|---|---|----|---|---|----------|
| IVI | memonic  | Code     | Condition                  | Operation                                                                                                                 | Cycle | Byte | 11 | 10 | U | С | N  | V | С | Z        |
| JRS | rr       | F1,rr    | Unconditionable            | MODELO/1 PC←PC+rr+1  MODEL2/3 PC←PC+rr+1, CB←NB                                                                           | 2     | 2    | _  | -  | _ | - |    | - | _ | -        |
| JRS | C,rr     | E4,rr    | C=1                        | MODELO/I  If Condition is true,                                                                                           | 2     | 2    | -  | _  | - | - |    | _ | _ | _        |
|     | NC,rr    | E5,rr    | C=0                        | then PC←PC+rr+1<br>else PC←PC+2                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | Z,rr     | E6,rr    | Z=1                        | MODEL2/3  If Condition is true,                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | NZ,rr    | E7,rr    | Z=0                        | then PC←PC+rr+1, CB←NB<br>else PC←PC+2, NB←CB                                                                             |       |      |    |    |   |   |    |   |   |          |
| JRS | LT,rr    | CE,E0,rr | [N∀V]=1                    |                                                                                                                           | 3     | 3    | -  | -  | - | - |    | - | - | -        |
|     | LE,rr    | CE,E1,rr | $Z \lor [N \forall V] = 1$ |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | GT,rr    | CE,E2,rr | $Z \lor [N \forall V] = 0$ | MODEL0/1                                                                                                                  |       |      |    |    |   |   |    |   |   |          |
|     | GE,rr    | CE,E3,rr | [N∀V]=0                    | If Condition is true,                                                                                                     |       |      |    |    |   |   |    |   |   |          |
|     | V,rr     | CE,E4,rr | V=1                        | then PC←PC+rr+2                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | NV,rr    | CE,E5,rr | V=0                        | else PC←PC+3                                                                                                              |       |      |    |    |   |   |    |   |   |          |
|     | P,rr     | CE,E6,rr | N=0                        |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | M,rr     | CE,E7,rr | N=1                        |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | F0,rr    | CE,E8,rr | F0=1                       |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | F1,rr    | CE,E9,rr | F1=1                       |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | F2,rr    | CE,EA,rr | F2=1                       | MODEL2/3                                                                                                                  |       |      |    |    |   |   |    |   |   |          |
|     | F3,rr    |          | F3=1                       | If Condition is true,                                                                                                     |       |      |    |    |   |   |    |   |   |          |
|     | NF0,rr   |          | F0=0                       | then PC←PC+rr+2, CB←NB                                                                                                    |       |      |    |    |   |   |    |   |   |          |
|     | NF1,rr   | _        | F1=0                       | else PC←PC+3, NB←CB                                                                                                       |       |      |    |    |   |   |    |   |   |          |
|     | NF2,rr   | CE,EE,rr | F2=0                       |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | NF3,rr   | CE,EF,rr | F3=0                       |                                                                                                                           |       |      |    |    |   |   |    |   |   |          |
| JRL | qqrr     | F3,rr,qq | Unconditionable            | MODEL0/1 PC←PC+qqrr+2                                                                                                     | 3     | 3    | -  | -  | - | - |    | - | - | _        |
|     |          |          |                            | MODEL2/3 PC←PC+qqrr+2, CB←NB                                                                                              | -     |      |    |    |   |   |    |   |   |          |
| JRL | C,qqrr   | EC,rr,qq | C=1                        | MODELO/1 If Condition is true,                                                                                            | 3     | 3    | -  | -  | - | - |    | - | - | -        |
|     | NC,qqrr  | ED,rr,qq | C=0                        | then PC←PC+qqrr+2<br>else PC←PC+3                                                                                         |       |      |    |    |   |   |    |   |   |          |
|     | Z,qqrr   | EE,rr,qq | Z=1                        | MODEL2/3  If Condition is true,                                                                                           |       |      |    |    |   |   |    |   |   |          |
|     | NZ,qqrr  | EF,rr,qq | Z=0                        | then PC←PC+qqrr+2, CB←NB<br>else PC←PC+3, NB←CB                                                                           |       |      |    |    |   |   |    |   |   |          |
| DJR | NZ,rr    | F5,rr    | B=0                        | MODELO/I B←B-1, If B=0, then PC←PC+rr+1 else PC←PC+2 $MODEL2/3$ B←B-1, If B=0, then PC←PC+rr+1, CB←NB else PC←PC+2, NB←CB | 4     | 2    |    | _  | _ |   |    | _ | _ | <b>‡</b> |

# **Branch Instructions (2/4)**

| Mr   | nemonic | Machine  | Condition       | Operation                                                             | Cycle | Byte |              |    |   | SC |    |   |     |          |
|------|---------|----------|-----------------|-----------------------------------------------------------------------|-------|------|--------------|----|---|----|----|---|-----|----------|
|      |         | Code     | Condition       | operation.                                                            | _     | Byte | 11           | 10 | U | D  | ν, | V | C Z | <u>-</u> |
| JP   | HL      | F4       | Unconditionable | MODEL0/1 PC←HL                                                        | 2     | 1    | -            | -  | _ | -  |    | - |     | -        |
|      | Data1   | ED I-I-  | TT              | MODEL2/3 PC←HL, CB←NB                                                 | 4     | 2    |              |    |   |    |    |   |     | _        |
|      | [kk]    | FD,kk    | Unconditionable | MODEL0/1 PC(L) $\leftarrow$ [00kk],<br>PC(H) $\leftarrow$ [00kk+1]    | 4     | 2    | -            | _  | _ | _  |    | _ |     | -        |
|      |         |          |                 | $PC(H) \leftarrow [00kk+1]$ $MODEL2/3 \ PC(L) \leftarrow [00kk]$      |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | $PC(H) \leftarrow [00kk+1], CB \leftarrow NB$                         |       |      |              |    |   |    |    |   |     |          |
| CARS | rr      | F0,rr    | Unconditionable |                                                                       | 4     | 2    | <del> </del> | _  |   | _  |    |   |     | _        |
| 0,   | ["      | 1 0,11   |                 | $[SP-1]\leftarrow PC(H), [SP-2]\leftarrow PC(L),$                     | ·     | ~    |              |    |   |    |    |   |     |          |
|      |         |          |                 | $SP \leftarrow SP-2, PC \leftarrow PC+rr+1$                           |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | MODEL2/3 (Minimum mode)                                               |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | [SP-1]←PC(H), [SP-2]←PC(L),                                           |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | SP←SP-2, PC←PC+rr+1, CB←NB                                            |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | MODEL2/3 (Maximum mode)                                               | 5     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | [SP-1]←CB, [SP-2]←PC(H),                                              |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | [SP-3]←PC(L), SP←SP-3,                                                |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | PC←PC+rr+1, CB←NB                                                     |       |      |              |    |   |    |    |   |     |          |
| CARS | C,rr    | E0,rr    | C=1             | MODEL0/1                                                              |       | 2    | -            | -  | _ | -  |    | - |     | -        |
|      |         |          |                 | If Condition is true                                                  |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | then $[SP-1] \leftarrow PC(H)$ , $[SP-2] \leftarrow PC(L)$ ,          | 4     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | SP←SP-2, PC←PC+rr+1                                                   |       |      |              |    |   |    |    |   |     |          |
|      | NC,rr   | E1,rr    | C=0             | else PC←PC+2                                                          | 2     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | MODEL2/3 (Minimum mode)  If Condition is true                         |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | then [SP-1] $\leftarrow$ PC(H), [SP-2] $\leftarrow$ PC(L),            | 4     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | $SP \leftarrow SP-2, PC \leftarrow PC+rr+1,$                          | 7     |      |              |    |   |    |    |   |     |          |
|      | Z,rr    | E2,rr    | Z=1             | CB←NB                                                                 |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | else PC←PC+2, NB←CB                                                   | 2     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | MODEL2/3 (Maximum mode)                                               |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | If Condition is true                                                  |       |      |              |    |   |    |    |   |     |          |
|      | NZ,rr   | E3,rr    | Z=0             | then [SP-1] $\leftarrow$ CB, [SP-2] $\leftarrow$ PC(H),               | 5     |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | [SP-3]←PC(L), SP←SP-3,                                                |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | PC←PC+rr+1, CB←NB                                                     |       |      |              |    |   |    |    |   |     |          |
|      |         |          |                 | 」 else PC←PC+2, NB←CB                                                 | 2     |      |              |    |   |    |    |   |     |          |
| CARS | LT,rr   | CE,F0,rr | [N∀V]=1         | MODEL0/1                                                              |       | 3    | l –          | -  | - | -  |    | _ |     | -        |
|      | LE,rr   | CE,F1,rr | Z∨[N∀V]=1       | If Condition is true                                                  | _     |      |              |    |   |    |    |   |     |          |
|      | GT,rr   | CE,F2,rr | Z∨[N∀V]=0       | then $[SP-1] \leftarrow PC(H)$ , $[SP-2] \leftarrow PC(L)$ ,          | 5     |      |              |    |   |    |    |   |     |          |
|      | GE,rr   | CE,F3,rr | [N∀V]=0         | $SP \leftarrow SP-2, PC \leftarrow PC+rr+2$ else $PC \leftarrow PC+3$ | 3     |      |              |    |   |    |    |   |     |          |
|      | V,rr    | CE,F4,rr | V=1             | MODEL2/3 (Minimum mode)                                               | 3     |      |              |    |   |    |    |   |     |          |
|      | NV,rr   | CE,F5,rr | V=0             | If Condition is true                                                  |       |      |              |    |   |    |    |   |     |          |
|      | P,rr    | CE,F6,rr | N=0             | then $[SP-1] \leftarrow PC(H)$ , $[SP-2] \leftarrow PC(L)$ ,          | 5     |      |              |    |   |    |    |   |     |          |
|      | M,rr    | CE,F7,rr | N=1             | SP←SP-2, PC←PC+rr+2,                                                  |       |      |              |    |   |    |    |   |     |          |
|      | F0,rr   | CE,F8,rr | F0=1            | CB←NB                                                                 |       |      |              |    |   |    |    |   |     |          |
|      | F1,rr   | CE,F9,rr | F1=1            | else PC←PC+3, NB←CB                                                   | 3     |      |              |    |   |    |    |   |     |          |
|      | F2,rr   | CE,FA,rr | F2=1            | MODEL2/3 (Maximum mode)                                               |       |      |              |    |   |    |    |   |     |          |
|      | F3,rr   | CE,FB,rr | F3=1            | If Condition is true                                                  |       |      |              |    |   |    |    |   |     |          |
|      | NF0,rr  | CE,FC,rr | F0=0            | then [SP-1] $\leftarrow$ CB, [SP-2] $\leftarrow$ PC(H),               | 6     |      |              |    |   |    |    |   |     |          |
|      | NF1,rr  | CE,FD,rr | F1=0            | [SP-3]←PC(L), SP←SP-3,                                                |       |      |              |    |   |    |    |   |     |          |
|      | NF2,rr  | CE,FE,rr | F2=0            | PC←PC+rr+2, CB←NB                                                     |       |      |              |    |   |    |    |   |     |          |
|      | NF3,rr  | CE,FF,rr | F3=0            | delse PC←PC+3, NB←CB                                                  | 3     |      |              |    |   |    |    |   |     |          |

# **Branch Instructions (3/4)**

| Mn   | nemonic   | Machine  | Condition       | Operation                                                                                                                                                                                                                                                                                                           | Cycle | Byte |    |    |   | S |   |   |   |   |
|------|-----------|----------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|------|----|----|---|---|---|---|---|---|
|      | icinionio | Code     | Condition       | Ороганоп                                                                                                                                                                                                                                                                                                            | Cycle | Byte | 11 | 10 | U | D | Ν | ٧ | С | Z |
| CARL | qqrr      | F2,rr,qq | Unconditionable | MODELO/I [SP-1]←PC(H), [SP-2]←PC(L), SP←SP-2, PC←PC+qqrr+2 $MODEL2/3$ (Minimum mode) [SP-1]←PC(H), [SP-2]←PC(L), SP←SP-2, PC←PC+qqrr+2, CB←NB                                                                                                                                                                       | 5     | 3    |    |    |   | _ | _ |   | _ | _ |
|      |           |          |                 | MODEL2/3 (Maximum mode)  [SP-1]←CB, [SP-2]←PC(H),  [SP-3]←PC(L), SP←SP-3,  PC←PC+qqrr+2, CB←NB                                                                                                                                                                                                                      | 6     |      |    |    |   |   |   |   |   |   |
| CARL | C,qqrr    | E8,rr,qq | C=1             |                                                                                                                                                                                                                                                                                                                     | 5     | 3    | _  | -  | - | - | - | - | - | - |
|      | NC,qqrr   | E9,rr,qq | C=0             | else PC←PC+3  MODEL2/3 (Minimum mode)  If Condition is true then [SP-1]←PC(H), [SP-2]←PC(L), SP←SP-2, PC←PC+qqrr+2,                                                                                                                                                                                                 | 5     |      |    |    |   |   |   |   |   |   |
|      | Z,qqrr    | EA,rr,qq | Z=1             | CB←NB else PC←PC+3, NB←CB  MODEL2/3 (Maximum mode)  If Condition is true                                                                                                                                                                                                                                            | 3     |      |    |    |   |   |   |   |   |   |
|      | NZ,qqrr   | EB,rr,qq | Z=0             | then [SP-1] $\leftarrow$ CB, [SP-2] $\leftarrow$ PC(H), [SP-3] $\leftarrow$ PC(L), SP $\leftarrow$ SP-3, PC $\leftarrow$ PC+qqrr+2, CB $\leftarrow$ NB else PC $\leftarrow$ PC+3, NB $\leftarrow$ CB                                                                                                                | 6     |      |    |    |   |   |   |   |   |   |
| CALL | [hh/l/]   | FB,ll,hh | Unconditionable | MODELO/I [SP-1]←PC(H), [SP-2]←PC(L), SP←SP-2, PC(L)←[hh $ll$ ], PC(H)←[hh $ll$ +1] $MODEL2/3$ (Minimum mode) [SP-1]←PC(H), [SP-2]←PC(L), SP←SP-2, PC(L)←[hh $ll$ ], PC(H)←[hh $ll$ +1], CB←NB $MODEL2/3$ (Maximum mode) [SP-1]←CB, [SP-2]←PC(H), [SP-3]←PC(L), SP←SP-3, PC(L)←[hh $ll$ ], PC(H)←[hh $ll$ +1], CB←NB | 8     | 3    | _  | -  | - |   | _ | - |   | _ |

# **Branch Instructions (4/4)**

| N A. | nemonic | Machine Code | Operation                                                                                                                                                                                                                                                                                                                                                                                                                    | Cvolo  | Byte |          |         |         | _       | С       |         |         |         | Comment |
|------|---------|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------|----------|---------|---------|---------|---------|---------|---------|---------|---------|
| IVII | nemonic | Machine Code | Operation                                                                                                                                                                                                                                                                                                                                                                                                                    | Сусіє  | Буце | 11       | 10      | U       | D       | Ν       | ٧       | С       | Z       | Comment |
| INT  | [kk]    | FC,kk        | $\label{eq:modelo} \begin{split} &\textit{MODELO/1} \\ &[SP-1] \leftarrow PC(H), [SP-2] \leftarrow PC(L), \\ &[SP-3] \leftarrow SC, SP \leftarrow SP-3, \\ &PC(L) \leftarrow [00kk], PC(H) \leftarrow [00kk+1] \\ &\textit{MODEL2/3 (Minimum mode)} \\ &[SP-1] \leftarrow PC(H), [SP-2] \leftarrow PC(L), \\ &[SP-3] \leftarrow SC, SP \leftarrow SP-3, \\ &PC(L) \leftarrow [00kk], PC(H) \leftarrow [00kk+1], \end{split}$ | 7      | 2    | -        | _       | _       | _       | _       | _       | _       | -       |         |
|      |         |              | CB $\leftarrow$ NB  MODEL2/3 (Maximum mode)  [SP-1] $\leftarrow$ CB, [SP-2] $\leftarrow$ PC(H),  [SP-3] $\leftarrow$ PC(L), [SP-4] $\leftarrow$ SC,  SP $\leftarrow$ SP-4, PC(L) $\leftarrow$ [00kk],  PC(H) $\leftarrow$ [00kk+1], CB $\leftarrow$ NB                                                                                                                                                                       | 8      |      |          |         |         |         |         |         |         |         |         |
| RET  |         | F8           | $\begin{split} &\textit{MODEL0/1, MODEL2/3 (Minimum mode)} \\ &\textit{PC(L)} \leftarrow [SP],  \textit{PC(H)} \leftarrow [SP+1], \\ &\textit{SP} \leftarrow SP+2 \\ &\textit{MODEL2/3 (Maximum mode)} \\ &\textit{PC(L)} \leftarrow [SP],  \textit{PC(H)} \leftarrow [SP+1], \end{split}$                                                                                                                                   | 3      | 1    | _        | -       | -       | -       | _       | _       | -       | -       |         |
| RETE |         | F9           | $CB\leftarrow[SP+2], NB\leftarrow CB, SP\leftarrow SP+3$ $MODEL0/1, MODEL2/3 (Minimum mode)$ $SC\leftarrow[SP], PC(L)\leftarrow[SP+1],$ $PC(H)\leftarrow[SP+2], SP\leftarrow SP+3$                                                                                                                                                                                                                                           |        | 1    | <b>‡</b> | <b></b> |         |
|      |         |              | $\label{eq:model2} \begin{split} &\textit{MODEL2/3 (Maximum mode)} \\ &\textit{SC} \leftarrow [SP], \textit{PC}(\texttt{L}) \leftarrow [SP+1], \\ &\textit{PC}(\texttt{H}) \leftarrow [SP+2], \textit{CB} \leftarrow [SP+3], \\ &\textit{NB} \leftarrow \textit{CB}, \textit{SP} \leftarrow \textit{SP} + 4 \end{split}$                                                                                                     | 5      |      |          |         |         |         |         |         |         |         |         |
| RETS |         | FA           | $\begin{tabular}{ll} MODEL0/1, MODEL2/3 (Minimum mode) \\ PC(L) \leftarrow [SP], PC(H) \leftarrow [SP+1], \\ SP \leftarrow SP+2, PC \leftarrow PC+2 \\ MODEL2/3 (Maximum mode) \\ \end{tabular}$                                                                                                                                                                                                                             | 5<br>6 | 1    | _        | _       | _       | -       | _       | _       | _       | _       |         |
|      |         |              | $PC(L) \leftarrow [SP], PC(H) \leftarrow [SP+1],$ $CB \leftarrow [SP+2], NB \leftarrow CB, SP \leftarrow SP+3,$ $PC \leftarrow PC+2$                                                                                                                                                                                                                                                                                         |        |      |          |         |         |         |         |         |         |         |         |

# **System Control Instructions**

| Mn    | emonic    | Machine Code   | Operation    | Cycle | Ryte |    |    |   | S | С |   |   |   | Comment |
|-------|-----------|----------------|--------------|-------|------|----|----|---|---|---|---|---|---|---------|
| 10111 | CITIOTIIC | Wacriirie Gode | Operation    | Cycle |      | 11 | 10 | U | D | Ν | V | С | Z | Comment |
| NOP   |           | FF             | No Operation | 2     | 1    | _  | -  | - | - | - | - | - | 1 |         |
| HALT  |           | CE,AE          | HALT         | 3     | 2    | -  | -  | - | _ | - | - | - | _ |         |
| SLP   |           | CE,AF          | SLEEP        | 3     | 2    | ı  | -  | - | _ | - | - | - | _ |         |

# Appendix C Programming Notes

# System Controller and Bus Control

- (1) All the interrupts including \$\overline{NMI}\$ are masked, until you write the optional value into both the "00FF00H" and "00FF01H" addresses. Consequently, even if you do not change the content of this address (You use the initial value, as is.), you should still be sure to perform the writing operation using the initialization routine.
- (2) When setting stack fields, including page addresses as well, you should write them in the order of the register SPP ("00FF01H") and the stack pointer SP.

Example: When setting the "178000H" address

LD EP, #00H

LD HL, #0FF01H

LD [HL], #17H

LD SP, #8000H

During this period the interrupts (including NMI) are masked.

# Watchdog Timer

The watchdog timer must reset within 3-second cycles by software.

# Oscillation Circuit and Operating Mode

- (1) When the high speed CPU operation is not necessary, you should operate the peripheral circuits according to the setting outline indicate below.
  - CPU operating clock
    OSC1
  - OSC3 oscillation circuit

OFF (When the OSC3 clock is not necessary for some peripheral circuits.)

- (2) Since 1 msec is necessary for the oscillation to stabilize after turning the OSC3 oscillation circuit ON. Consequently, you should switch the CPU operating clock (OSC1 → OSC3) after allowing for a sufficient waiting time once the OSC3 oscillation goes ON.
- (3) When switching the clock from OSC3 to OSC1, be sure to switch OSC3 oscillation OFF with separate instructions. Using a single instruction to process simultaneously can cause a malfunction of the CPU.

# Input Ports (K Ports)

When changing the input terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an input port. In particular, special attention should be paid to key scan for key matrix formation. Make this wait time the amount of time or more calculated by the following expression.

Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

RIN: Pull up resistance Max. value CIN: Terminal capacitance Max. value

# Output Ports (R Ports)

- (1) Since the special output signals (CL, FR, TOUT, FOUT and BZ) are generated asynchronously from the output control registers (LCCLK, LCFRM, PTOUT, FOUTON, BZON, BZSHT and BZSTP), when the signals is turned ON or OFF by the output control register settings, a hazard of a 1/2 cycle or less is generated.
- (2) When the FOUT frequency is made "fosc3/n", you must turn on the OSC3 oscillation circuit before outputting FOUT. A time interval of 1 msec, from the turning ON of the OSC3 oscillation circuit to until the oscillation stabilizes, is necessary, due to the oscillation element that is used. Consequently, if an abnormality occurs as the result of an unstable FOUT signal being output externally, you should allow an adequate waiting time after turning ON of the OSC3 oscillation, before turning outputting FOUT.

At initial reset, OSC3 oscillation circuit is set to OFF state.

(3) The SLP instruction has executed when the special output signals (TOUT, FOUT and BZ) are in the enable status, an unstable clock is output for the special output at the time of return from the SLEEP state. Consequently, when shifting to the SLEEP state, you should set the special output signal to the disable status prior to executing the SLP instruction.

## I/O Ports (P Ports)

(1) When changing the port terminal from LOW level to HIGH with the built-in pull-up resistor, a delay in the waveform rise time will occur depending on the time constant of the pull-up resistor and the load capacitance of the terminal. It is necessary to set an appropriate wait time for introduction of an I/O port. Make this wait time the amount of time or more calculated by the following expression.

Wait time = RIN x (CIN + load capacitance on the board) x 1.6 [sec]

RIN: Pull up resistance Max. value CIN: Terminal capacitance Max. value

(2) When the analog comparator is used, "0" must always be set for the I/O control registers (IOC14–IOC15 or IOC16–IOC17, or both) of I/O ports which will become input terminals.

# Serial Interface

- Be sure to initialize the serial interface mode in the transmitting/receiving disable status (TXEN = RXEN = "0").
- (2) Do not perform double trigger (writing "1") to TXTRG (RXTRG) when the serial interface is in the transmitting (receiving) operation. Furthermore, do not execute the SLP instruction. (When executing the SLP instruction, set TXEN = RXEN = "0".)
- (3) In the clock synchronous mode, since one clock line (SCLK) is shared for both transmitting and receiving, transmitting and receiving cannot be performed simultaneously. (Half duplex only is possible in clock synchronous mode.) Consequently, be sure not to write "1" to RXTRG (TXTRG) when TXTRG (RXTRG) is "1".
- (4) When a parity error or flaming error is generated during receiving in the asynchronous mode, the receiving error interrupt factor flag FSERR is set to "1" prior to the receiving complete interrupt factor flag FSREC for the time indicated in Table C.1. Consequently, when an error is generated, you should reset the receiving complete interrupt factor flag FSREC to "0" by providing a wait time in error processing routines and similar routines.

  When an overrun error is generated, the receiving complete interrupt factor flag FSREC is not set to "1" and a receiving complete interrupt is not generated.

Table C.1 Time difference between FSERR and FSREC on error generation

| Clock source       | Time difference              |
|--------------------|------------------------------|
| fosc3 / n          | 1/2 cycles of fosc3 / n      |
| Programmable timer | 1 cycle of timer 1 underflow |

### Clock Timer

(1) The clock timer is actually made to RUN/STOP in synchronization with the falling edge of the 256 Hz signal after writing to the TMRUN register. Consequently, when "0" is written to the TMRUN, the timer shifts to STOP status when the counter is incremented "1". The TMRUN maintains "1" for reading until the timer actually shifts to STOP status. Figure C.1 shows the timing chart of the RUN/STOP control.



Fig. C.1 Timing chart of RUN/STOP control

(2) The SLP instruction is executed when the clock timer is in the RUN status (TMRUN = "1"). The clock timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (TMRUN = "0") prior to executing the SLP instruction.

# Stopwatch Timer

(1) The stopwatch timer is actually made to RUN/STOP in synchronization with the falling edge of the 256 Hz signal after writing to the SWRUN register. Consequently, when "0" is written to the SWRUN, the timer shifts to STOP status when the counter is incremented "1". The SWRUN maintains "1" for reading until the timer actually shifts to STOP status. Figure C.2 shows the timing chart of the RUN/STOP control.



Fig. C.2 Timing chart of RUN/STOP control

(2) The SLP instruction is executed when the stopwatch timer is in the RUN status (SWRUN = "1"). The stopwatch timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (SWRUN = "0") prior to executing the SLP instruction.

# Programmable Timer

(1) The programmable timer is actually made to RUN/STOP in synchronization with the falling edge of the input clock after writing to the PRUN0(1) register. Consequently, when "0" is written to the PRUN0(1), the timer shifts to STOP status when the counter is decremented "1". The PRUN0(1) maintains "1" for reading until the timer actually shifts to STOP status. Figure C.3 shows the timing chart of the RUN/STOP control.



Fig. C.3 Timing chart of RUN/STOP control

The event counter mode is excluded from the above note.

- (2) The SLP instruction is executed when the programmable timer is in the RUN status (PRUN0(1) = "1"). The programmable timer operation will become unstable when returning from SLEEP status. Therefore, when shifting to SLEEP status, set the clock timer to STOP status (PRUN0(1) = "0") prior to executing the SLP instruction.
  - In the same way, disable the TOUT signal (PTOUT = "0") to avoid an unstable clock output to the R27 output port terminal.
- (3) Since the TOUT signal is generated asynchronously from the register PTOUT, when the signal is turned ON or OFF by the register setting, a hazard of a 1/2 cycle or less is generated.

- (4) When the OSC3 oscillation circuit is made the clock source, it is necessary to turn the OSC3 oscillation ON, prior to using the programmable timer.
  - From the time the OSC3 oscillation circuit is turning ON until oscillation stabilizes, an interval of 1 msec is necessary. Consequently, you should allow an adequate waiting time after turning the OSC3 oscillation circuit ON before starting the count of the programmable timer.
  - At initial reset, OSC3 oscillation circuit is set to OFF status.
- (5) When the 16-bit mode has been selected, be sure to read the counter data in the order of PTD00– PTD07 and PTD10–PTD17. Moreover, the time interval between reading PTD00–PTD07 and PTD10–PTD17 should be 0.73 msec/0.62 msec\*1 or less.

| fosc1      | *1        |
|------------|-----------|
| 32.768 kHz | 0.73 msec |
| 38.4 kHz   |           |
| 76.8 kHz   | 0.62      |
| 96.0 kHz   | 0.62 msec |
| 153.6 kHz  |           |

## LCD Controller

- (1) Since the CL and FR signals are generated asynchronously from the output control registers LCCLK and LCFRM, when the signals is turned ON or OFF by setting of the registers LCCLK and LCFRM, a hazard of a 1/2 cycle or less is generated.
- (2) When the SLP instruction is executed, display control registers LCDC0 and LCDC1 are automatically reset to "0" by hardware. Furthermore, in the SLEEP status, HIGH (VDD) level is output for the CL and FR signals. (When registers R25D and R26D are set to "1".)

### Sound Generator

(1) Since the BZ signal is generated asynchronously from the register BZON, when the signal is turned ON or OFF by the register setting, a hazard of a 1/2 cycle or less is generated.

- (2) The SLP instruction has executed when the BZ signal is in the enable status (BZON = "1" or BZSHT = "1"), an unstable clock is output from the R50 output port terminal at the time of return from the SLEEP status. Consequently, when shifting to the SLEEP status, you should set the BZ signal to the disable status (BZON = BZSHT = "0") prior to executing the SLP instruction.
- (3) The one-shot output is only valid when the normal buzzer output is OFF (BZON = "0") status. The trigger is invalid during ON (BZON = "1") status.

## **Analog Comparator**

- (1) To reduce current consumption, turn the analog comparator OFF (CMP0ON = CMP1ON = "0") when it is not necessary.
- (2) After the analog comparator has been turned ON, a maximum time of 3 msec is necessary until output stabilizes. Consequently, you should allow an adequate waiting time after turning the analog comparator ON, before reading the comparison result.
- (3) Since the input terminals of the analog comparator are common to the I/O ports, the I/O control registers (IOC14–IOC17) corresponding to the channel to be used must be set to the input mode.

# SVD (Supply Voltage Detection) Circuit

- (1) To reduce current consumption, turn the SVD circuit OFF (SVDON = SVDSP = "0") when it is not necessary.
- (2) When executing an SLP instruction while the SVD circuit is operating, the stop operation of the OSC1 oscillation circuit is kept waiting until the sampling is completed. The two bits of SVDON and SVDSP are automatically reset to "0" by hardware while waiting for completion of sampling.

# Interrupt (Exception) Processing

- (1) When executing the RETE instruction without resetting the interrupt factor flag after an interrupt has been generated, the same interrupt will be generated. Consequently, the interrupt factor flag corresponding to that routine must be reset (writing "1") in the interrupt processing routine.
- (2) Beware. If the interrupt flags (I0 and I1) have been rewritten (set to lower priority) prior to resetting an interrupt factor flag after an interrupt has been generated, the same interrupt will be generated again.
- (3) An exception processing vector is fixed at 2 bytes, so it cannot specify a branch destination bank address. Consequently, to branch from multiple banks to a common exception processing routine, the front portion of an exception processing routine must be described within the common area (000000H–007FFFH).

#### **EPSON International Sales Operations**

## **AMERICA**

## S-MOS SYSTEMS, INC.

150 River Oaks Parkway San Jose, CA 95134, U.S.A.

Phone: +1-408-922-0200 Fax: +1-408-922-0238

Telex: 176079 SMOS SNJUD

#### S-MOS SYSTEMS, INC.

## EASTERN AREA SALES AND TECHNOLOGY CENTER

301 Edgewater Place, Suite 120 Wakefield, MA 01880, U.S.A.

Phone: +1-617-246-3600 Fax: +1-617-246-5443

#### S-MOS SYSTEMS, INC.

#### SOUTH EASTERN AREA SALES AND TECHNOLOGY CENTER

4300 Six Forks Road, Suite 430 Raleigh, NC 27609, U.S.A.

Phone: +1-919-781-7667 Fax: +1-919-781-6778

#### S-MOS SYSTEMS, INC.

### **CENTRAL AREA SALES AND TECHNOLOGY CENTER**

1450 E.American Lane, Suite 1550 Schaumburg, IL 60173, U.S.A.

Phone: +1-847-517-7667 Fax: +1-847-517-7601

### **EUROPE**

#### - HEADQUARTERS -

#### **EPSON EUROPE ELECTRONICS GmbH**

Riesstrasse 15

80992 Muenchen, GERMANY

Phone: +49-(0)89-14005-0 Fax: +49-(0)89-14005-110

### - GERMANY -

### **EPSON EUROPE ELECTRONICS GmbH** SALES OFFICE

Breidenbachstrasse 46

D-51373 Leverkusen, GERMANY

Phone: +49-(0)214-83070-0 Fax: +49-(0)214-83070-10

#### - UNITED KINGDOM -

## **EPSON EUROPE ELECTRONICS GmbH UK BRANCH OFFICE**

G6 Doncastle House, Doncastle Road Bracknell, Berkshire RG12 8PE, ENGLAND

Phone: +44-(0)1344-381700 Fax: +44-(0)1344-381701

## - FRANCE -

### **EPSON EUROPE ELECTRONICS GmbH** FRENCH BRANCH OFFICE

1 Avenue de l' Atlantique, LP 915 Les Conquerants Z.A. de Courtaboeuf 2, F-91976 Les Ulis Cedex, FRANCE Phone: +33-(0)1-64862350 Fax: +33-(0)1-64862355

## **ASIA**

### - HONG KONG, CHINA -

#### EPSON HONG KONG LTD.

20/F., Harbour Centre, 25 Harbour Road

Wanchai, HONG KONG

Phone: +852-2585-4600 Fax: +852-2827-4346

Telex: 65542 EPSCO HX

#### - CHINA -

#### SHANGHAI EPSON ELECTRONICS CO., LTD.

4F, Bldg., 27, No. 69, Gui Jing Road

Caohejing, Shanghai, CHINA

Phone: 21-6485-5552 Fax: 21-6485-0775

#### - TAIWAN, R.O.C. -

### **EPSON TAIWAN TECHNOLOGY & TRADING LTD.**

10F, No. 287, Nanking East Road, Sec. 3

Taipei, TAIWAN, R.O.C.

Phone: 02-2717-7360 Fax: 02-2712-9164

Telex: 24444 EPSONTB

## **EPSON TAIWAN TECHNOLOGY & TRADING LTD. HSINCHU OFFICE**

13F-3, No. 295, Kuang-Fu Road, Sec. 2 HsinChu 300, TAIWAN, R.O.C.

Phone: 03-573-9900 Fax: 03-573-9169

### - SINGAPORE -

### **EPSON SINGAPORE PTE., LTD.**

No. 1 Temasek Avenue, #36-00 Millenia Tower, SINGAPORE 039192

Phone: +65-337-7911 Fax: +65-334-2716

### - KOREA -

### **SEIKO EPSON CORPORATION KOREA OFFICE**

10F, KLI 63 Bldg., 60 Yoido-Dong Youngdeungpo-Ku, Seoul, 150-010, KOREA

Phone: 02-784-6027 Fax: 02-767-3677

#### - JAPAN -

#### **SEIKO EPSON CORPORATION ELECTRONIC DEVICES MARKETING DIVISION**

### **Electronic Device Marketing Department** IC Marketing & Engineering Group

421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN

Phone: +81-(0)42-587-5816 Fax: +81-(0)42-587-5624

### **ED International Marketing Department I** (Europe & U.S.A.)

421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN Phone: +81-(0)42-587-5812 Fax: +81-(0)42-587-5564

# **ED International Marketing Department II (Asia)**

421-8, Hino, Hino-shi, Tokyo 191-8501, JAPAN

Phone: +81-(0)42-587-5814 Fax: +81-(0)42-587-5110



In pursuit of "Saving" Technology, Epson electronic devices.

Our lineup of semiconductors, liquid crystal displays and quartz devices assists in creating the products of our customers' dreams.

Epson IS energy savings.





 $\blacksquare$  Electronic devices information on the Epson WWW server

http://www.epson.co.jp