## 8-BIT MICROPROCESSOR TLCS-Z80,85 1990

TE.

TOSHIBA AMERICA ELECTRONIC COMPONENTS, INC.

#### TABLE OF CONTENTS

| 8-BIT MICROCOMPUTER PRODUCTS GUIDE                 | , i          |
|----------------------------------------------------|--------------|
| PART 1 TLCS-Z80 LSI DEVICES                        |              |
| CHAPTER 1 TLCS-Z80 FAMILY                          |              |
| TMPZ84C00AP-6 / AM-6 / AT-6 / AP-8 / AM-8 / AT-8   | MPUZ80 - 1   |
| TMPZ84C01F, TMPZ84C02AF-6                          | MPUZ80 - 59  |
| TMPZ84C10AP-6 / AM-6 / AT-6                        | MPUZ80 - 95  |
| TMPZ84C20AP-6 / AM-6 / AT-6 / AP-8                 | MPUZ80 - 165 |
| TMPZ84C30AP-6 / AM-6 / AT-6 / AP-8                 | MPUZ80 - 197 |
| TMPZ84C40AP-6 / 41AP-6 / 42AP-6 /43AF-6 / 44 AT-6, |              |
| TMPZ84C40AM-6 / 41AM-6 / 42AM-6,                   |              |
| TMPZ84C40AP-8 / 41AP-8 / 42AP-8                    | MPUZ80 - 224 |
| TMPZ84C61AP-6                                      | MPUZ80 - 274 |
| CHAPTER 2 TLCS-Z80 ASSP FAMILY                     |              |
| TMPZ84C011AF-6                                     | MPUZ80 - 297 |
| TMPZ84C013AT-6 / AT-8                              | MPUZ80 - 404 |
| TMPZ84C015AF-6 / AF-8                              | MPUZ80 - 564 |
| The Guide of Toshiba TLCS-Z80 ASSP                 |              |
| Development Tools and Development Methods          | MPUZ80 - 748 |

#### PART 2 TLCS-85 LSI DEVICES

| ТМР8085АР-2, ТМР8085АНР-2           | MPU85 -   | 1   |
|-------------------------------------|-----------|-----|
| TMP8155P-2, TMP8156P-2              | MPU85 -   | 26  |
| TMP82C51AP-2 / AM-2 / AP-10 / AM-10 | MPU85 -   | 42  |
| TMP8251AP                           | MPU85 -   | 60  |
| TMP82C53P-2                         | MPU85 -   | 78  |
| TMP82C54P-2 / M-2                   | MPU85 -   | 93  |
| TMP8253P-5                          | MPU85 - 1 | 119 |
|                                     |           |     |

| TMP82C55AP-2 / AM-2 / AP-10 / AM-10 | MPU85 - 133 |
|-------------------------------------|-------------|
| TMP8255AP-5                         | MPU85 - 153 |
| TMP82C59AP-2/AM-2                   | MPU85 - 172 |
| TMP8259AP                           | MPU85 - 198 |
| TMP82C37AP-5 / AM-5 / AT-5          | MPU85 - 207 |
| TMP8237AP-5                         | MPU85 - 240 |
| TMP82C79P-2 / M-2                   | MPU85 - 272 |
| TMP8279P-5                          | MPU85 - 294 |
| TMP82C255AN-2 / AN-10,              |             |
| TMP82C265AF-2 / AF-10               | MPU85 - 316 |

## PART 1 TLCS-Z80 LSI DEVICES CHAPTER 1 TLCS-Z80 FAMILY

## CHAPTER 2 TLCS-Z80 ASSP FAMILY

## PART 2 TLCS-85 LSI DEVICES



## ○ 8-BIT MICROPROCESSOR

## TLCS-Z80 FAMILY MPUs

| Series                            |                | TLCS-Z80                                        |                                                 |            |               |  |
|-----------------------------------|----------------|-------------------------------------------------|-------------------------------------------------|------------|---------------|--|
| P<br>Unit<br>Item                 | roduct<br>Name | TMPZ84C00AP-6<br>TMPZ84C00AM-6<br>TMPZ84C00AT-6 | TMPZ84C00AP-8<br>TMPZ84C00AM-8<br>TMPZ84C00AT-8 | TMPZ84C01F | TMPZ84C02AF-6 |  |
| Minimum Instruction<br>Cycle Time | μS             | 0.6                                             | 0.6 0.5                                         |            | 0.6           |  |
| Supply Voltage                    | v              | 4.5~                                            | -5.5                                            | 4.5~5.5*   | 4.5~5.5       |  |
| Supply Current Typ.               | mA             | 15                                              | 20                                              | 15         | 20            |  |
| Operating Temp.                   | Ĉ              | - 40~85                                         |                                                 |            |               |  |
| No. of Pins                       | -              | 40/44                                           | 40/44                                           | 44         | 44            |  |
| Clock rate                        | MHz            | DC~6                                            | DC~8                                            | DC~4       | DC~6          |  |
|                                   |                |                                                 |                                                 |            | 060489        |  |

| Series                            |     | TLCS-Z80 (ASSP) |                |        |  |  |
|-----------------------------------|-----|-----------------|----------------|--------|--|--|
| Product<br>Unit Name<br>Item      |     | TMPZ84C011AF-6  | TMPZ84C015AF-6 |        |  |  |
| Minimum Instruction<br>Cycle Time | μS  | 0.6             | 0.6            | 0.6    |  |  |
| Supply Voltage                    | v   | 4.5~5.5         |                |        |  |  |
| Supply Current Typ.               | mA  | 22              | 25             |        |  |  |
| Operating Temp.                   | ĉ   | - 40~85         |                |        |  |  |
| No. of Pins                       |     | 100 84 100      |                |        |  |  |
| Clock rate                        | MHz | DC~6            | DC~6           | DC~6   |  |  |
|                                   |     |                 |                | 060489 |  |  |

(Notes) 💥 : Operatable under low supply voltage (2.7V (Min));

Postfix M: SOP (Small Outline Package), P: DIP (Dual-in-Line Package)

T: PLCC (Plastic Leaded Chip Carrier), F: QFP (Quad Flat Package)

i

## **TLCS-Z80 FAMILY PERIPHERALs**

| Series                            |               | TLCS-Z80                                        |                                                 |                                                 |                                |                                |  |  |
|-----------------------------------|---------------|-------------------------------------------------|-------------------------------------------------|-------------------------------------------------|--------------------------------|--------------------------------|--|--|
| Pr<br>Unit<br>Item                | oduct<br>Name | TMPZ84C10AP-6<br>TMPZ84C10AM-6<br>TMPZ84C10AT-6 | TMPZ84C20AP-6<br>TMPZ84C20AM-6<br>TMPZ84C20AT-6 | TMPZ84C30AP-6<br>TMPZ84C30AM-6<br>TMPZ84C30AT-6 | TMPZ84C40AP-6<br>TMPZ84C40AM-6 | TMPZ84C41AP-6<br>TMPZ84C41AM-6 |  |  |
| Minimum Instruction<br>Cycle Time | μS            | _                                               | _                                               |                                                 | -                              | _                              |  |  |
| Supply Voltage                    | v             |                                                 | 4.5~5.5                                         |                                                 |                                |                                |  |  |
| Supply Current Typ.               | mA            | 6                                               | 3                                               | 4                                               | 4                              | 4                              |  |  |
| Operating Temp.                   | ĉ             | - 40~85                                         |                                                 |                                                 |                                |                                |  |  |
| No. of Pins                       | -             | 40 / 44                                         | 40 / 44                                         | 28/44                                           | 40                             | 40                             |  |  |
| Clock rate                        | MHz           | DC~6                                            | DC~6                                            | DC~6                                            | DC~6                           | DC~6                           |  |  |

060489

| Series                            |     | TLCS-Z80      |               |               |        |  |
|-----------------------------------|-----|---------------|---------------|---------------|--------|--|
| Product<br>Unit Name<br>Item      |     | TMPZ84C42AP-6 | TMPZ84C43AF-6 | TMPZ84C61AP-6 |        |  |
|                                   |     | TMPZ84C42AM-6 | TMPZ84C44AT-6 |               |        |  |
| Minimum Instruction<br>Cycle Time | μS  |               |               |               |        |  |
| Supply Voltage                    | v   | 4.5~5.5       |               |               |        |  |
| Supply Current Typ.               | mA  | 4             | 4             | 3             | 4      |  |
| Operating Temp.                   | ĉ   | -40~85        |               |               |        |  |
| No. of Pins                       | -   | 40 44 16 16   |               |               |        |  |
| Clock rate                        | MHz | DC~6          | DC~6          | DC~6          | DC~8   |  |
|                                   |     |               |               |               | 060489 |  |

(Notes)

 Postfix
 P : DIP (Dual-in-line Package);
 T : PLCC (Plastic Leaded Chip Carrier)

 F : QFP (Quad Flat Package);
 M: SOP (Small Outine Package)

ii

#### TLCS-Z80 FAMILY 8MHz VERSION (PERIPHERALS & ASSP)

| Series                            |                | TLCS-Z80 (PERIPHERALS) |               |               |               |               |  |
|-----------------------------------|----------------|------------------------|---------------|---------------|---------------|---------------|--|
| P<br>Unit<br>Item                 | roduct<br>Name | TMPZ84C20AP-8          | TMPZ84C30AP-8 | TMPZ84C40AP-8 | TMPZ84C41AP-8 | TMPZ84C42AP-8 |  |
| Minimum Instruction<br>Cycle Time | μS             |                        | _             |               |               |               |  |
| Supply Voltage                    | V              |                        | 4.75~5.25     |               |               |               |  |
| Supply Current Typ.               | mA             | 4                      | 5             | 5             | 5             | 5             |  |
| Operating Temp.                   | Ĵ              | - 10~70                |               |               |               |               |  |
| No. of Pins                       | -              | 40                     |               |               |               |               |  |
| Clock rate                        | MHz            |                        |               | 8             |               |               |  |

060489

| Series                            |               | TLCS-Z8        | 0 (ASSP)       |  |  |
|-----------------------------------|---------------|----------------|----------------|--|--|
| Pr<br>Unit<br>Item                | oduct<br>Name | TMPZ84C015AF-8 | TMPZ84C013AT-8 |  |  |
| Minimum Instruction<br>Cycle Time | μS            | 0.5            |                |  |  |
| Supply Voltage                    | V             | 4.75~5.25      |                |  |  |
| Supply Current Typ.               | mA            | 35             | 31             |  |  |
| Operating Temp.                   | Ĉ             | - 10~70        |                |  |  |
| No. of Pins                       | -             | 100 84         |                |  |  |
| Clock rate                        | MHz           | 8              |                |  |  |
|                                   |               |                | 060489         |  |  |

iii

### ○ 8-BIT MICROPROCESSOR

## TLCS-85 FAMILY (1/2)

| Series                            |     | TLCS-85 (NMOS) |              |                    |            |             |
|-----------------------------------|-----|----------------|--------------|--------------------|------------|-------------|
| Product<br>Unit Name              |     | TMP8085AP-2    | TMP8085AHP-2 | TMP8155P-2         | TMP8156P-2 | TMP8237AP-5 |
| Minimum Instruction<br>Cycle Time | μS  | 1.3/0.8        | 1.3 / 0.8    |                    |            | <u> </u>    |
| Supply Voltage                    | v   | 4.75~5.25      | 4.5~5.5      | 4.75~5.25 4.75~5.2 |            |             |
| Supply Current Typ.               | mA  | 170            | 135          | 180                | 180        | 150         |
| Operating Temp.                   | °C  | 0~70           |              |                    |            |             |
| No. of Pins                       | _   | 40             | 40 40 40     |                    |            |             |
| Clock rate                        | MHz | 3/5            | 3/5          | 3/5                | 3/5        | 3/5         |

060489

| Series                            |               | TLCS-85 (NMOS) |            |                    |               |            |  |
|-----------------------------------|---------------|----------------|------------|--------------------|---------------|------------|--|
| Pr<br>Unit<br>Item                | oduct<br>Name | TMP8251AP      | TMP8253P-5 | TMP8255AP-5        | TMP8259AP     | TMP8279P-5 |  |
| Minimum Instruction<br>Cycle Time | μS            | -              | -          | -                  | -             | -          |  |
| Supply Voltage                    | V             | 4.75~5.25      |            |                    | 4.5~5.5       |            |  |
| Supply Current Typ.               | mA            | 100            | 140        | 120                | 85            | 120        |  |
| Operating Temp.                   | °C            | 0~70           |            |                    |               |            |  |
| No. of Pins                       | -             | 28             | 28 24 40   |                    |               | 40         |  |
| Clock rate                        | MHz           | 3              | 2.5        | 3<br>(TRD = 200ns) | (TRD = 200ns) | 3          |  |

060489

(Note) Postfix P: DIP (Dual-in-line Package)

iv

## TLCS-85 FAMILY (2/2)

|                | TLCS-85 (CMOS)                  |                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                              |
|----------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Product        |                                 | TMP82C51AP-10                                                                                                                                            |                                                                                                                                                                                   | TMP82C54P-2                                                                                                                                                                                                     | TMP82C55AP-2                                                                                                                                                                                                                                                                                                                                 |
| Item Unit Name | TMP82C51AM-2                    | TMP82C51AM-10                                                                                                                                            | TMP82C53P-2                                                                                                                                                                       | TMP82C54M-2                                                                                                                                                                                                     | TMP82C55AM-2                                                                                                                                                                                                                                                                                                                                 |
| V              | 4.5~5.5                         |                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                              |
| mA             | 0.8                             | 4                                                                                                                                                        | 2 <0.5µA>                                                                                                                                                                         | 3                                                                                                                                                                                                               | 2 <0.5µA>                                                                                                                                                                                                                                                                                                                                    |
| °C             | -40~85                          |                                                                                                                                                          |                                                                                                                                                                                   |                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                              |
| -              | 28                              | 28                                                                                                                                                       | 24                                                                                                                                                                                | 24                                                                                                                                                                                                              | 40                                                                                                                                                                                                                                                                                                                                           |
| MHz            | 5                               | 10                                                                                                                                                       | 5                                                                                                                                                                                 | 10                                                                                                                                                                                                              | 5<br>(TRD = 140ns)                                                                                                                                                                                                                                                                                                                           |
|                | ame<br>∨<br>mA<br>℃<br>−<br>MHz | Imp82c51AP-2           ame           TMP82c51AM-2           V           mA           0.8           °C           —           28           MHz           5 | Auct     TMP82C51AP-2     TMP82C51AP-10       TMP82C51AM-2     TMP82C51AM-10       V     TMP82C51AM-2       mA     0.8     4       °C     -       -     28       MHz     5     10 | Matrix     TMP82C51AP-2     TMP82C51AP-10     TMP82C53P-2 $V$ TMP82C51AM-10     TMP82C53P-2 $V$ 4.5~5.5       mA     0.8     4     2 <0.5 $\mu$ A> $C$ -40~85       -     28     28     24 $MHz$ 5     10     5 | Matrix     TMP82C51AP-2     TMP82C51AP-10     TMP82C51AP-2     TMP82C51AP-2       V     TMP82C51AM-2     TMP82C51AM-10     TMP82C53P-2     TMP82C54M-2       V $4.5 \sim 5.5$ TMP82C54M-2     TMP82C54M-2       V $4.5 \sim 5.5$ $5.5 \sim 5.5$ mA $0.8$ $4$ $2 < 0.5 \mu A >$ $3$ °C $-40 \sim 85$ - $28$ $24$ $24$ $MHz$ $5$ $10$ $5$ $10$ |

| Series               |     | TLCS-85 (CMOS)      |                |                |                    |             |  |  |
|----------------------|-----|---------------------|----------------|----------------|--------------------|-------------|--|--|
| Product<br>Unit Name |     | TMP82C55AP-10       | TMP82C255AN-2  | TMP82C265AF-2  | TMP82C59AP-2       | TMP82C79P-2 |  |  |
| ltem                 |     | TMP82C55AM-10       | TMP82C255AN-10 | TMP82C265AF-10 | TMP82C59AM-2       | TMP82C79M-2 |  |  |
| Supply Voltage       | V   |                     | 4.5~5.5        |                |                    |             |  |  |
| Supply Current Typ.  | mA  | 2 <0.5µA>           | 1A> 3 3        |                | 0.8                | 2           |  |  |
| Operating Temp.      | °C  |                     | - 40~85        |                |                    |             |  |  |
| No. of Pins          | -   | 40                  | 40 64 80 28 4  |                |                    |             |  |  |
| Clock rate           | MHz | 10<br>(TRD = 100ns) | 8 / 10         | 8/10           | 8<br>(TRD = 120ns) | 5           |  |  |

060489

| Series              |               | TLCS-85 (CMOS) |               |  |
|---------------------|---------------|----------------|---------------|--|
| Pr<br>Unit          | oduct<br>Name | TMP82C37AP-5   | *TMP82C37BP-8 |  |
| Item                | $\searrow$    | TMP82C37AM-5   | *TMP82C37BM-8 |  |
| Supply Voltage V    |               | 4.5~5.5        |               |  |
| Supply Current Typ. | mA            | 5 8            |               |  |
| Operating Temp. 🕅   |               | - 40~85        |               |  |
| No. of Pins -       |               | 40             | 40            |  |
| Clock rate MHz      |               | 5 8            |               |  |
|                     |               |                | 06048         |  |

(Notes) \*: under development; <> : Hold current; Postfix P : DIP (Dual-in-line Package), F : QFP (Quad Flat Package)

N : Plastic shrink DIP, M : SOP (Small Outline Package)

۷

## PART 1 8-BIT MICROPROCESSOR CHAPTER 1 TLCS-Z80 FAMILY

TOSHIBA CORPORATION

## CONTENTS

| TMPZ84C00AP-6 / AM-6 / AT-6 / AP-8 / AM-8 / AT-8   | MPUZ80 - 1   |
|----------------------------------------------------|--------------|
| TMPZ84C01F, TMPZ84C02AF-6                          | MPUZ80 - 59  |
| TMPZ84C10AP-6 / AM-6 / AT-6                        | MPUZ80 - 95  |
| TMPZ84C20AP-6 / AM-6 / AT-6 / AP-8                 | MPUZ80 - 165 |
| TMPZ84C30AP-6 / AM-6 / AT-6 / AP-8                 | MPUZ80 - 197 |
| TMPZ84C40AP-6 / 41AP-6 / 42AP-6 / 43AF-6 / 44AT-6, |              |
| TMPZ84C40AM-6 / 41AM-6 / 42AM-6,                   |              |
| TMPZ84C40AP-8 / 41AP-8 / 42AP-8                    | MPUZ80 - 224 |
| TMPZ84C61AP-6                                      | MPUZ80 - 274 |

i

## TMPZ84C00AP-6 / TMPZ84C00AM-6 / TMPZ84C00AT-6 TMPZ84C00AP-8 / TMPZ84C00AM-8 / TMPZ84C00AT-8 TLCS-Z80 MPU : 8-BIT MICROPROCESSOR

#### 1. OUTLINE AND FEATURES

The TMPZ84C00A is an 8-bit microprocessor (hereinafter referred to as MPU), which provides low power operation and high performance.

Built into the TMPZ84C00A are bus control, memory control and timing control circuits in addition to paired 6 general purpose registers, accumulator, flag registers and an arithmetic-and-logic unit.

The TMPZ84C00A is fabricated using Toshiba's CMOS Silicon gate Technology. The pricipal functions and features of the TMPZ84C00A are as follows.

|                             | Operating | Supply Current (TYP.) |                |  |  |
|-----------------------------|-----------|-----------------------|----------------|--|--|
| Produce Name                | Frequency | AT RUN                | AT<br>STAND BY |  |  |
| TMPZ84C00AP-<br>6/AM-6/AT-6 | 6MHz      | 15mA                  | 0.5µA          |  |  |
| TMPZ84C00AP-<br>8/AM-8/AT-8 | 8MHz      | 20mA                  | 0.5µA          |  |  |
|                             |           |                       | 000            |  |  |

#### Table 1.1 Operating Frequency and Supply Current

- (1) Commands compatible with the Zilog Z80 MPU.
- (2) Low power consumption
- (3) DC to 8MHz operation (at  $5V \pm 10\%$ )
- (4) Single 5V power supply  $(5V \pm 10\%)$
- (5) Operating temperature  $(-40^{\circ}C \text{ to } 85^{\circ}C)$
- (6) Powerful set of 158 instrucitons available
- (7) Powerful interrupt function
  - (a) Non-maskable interrupt terminal (NMI)
  - (b) Maskable interrupt terminal  $(\overline{INT})$

The following 3 modes are selectable:

- 8080 compatible interrupt mode (interrupt by Non-Z80 family peripheral LSI) (Mode 0)
- Restart interrupt (Mode 1)

MPUZ80-1

- Daisy chain structure interrupt using Z80 family peripheral LSI (Mode 2)
- (8) An auxiliary resister provided to each of general purpose registers
- (9) Two index registers
- (10) 10 addressing modes
- (11) Built-in refresh circuit for dynamic memory
- (12) Molded in 40-pin DIP package (P), 40-pin SOP package (M) and 44-pin PLCC package (T).

Further, in the following text and explanations for charts and tables, hexadecimal numbers are directly used without giving an identification to explanation of address, etc. to the extent not to cause confusions.

Note: Z80 is a trademark of Zilog Inc., U.S.A.

**MPUZ80-2** 

#### 2. PIN ASSIGNMENT AND FUNCTIONS

The pin assignment and I/O pin names and brief functions of TMPZ84C00A are shown below.

#### 2.1 PIN ASSIGNMENT (TOP View)

The pin assignment of the TMPZ84C00A are as shown in Figure 2.1 and Figure 2.2.



Figure 2.1 DIP, SOP Pin Assignment



(1/2)

#### 2.2 PIN NAMES AND FUNCTIONS

I/O pin names and functions are as shown Table 2.1.

| Pin    | Q'ty<br>(Number) | Туре                    | Function                                                                                                                                                                                                                                                                                                                                                      |
|--------|------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7  | 8                | Input/output<br>3-state | The 8-bit bi-directional data bus.                                                                                                                                                                                                                                                                                                                            |
| A0-A15 | 16               | Output<br>3-state       | The 16-bit address bus.<br>These pins specify memory and I/O port<br>addresses. During a refresh cycle, the refresh<br>address is output.                                                                                                                                                                                                                     |
| M1     | 1                | Output                  | The Machine Cycle 1 signal.<br>In an operation code fetch cycle, this pin goes<br>"0" with the MREQ signal. At the execution of a<br>2-byte operation code, this pin goes "0" for each<br>operation code fetch. In a maskable interrupt<br>acknowledge cycle, this pin goes "0" with the<br>IORQ signal.                                                      |
| RD     | 1                | Output<br>3-state       | The Read signal. It indicates that the MPU is<br>ready for accepting data from memory or I/O<br>device. The data from the addressed memory or<br>I/O devices is gated by this signal onto the MPU<br>data bus.                                                                                                                                                |
| WR     | 1                | Output<br>3-state       | The Write signal. This signal is output when the data to be stored in the addressed memory or I/O device is on the data bus.                                                                                                                                                                                                                                  |
| MREQ   | 1                | Output<br>3-state       | The Memory Request signal. When the execution address for memory access is on the address bus, this pin goes "0". During a memory refresh cycle, this pin also goes "0" with RFSH signal.                                                                                                                                                                     |
| IORQ   | 1                | Output<br>3-state       | The Input/Output Request signal. This pin goes<br>"0" when the address for an I/O read or write<br>operation is on the low-order 8 bits (A0 through<br>A7) of the address bus. The IORQ signal is also<br>output with the M1 signal at interrupt<br>acknowledge to tell an I/O device that the<br>interrupt response vector can be placed on the<br>data bus. |
| CLK    | 1                | Input                   | The Single-phase Clock Input.<br>When the clock input is placed in the DC state<br>(continued "1" or "0" level), this pin stops<br>operating and holds the state of that time.                                                                                                                                                                                |

#### Table 2.1 Pin names and Functions

060489

|                   |                  |              | (2/2)                                                                                                                                                                                                                                                                                             |
|-------------------|------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin               | Q'ty<br>(Number) | Туре         | Function                                                                                                                                                                                                                                                                                          |
| RESET             | 1                | Input        | The Reset signal input.<br>RESET signal is used for initialization MPU and<br>must be kept in active state ("0") for a period of<br>at least 3 clocks.                                                                                                                                            |
| ĪNT               | 1                | Input        | The Maskable Interrupt signal. An interrupt is<br>caused by the peripheral LSI. An interrupt is<br>acknowledged when the interrupt enable flip-<br>flop (IFF) is set to "1" by software.<br>The INT pin is normally wire-ORed and requires<br>an external pullup resistor for these applications. |
| WAIT              | 1                | Input        | The Wait Request signal. This signal indicates to<br>the MPU that the addressed memory or I/O<br>device is not ready for data transfer. As long as<br>this signal is "0", the MPU is in the Wait state.                                                                                           |
| BUSREQ            | 1                | Input        | The bus Request signal. The BUSREQ signal<br>forces the MPU address bus, data bus, and<br>control signals MREQ, IORQ, RD, and WR to be<br>placed in the high-impedance state. This signal is<br>normally Wire-ORed and requires an external<br>pullup resistor for these applications.            |
| BUSACK            | 1                | Output       | The Bus Acknowledge signal. In response to the BUSREQ signal, the BUSACK signal indicates to the requesting peripheral LSI that the MPU address bus, data bus, and control signals MREQ, IORQ, RD and WR have been put in the high-impedance state.                                               |
| HALT              | 1                | Output       | The Halt signal. This pin goes "0" when the MPU has executed a Halt instruction and is in the Halt state.                                                                                                                                                                                         |
| RFSH              | 1                | Output       | The refresh signal. When the dynamic memory refresh address is on the low-order 8 bits of the address bus, this signal goes "0". At the same time, the MREQ signal also goes active ("0").                                                                                                        |
| NMI               | 1                | Input        | The Non-maskable Interrupt Request signal.<br>This interrupt request has a higher priority than<br>the maskable interrupt and is not dependent on<br>the interrupt enable flip-flop (IFF) state.                                                                                                  |
| NC<br>(PLCC only) | 4                | _            | Not connected internaly.<br>Please use by open.                                                                                                                                                                                                                                                   |
| V <sub>CC</sub>   | 1                | power supply | + 5 V                                                                                                                                                                                                                                                                                             |
| V <sub>SS</sub>   | 1                | power supply | 0 V                                                                                                                                                                                                                                                                                               |

060489

#### 3. FUNCTIONAL DESCRIPTION

The system configuration, functions and basic operation of the  $\ensuremath{\mathsf{TMPZ84C00A}}$  are described here.

#### 3.1 BLOCK DIAGRAM

The block diagram of the internal configuration is shown in Figure 3.1.



Figure 3.1 Block Diagram

#### 3.2 SYSTEM CONFIGURATION

The MPU has the configuration shown in Figure 3.1. The address signal is put on the address bus via the address buffer. The data bus is controlled for input or output by the data bus interface. Both the address and data buses are put in the high-impedance state by the BUSEQ signal input to make them available for other peripheral LSIs. The Opcode read from memory via the data bus is written to the instruction register. This Opcode is decoded by the instruction decoder. According to the result of the decoding, control signals are sent to the relevant devices. Receiving these control signals, the ALU performs arithmetic operations. The register array temporarily hold the information required to perform operation.

The following describes the MPU's main components and functions which the user must understand to operate the TMPZ84C00A.

[1] Internal Register Groups

The configuration of the internal register groups is as follows:

(1) Main registers

A, F, B, C, D, E, H, L

(2) Alternate registers

A', F', B', C', D', E', H', L'

(3) Special purpose registers

I, R, IX, IY, SP, PC

Figure 3.3 shows the configuration of the internal register groups. The register groups, each being of a static RAM, consists of eighteen 8-bit registers and four 16-bit registers. The following describes the function of each register:

(1) Main registers (A, F, B, C, D, E, H, L)

(a) Accumulator (A)

The accumulator is an 8-bit register used for arithmetic and data transfer operations.

(b) Flag register (F) (see Fig. 3.2)

The flag register is an 8-bit register to hold the result of each arithmetic operation. Actually, the 6 of the 8 bits are set ("1")/reset ("0") according to the condition specified by an instruction.

#### **MPUZ80-7**





The following 4 bits are directly available to the programmer for setting the jump, call and return instruction conditions:



060489

Figure 3.3 Flag Register Configuration

• <u>Sign flag (S)</u>

When the result of an operation is negative, the S flag is set to "1". Actually, the content of bit 7 of accumulator is stored in this flag.

Zero flag (Z)

When all bits turn out to be "0" s after operation, the Z flag is set to "1" . Otherwise, it is set to "0".

With a block search instruction (CPI, CPIR, CPD or CPDR), the Z flag is set to "1" if the source data and the accumulator data match.

With a block I/O instruction (INI, IND, OUTI or OUTD), the Z flag is set to "1" if the content of the B register used as the byte counter is "0" at the end of comparison.

• Parity/overflow flag (P/V)

This flag has two functions. One is the parity flag (P) that indicates the result of a logical operation (AND A, B etc.). The P flag is set to "1" if the parity is even as a result of the operation on signed values by two's complement. It is reset to "0" if the parity is odd. With a block search instruction (CPI, CPIR, CPD or CPDR) and a block transfer instruction (LDI or LDD), the P flag indicates the state of the byte counter (register pair B and C). It is set to "1" if the byte counter is not "0" and reset to "0" when the byte counter becomes "0" (at the end of comparison or data transfer). The content of the interrupt enable flip-flop (IFF) is saved to the P flag when the contents of the R register or I register are transferred to the accumulator.

The other use of the P/V flag is the overflow flag (V) that indicates whether an overflow has occurred or not as a result of an arithmetic operation. The V flag is set to "1" when the value in the accumulator gets out of a range of the maximum value +127 and the minimum value -128 and therefore cannot be correctly represented as a two's complement notation.

Whether the P/V flag operates as the P flag or V flag is determined by the type of the instruction executed.

<u>Carry flag (C)</u>

The C flag is set to "1" if a carry occurs from bit 7 of the accumulator or a borrow occurs as a result of an operation.

The following two flags are not available to the programmer for the test and set ("1")/reset ("0") purposes. They are internally used by the MPU for BCD arithmetic operations.

• Half carry flag (H)

The H flag is used for holding the carry or borrow from the low-order 4 bits of a BCD operation result. When a DAA instruction (decimal adjust) is executed, the MPU automatically uses the H flag to adjust the result of a decimal addition or subtraction.

#### $\circ$ <u>Add/subtract flag (N)</u>

In BCD operation, algorithm is different between addition and subtraction. The N flag indicates whether the executed operation is addition or subtraction. For change of the flag state depending on the instruction, see 3.4 "TMPZ84C00A Instruction Set".

#### (c) General-purpose registers (B, C, D, E, H, L)

General-purpose registers consist of 8 bits each. They are used as 16-bit register pairs (BC, DE, HL) as well as independent 8-bit registers to supplement the accumulator. The B register and the register pair BC are used as counters when a block I/O, block transfer, or search instruction is executed. The register pair HL has various memory addressing features as compared with the register pairs BC and DE.

#### (2) Alternate registers (A', F', B', C', D', E', H', L')

The configuration of the alternate registers is exactly the same as that of the main registers. There is no instruction that handles the alternate registers directly. The data in the alternate registers are processed by moving them into the main registers by means of exchange instructions as shown below:

EX AF, AF'  $(A \leftrightarrow A', F \leftrightarrow F')$ 

EXX  $(B \leftrightarrow B', C \leftrightarrow C', D \leftrightarrow D', E \leftrightarrow E', H \leftrightarrow H', L \leftrightarrow L')$ 

When a high-speed interrupt response has been requested within the system, these instruction can be used to quickly move the contents of the accumulator, flag registers, and general-purpose registers into the corresponding registers. This eliminates the need for transferring the register contents to/from the external stack during execution of the interrupt handling routine, thereby shortening the interrupt servicing time greatly.

#### (3) Special purpose registers (I, R, IX, IY, SP, PC)

#### (a) Interrupt page address register (I)

The TMPZ84C00A provides two kinds of interrupts :maskable interrupt (INT) and non-maskable interrupt (NMI). The maskable interrupt provides three modes (0, 1, and 2) in which the interrupt is handled. These modes can be selected by instructions IM0, IM1, and IM2 respectively. In Mode 2, any memory location can be called indirectly depending on the interrupt. For this purpose, the I register stores the high-order 8 bits of the indirect address. The low-order 8 bits are supplied from the interrupting peripheral LSI. This scheme permits calling the interrupt handling routine from any memory location in an extremely short access time. For the details of interrupts, see [4] "Interrupt Capability".

#### (b) Memory refresh register (R)

The R register is used as the memory refresh counter when the dynamic RAM is used for memory. This permits using of the dynamic memory in the same manner as the static memory. The Low-order 7 bits of this 8-bit register is automatically incremented for each instruction fetch. While the MPU decodes and executes the fetched instruction, the contents of the R register are synchronized with the refresh signal to place the low-order 8 bits on the address bus. This operation is all performed by the MPU and, therefore, dose not need a special processing by program. The MPU operation is not delayed by this operation. During refresh, the contents of the I register are placed on the high-order 8 bits of the address bus.

(c) Index registers (IX, IY)

The two independent index registers IX and IY hold the 16-bit base address when used in the index addressing mode. In this addressing mode, the memory address obtained by adding the contents of an index register to the displacement value (for example, LD IX+40H) is specified. This mode is convenient for using data tables. Also these registers can be used separately for memory addressing and data retaining registers.

(d) Stack pointer (SP)

The stack pointer is a 16-bit register to provide the start address information in the stack area in the external RAM. The content of the stack pointer is decremented at the execution of a CALL instruction or PUSH instruction or interrupt handling and is incremented at the execution of a return instruction or POP instruction. At the execution of a CALL instruction or interrupt handling, the current content of the program counter is saved into the stack. At the execution of a return instruction, the content is restored from the stack to the program counter. These operations are all performed by the MPU automatically. However, the other registers are not saved or restored automatically. For the storing of the contents of these registers, an exchange instruction (EX or EXX) for alternate register, a PUSH or a POP instructions must be used. When a PUSH instruction is executed, the contents of the specified register are saved into the stack. When a POP instruction is executed, the contents of the stack are moved to the specified register.

These data are restored on a last-in, first-out basis. Use of the stack permits processing of multiple-level interrupts, deep subroutine nestings, and various data manipulation very easily. The stack pointer is not initialized in the hardware approach. Therefore, it is required to allocate the stack area in RAM to specify initialization (at the highest address of the stack area) in the initial program.

| (ex)   |                                              |                                  |               |                 |                                 |                   |          |                                                            |
|--------|----------------------------------------------|----------------------------------|---------------|-----------------|---------------------------------|-------------------|----------|------------------------------------------------------------|
| ME     | VIORY A<br>(HEX                              | (DDRES                           | s             | c               | M E M O R Y<br>ADDRESS<br>(HEX) | INSTR             | RUCTION  | The contents of the SP before the instruction is accepted. |
| LOWER  |                                              |                                  | ion           | tio             | 1230                            | CALL              | 1500H    | FFF1                                                       |
| ↑<br>↓ | FFEB<br>FFEC<br>FFED<br>FFEE<br>FFEF<br>FFEF | C0<br>B2<br>23<br>05<br>33<br>12 | ★ save direct | - restore direc | 1500<br>1501                    | PUSH<br>PUSH      | AF<br>BC | FFEF ; A=05, F=23<br>FFED ; B=B2, C=C0                     |
| HIGHER |                                              |                                  |               | Ļ               | 1600<br>1601<br>1602            | POP<br>POP<br>BET | BC<br>AF | FFEB<br>FFED<br>FFFF                                       |
|        |                                              |                                  |               |                 | 1302                            |                   |          |                                                            |

The foregoing example shows the stack pointer and stack operations in which the instructions starting with the CALL at address 1230H and ending with the RET at address 1602H have been executed. However, it is assumed that there is no instruction or interrupt other than shown above that uses the stack during the execution. When the value the stack pointer before executing the CALL instruction at address 1230H indicates address FFF1H, address 1233H is stored at addresses FFF0H and FFEFH because the CALL instruction consists of 3 bytes, then the stack pointer is decremented. Similarly, the data are saved or restored sequentially according to the instructions. These stack and stack pointer operations are all performed automatically.

(e) Program counter (PC)

The program counter holds, in 16 bits, the memory address of the instruction to be executed next. The MPU fetches the instruction from the memory location indicated by the program counter. When the content of the program counter is put on the address bus, the program counter is incremented automatically. However, it is not incremented with a jump instruction, a call instruction, or interrupt processing. Instead, the specified new address is set on it. With a return instruction, the content restored from the stack is set on the program counter. These operations are all performed automatically and therefore, no care is required for programming.

#### [2] Halt Capability

When a HALT instruction has been executed, the MPU is put in the halt state. The halt capability can be used to halt the MPU against the external interrupts, thereby reducing the power dissipation. In the halt state the states of MPU's internal registers are retained. The halt state is cleared by reset or when an interrupt is accepted. For the details of halt operation, see [3] "Basic Timing".

(1) Halt operation

When a HALT instruction has been executed, the MPU sets the HALT signal to "0" to indicate that the MPU is going to be put in the halt state. Actually, the MPU in the halt state automatically continues executing NOP instructions if there is the system clock input. However, the program counter is not incremented. This keeps the refresh signal generated when the dynamic memory is used. During halt, the MPU's internal states are retained. By using TLCS-Z80's clock generator/controller (TMPZ84C60P or TMPZ84C61AP), the clock input control for these halt operations is realized easily.

(2) Releasing the halt state

The halt state is cleared by accepting an interrupt (the  $\overline{INT}$  or  $\overline{NMI}$  signal input) or by reset (the  $\overline{RESET}$  signal input). When an interrupt is accepted, the halt state is cleared and the interrupt handling routine is executed. However, a maskable interrupt (INT) cannot be accepted unless the interrupt enable flip-flop (IFF) is set.

Note that when the halt state is cleared by the  $\overline{\text{RESET}}$  signal, the MPU is reset and the program counter is set to "0".

[3] RESET Signal

Holding the  $\overline{\text{RESET}}$  pin at the low level ("0") under the following conditions, the MPU's internal states are reset:

- (1) The supply voltage level is within the operational voltage range.
- (2) System clock stabilization.
- (3) Holding the RESET signal at the low level ("0") for at least 3 full clock cycles. When the RESET signal goes high ("1"), the MPU starts executing instructions from address 0000H after at least 2T state dummy cycles. When reset, the MPU performs the following processing:
  - (1) Program counter

0000H is set.

(2) Interrupt

The interrupt enable flip-flop (IFF) is reset to "0" to disable the maskable interrupt. For the maskable interrupt processing, mode 0 is specified.

(3) Control output

All control outputs are made inactive ("1"). Therefore, the halt state is also cleared.

(4) Interrupt page address register (I register)

The content of the R register becomes 00H.

(5) Refresh register (R register)

The content of the R register becomes 00H.

The contents of the registers other than above and the external memory do not change.

Therefore, they must be initialized as required.

[4] Interrupt Capability

The interrupt capability is used to suspend the execution of the current program and execute the processing of the requested peripheral LSI. Normally, this interrupt processing routine contains the data exchange and transfer of status and control information between the MPU and the peripheral LSI. When this routine has been completed, the MPU returns to the active state before the interrupt has been accepted.

The TMPZ84C00A provides the non-maskable interrupt (NMI) and maskable interrupt (INT) capabilities which are detected by the  $\overline{\text{NMI}}$  and  $\overline{\text{INT}}$  interrupt request signals, respectively. A non-maskable interrupt, when caused by a peripheral LSI, is accepted unconditionally. This interrupt is used to support critical functions such as the protection of the system from unpredictable happening including power failure. A maskable interrupt can be enabled or disabled by program. For example, if the timer is used and, therefore, an interrupt is not desired, the system can be programmed to disable the interrupt. Table 3.1 lists the processing by interrupt source.

#### (1) Interrupt enable/disable

A non-maskable interrupt cannot be disabled by program, while a maskable interrupt can be enabled or disabled by program. The MPU has the interrupt enable flip-flop (IFF). A maskable interrupt can be enabled or disabled by setting this flip-flop to "1" (set) or "0" (reset) through an EI instruction (enable) or a DI instruction (disable) in program. Actually, the IFF consists of two flip-flops IFF1 and IFF2. IFF1 is used to select between the enable and disable of a maskable interrupt. IFF2 holds the state of IFF1 before a maskable interrupt has been accepted. Both IFF1 and IFF2 are reset to "0" when any of the following conditions occurs, disabling an interrupt:

- MPU reset
- Execution of DI instruction
- Acceptance of maskable interrupt

Both IFF1 and IFF2 are set to "1" when the the following condition occurs, enabling an interrupt:

• Execution of EI instruction

Actually, the waiting maskable interrupt request is accepted after the execution of the instruction that follows the EI instruction.

This delay by one instruction is caused by accepting an interrupt after completion of the execution of a return instruction if the instruction following the EI instruction is a return instruction.

In the above operation, the contents of IFF1 and IFF2 are the same.

060489

| Interrupt Source                               | Priority | Programmed condition |        | Vector address            | Interrupt<br>return<br>instruction |
|------------------------------------------------|----------|----------------------|--------|---------------------------|------------------------------------|
| Non-maskable interrupt                         | 1        | No                   | one    | Address 66H               | RETN                               |
| (the falling edge of $\overline{\text{NMI}}$ ) |          |                      |        |                           |                                    |
|                                                |          |                      |        | Instruction from          |                                    |
| Maskable interrupt (INT                        | 2        | IFF = 1              | Mode 0 | peripheral LSI.           | (Note)                             |
| becomes "0" at                                 |          |                      |        | Normally, CALL or RST     | RET I                              |
| instruction's last clock)                      |          |                      |        | instruction.              |                                    |
|                                                |          | Mode 1               |        | Address 38H.              |                                    |
|                                                |          |                      |        | The address indicated by  |                                    |
|                                                |          |                      |        | the data table (memory)   |                                    |
|                                                |          |                      | Mode 2 | at the address specified  | 1                                  |
|                                                |          |                      |        | by I register (high-order |                                    |
|                                                |          |                      |        | 8 bits) and data from     |                                    |
|                                                |          |                      |        | peripheral LSI (low-      |                                    |
|                                                |          |                      |        | order 8 bits, LSB = "0"). |                                    |

Table 3.1 Processing by Interrupt Source

Note : Mode 0 applies when the instruction from peripheral LSI is CALL or RST instruction.



Figure 3.4 Interrupt Enable Flip-Flop (IFF)

060489

When a non-maskable interrupt has been accepted, IFF1 is reset to "0" (interrupt disable) until an EI or RETN instruction is executed, so as to prevent from accepting the next interrupt. For this purpose, the state (interrupt enable/disable) of IFF1 immediately before non-maskable interrupt acceptance must be stored. This state is copied into IFF2 upon acceptance of a non-maskable interrupt. The content of IFF2 is copied into the parity flag at the execution of the following instructions, so that the copied data can be tested or stored:

- The load instruction (LD A, I) to load the contents of the I register into the accumulator.
- The load instruction (LD A, R) to load the contents of the R register into the accumulator.

When the return instruction (RETN) from the non-maskable interrupt is executed, the contents of the current IFF2 are copied back to IFF1. If an operation which changes the contents of IFF2 (due to the execution of EI or DI instruction, for example) has not been performed during interrupt handling, IFF1 automatically returns to the state immediately before the interrupt acceptance. Table 3.2 lists the states of IFF1 and IFF2 after execution of interrupt-related instructions.

| Operation sequence | IFF1 | IFF2 | Remarks          |
|--------------------|------|------|------------------|
| NPU reset          | 0    | 0    |                  |
| El                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| LD A, I            | *    | *    | Parity flag←IFF2 |
| RETN               | 1    | 1    | IFF1←IFF2        |
| LD A, R            | *    | *    | Parity flag←IFF2 |
| INT acceptance     | 0    | 0    |                  |
| RETI               | *    | *    |                  |
| EI                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| DI                 | 0    | 0    |                  |
| RETN               | *    | *    |                  |

Table 3.2 State of IFF1 and IFF2

Note: \*=no change

#### (2) Interrupt processing

With a non-maskable interrupt, the internal NMI flip-flop is set to "1" on the falling edge of the interrupt signal,  $\overline{\text{NMI}}$ . The state of this flip-flop is sampled on the rising edge of the last clock of each instruction to accept an interrupt. A maskable interrupt is accepted if the interrupt signal  $\overline{\text{INT}}$  is low ("0") on the rising edge of the last clock of each instruction and the interrupt enable state (IFF = 1 and  $\overline{\text{BUSREQ}}$  signal=inactive ("1")) is on. The following is the processing to be performed after a non-maskable interrupt and a maskable interrupt are accepted:

(a) Non-maskable interrupt (NMI)

When a non-maskable interrupt has been accepted, the MPU performs the following processing:

- 1 The internal NMI flip-flop is reset to "0".
- 2 IFF1 is reset to "0", disabling the maskable interrupt.

The contents of the IFF1 immediately before the interrupt acceptance are copied into the IFF2.

- 3 The contents of the current program counter are saved into the stack.
- 4 The instructions starting from non-maskable interrupt vector address 66H are executed.

A non-maskable interrupt processing program terminates after executing the RETN instruction. This return instruction performs the followings:

- 1 The contents of the current IFF2 are copied into IFF1.
- 2 The contents of the program counter are restored from the stack.



Figure 3.5 Non-Maskable Interrupt Processing

(b) Maskable interrupt (INT)

When a maskable interrupt has been accepted, the MPU performs the following processings:

- 1 Both IFF1 and IFF2 are reset to "0", disabling the maskable interrupts.
- 2 The contents of the current program counter are saved into the stack.
- 3 A maskable interrupt is serviced in one of the three modes 0, 1 and 2. A mode is selected by executing the instruction IM0, IM1or IM2 before the interrupt is serviced. The instructions are executed starting from the vector address corresponding to the selected mode.

#### Mode 0

In mode 0, the interrupting peripheral LSI puts a restart instruction (RST) or a call instruction (CALL) on the data bus and the MPU executes the interrupt service routine according to that instruction. At reset, this mode is automatically set.



Figure 3.6 Interrupt Processing in Mode 0

#### • Mode 1

When an interrupt is accepted in mode 1, restart is performed from address 0038H. Therefore, the service routine for this interrupt is programmed from the address 0038H.



Figure 3.7 Interrupt Processing in Mode 1

#### • Mode 2

The interrupt processing in mode 2 requires a 16-bit pointer consisting of the high-order 8 bits of the I register and the low-order 8 bits (with the LSB = "0") of the data fetched from the TLCS-Z80 family peripheral LSI. Therefore, the necessary value must be loaded in the I register beforehand. This pointer is used to specify the memory address in the table. The contents of the specified address and the next address provide the start address of the service routine. Therefore, use of this mode requires the table of the service routine's start address (16 bits) to be set at appropriate location under software control. This location can be anywhere in memory.

The LSB of the table pointer is set to "0" because a 2-byte data is needed to specify the service routine start address in 16 bits and start that address from an even-number address. In the table, the start address begins with the low-order byte followed by the high-order byte as shown in Figure 3.8.



Figure 3.8 Interrupt Processing in Mode 2

Mode 2 is used in the daisy chain interrupt processing using TLCS-Z80 family LSI. TLCS-Z80 family peripheral LSIs all contain the interrupt priority controller in daisy chain structure. In this interrupt structure, the interrupt request signals are connected one after another and given priorities for processing when two or more maskable interrupt requests occur at a time. Only the interrupt vector from the peripheral LSI having the highest priority is put on the data bus. By receiving the interrupt vector in mode 2, the processing for that peripheral LSI can be performed. When an interrupt requested by a peripheral LSI having a priority higher than that of the current peripheral LSI during the execution of the interrupt processing routine, the higher priority interrupt can be enabled by the EI instruction to form an interrupt nesting.

The maskable interrupt processing program terminates by executing an RETI instruction. This return instruction performs the following processings:

- Restores the content of the program counter from the stack.
- Notifies the requesting peripheral LSI of the termination of interrupt processing.

#### 3.3 MPU STATUS TRANSITION DIAGRAM AND BASIC TIMING

The following describes the MPU status transition and the basic timing of each MPU operation.

#### [1] Instruction Cycle

Each TMPZ84C00A instruction is executed by combining the basic operations of memory read/write, input/output, bus request/acknowledge, and interrupt. These basic operations are performed synchronizing with the system clock (the CLK signal).

One clock period is called a state (T). The smallest unit of each basic operation is called a machine cycle (M). Each instruction consists of 1 to 6 machine cycles and each machine cycle consists of 3 to 6 clock states basically. However, the number of clock states in a machine cycle can be increased by the WAIT signal described later on. Figure 3.9 shows an example of the basic timing of a 3-machine-cycle instruction.

The first machine cycle (M1) of each instruction is the cycle in which the Opcode of the instruction to be executed next is read (this is called the Opcode fetch cycle). The Opcode fetch cycle basically consists of 4 to 6 clock states. In the machine cycle that follows the Opcode fetch cycle, data is transferred between the MPU and the memory or peripheral LSIs. This operation basically consists of 3 to 5 clock states.



Cycle instruction

060489

#### Figure 3.9 Example of MPU Basic Timing (3-Machine-Cycle Instruction)

TMPZ84C00A

#### [2] Status Transition Diagram





MPUZ80-22

#### [3] Basic Timing

(1) Opcode fetch cycle (M1)

In the Opcode fetch cycle, MPU fetches an Opcode in the machine-language codes in memory. This is also called the M1 cycle because it is the first machine cycle to execute each instruction.

Figure 3.11 shows the basic timing of a basic Opcode fetch cycle.

In clock state T1, the content of the program counter is put on the address bus. The  $\overline{\text{M1}}$  signal goes "0", indicating to the MPU that this is the Opcode fetch cycle. At the same time,  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals go "0". When the  $\overline{\text{MREQ}}$  signal goes "0", the address signal has already been stabilized. Therefore, this signal can be used for the memory chip enable signal. The  $\overline{\text{RD}}$  signal indicates that the MPU is ready to accept the data from memory. By these signals, the MPU accesses memory to fetch the Opcode in the instruction register. The MPU samples the  $\overline{\text{WAIT}}$  signal on the falling edge of clock state T2. If the  $\overline{\text{WAIT}}$  signal is "0" on the falling edge of clock state T2 and the following wait state (TW), the next state becomes clock state TW. Figure 3.12 shows the delay state of the Opcode fetch cycle caused by the  $\overline{\text{WAIT}}$  signal.

The data (Opcode) on the data bus is fetched on the rising edge of clock state T3 then, the  $\overline{\text{MREQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{M1}}$  signals go "1". In clock state T3, a memory refresh address is put on the low-order 8 bits of the address bus and the  $\overline{\text{RFSH}}$  signal goes "0" and the  $\overline{\text{MREQ}}$  signal goes "0" again. This signal indicates that the memory refresh cycle is on. At this time, the contents of the I register are put on the high-order 8 bits of the address bus and the 8 bits of the R register are put on the low-order 8 bits of the address bus. By using the  $\overline{\text{RFSH}}$  and  $\overline{\text{MREQ}}$  signals, memory refresh is performed in clock state T3 and T4. However, the  $\overline{\text{RD}}$  signal remains "1" because the contents of the memory refresh address are not put on the data bus.

In clock state T4, the  $\overline{\text{MREQ}}$  signal returns to "1". The refresh address is kept output until the rising edge of the clock state T1 in the next machine cycle, keeping the  $\overline{\text{RFSH}}$  signal set to "0". The cycle delay state caused by setting the  $\overline{\text{WAIT}}$ signal to "0" is the same in the memory read/write, input/output, and maskable interrupt acknowledge cycles. The diagram of the cycle delay state caused by the  $\overline{\text{WAIT}}$  signal set to "0" is omitted in the following description.
TOSHIBA









MPUZ80-24

#### (2) Memory read/write operations

Figure 3.13 shows the basic timing of memory read/write operations (except for the Opcode fetch cycle) in the same diagram for convenience.

In each operation, the memory address signal to read/write data on the address bus is output in clock clock state T1. The operation in which the  $\overline{\text{WAIT}}$  signal is sampled in clock state T2 and the following TW state is the same as the Opcode fetch cycle.

In memory read, memory data is put on the data bus by the address,  $\overline{\text{MREQ}}$ , and  $\overline{\text{RD}}$  signals. The MPU reads this data.

In memory write, the memory address signal is put on the address bus then the  $\overline{\text{MREQ}}$  signal is set to "0" to put the write data onto the data bus. When the data bus has been stabilized, the  $\overline{\text{WR}}$  signal is output in clock state T2. The WR signal can be used as the memory write signal.



Figure 3.13 Memory Read/Write Cycle Timing

#### (3) Input/output operations

Figure 3.14 shows the basic timing of input/output operations. The feature of the I/O operation timing is that, regardless of the state of the WAIT signal in clock state T2, the I/O cycle automatically goes in the wait state (TW\*) after clock T2. The WAIT signal is sampled on the falling edge of TW\*. If the WAIT signal is "0" on the falling edges of TW\* and the following clock state, the I/O operation enters into clock state TW\*. Clock state TW\* is inserted because the  $\overline{IORQ}$  signal goes "0" in clock state T2, so that it is too late to sample the WAIT signal after decoding the I/O port address. In each of input and output operations, the I/O port address is put on the low-order 8 bits of the address bus in clock state T1. On the high-order 8 bits, the contents of the accumulator or B register are output. In clock state T2, the  $\overline{IORQ}$  signal goes "0" instead of the MREQ signal. The  $\overline{IORQ}$  signal can be used as the chip enable signal for a peripheral LSI.

In an input operation, the contents of the input port are read onto the data bus by the address,  $\overline{\text{IORQ}}$ , or  $\overline{\text{RD}}$  signals. The MPU reads this data.

In an output operation, the output port address and the output data are respectively put on the address bus and data bus in clock state Tl, then the  $\overline{IORQ}$  and  $\overline{WR}$  signals go "0" in clock state T2. The  $\overline{WR}$  signal can be used as the output port write signal.



Figure 3.14 I/O Operating Timing

MPUZ80-26

#### (4) Bus request and bus acknowledge operations

Figure 3.15 shows the basic timing of bus request and bus acknowledge operations.

The address bus (A0 through A15), data bus (D0 through D7),  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{WR}}$  signals controlled by the MPU can be put in the high-impedance state (floating) to electrically disconnect them from the MPU. This operation, after sampling the  $\overline{\text{BUSREQ}}$  signal on the rising edge of the last clock of each machine cycle, starts on the rising edge of the next clock if this signal is found "0".

Subsequently, these buses are controlled by external peripheral LSIs. For example, data can be directly transferred between memory and these peripheral LSIs. This state is cleared if the <u>BUSREQ</u> signal is found "1" after sampling it on the rising edge of each subsequent clock state (TX), and enters into the next machine cycle. During the floating state, the <u>BUSACK</u> signal goes "0" to indicate it to the peripheral LSIs.

In this state, however, no memory refresh is performed and, therefore, the  $\overline{\text{RFSH}}$  signal is set to "1". Hence, to maintain this state for a long time with a system using dynamic memory, memory refresh must be performed by the external controller.

Note that, in the floating state, neither maskable interrupt (INT) nor nonmaskable interrupt (NMI) can be accepted.



Figure 3.15 Bus Request and Bus Acknowledge Timing

(5) Maskable interrupt acknowledge operation

Figure 3.16 shows the basic timing of the maskable interrupt acknowledge.

The MPU samples the maskable interrupt request signal (INT) on the rising edge of the last clock of each instruction execution. If the INT signal is found "0", a maskable interrupt is accepted except in the following cases:

- The interrupt enable flip-flop is reset to "0".
- The **BUSREQ** signal is "0".

When a maskable interrupt has been accepted, a special Opcode fetch cycle is generated. In this cycle, 2 clock states of wait state (TW\*) is automatically inserted after the clock state T2. The WAIT signal is sampled on the falling edges of the second clock state TW\* and the following clock state TW and, if the WAIT signal is found "0", the instruction cycle enters in the next clock state TW. In this Opcode fetch cycle, the  $\overline{IORQ}$  signal goes "0" in the first TW\* state instead of the MREQ signal while, in a normal Opcode fetch cycle, the  $\overline{MREQ}$  signal goes "0" in clock state T1. This indicates to the maskable interrupt requesting LSI that the 8-bit interrupt vector can be put on the data bus. The MPU reads this data to perform interrupt processing. Therefore, the contents of the program counter put on the address bus are not used. Unlike an ordinary I/O operation, the  $\overline{RD}$  signal does not go "0".

In clock state T3, the memory refresh address signal is put on the address bus for memory refresh like normal Opcode fetch cycle and the  $\overline{\text{RFSH}}$  signal goes "0". In the subsequent machine cycles (M2 and M3), the contents of the current program counter are saved into the stack. In machine cycles M4 and M5, the contents of the I register (the high-order 8 bits) and the contents of the address indicated by the address of the vector (the low-order 8 bits) from the peripheral LSI are fetched in the program counter.



Figure 3.16 Maskable Interrupt Acknowledge Timing

#### (6) Non-maskable interrupt acknowledge operation

Figure 3.17 shows the basic timing of non-maskable interrupt acknowledge.

When the non-maskable interrupt request signal ( $\overline{\text{NMI}}$ ) goes low, the internal non-maskable flip-flop is set to "1". The  $\overline{\text{NMI}}$  signal is detected in any timing of each instruction. However, the internal NMI flip-flop is sampled on the rising edge of the last clock of each instruction. Therefore, the  $\overline{\text{NMI}}$  signal should go low by the last clock state of an instruction.

The Opcode fetch cycle for non-maskable interrupt request acknowledge is generally the same as the ordinary Opcode fetch cycle. However, the Opcode on the data bus at the time is ignored. The contents of the current program counter are saved into the stack in the subsequent machine cycles (M2 and M3). In the following machine cycle, the operation jumps to address 0066H, the non-maskable interrupt vector address. The machine cycles after these depend on the contents of the fetched Opcode.

### TOSHIBA



Figure 3.17 Non-Maaskable Inpterrupt Acknowledge Timing

#### (7) Halt operation

When a HALT instruction is fetched in the Opcode fetch cycle, the MPU sets the  $\overline{\text{HALT}}$  signal to "0" synchronized with the falling edge of clock state T4 to indicate it to the peripheral LSI and stops operating. If the system clock is kept supplied in the halt state, the MPU continues executing NOP instructions. This is done to output refresh signals when the dynamic memory is used. The NOP instruction execution cycle is the same as the ordinary Opcode fetch cycle except the data on the data bus are ignored.

The halt state is cleared when an interrupt is accepted or the RESET signal is set to "0" to reset the MPU. Figure 3.18 shows the halt state clear operation by interrupt acknowledge. An interrupt is sampled on the rising edge of the last clock (clock state T4) of the NOP instruction. A maskable interrupt can be accepted when the  $\overline{\text{INT}}$  signal is "0". A non-maskable interrupt is accepted when the internal NMI flip-flop which is set on the falling edge of the  $\overline{\text{NMI}}$  signal is set at "1". However, it is required that the interrupt enable flip-flop is set to "1" for a maskable interrupt to be accepted. The interrupt processing for the accepted interrupt starts from the next cycle. However, when the supply of the system clock has been stopped by the power down operation, it is required to restart the supply of the system clock and input the  $\overline{INT}$  signal until the execution of one instruction is completed or the  $\overline{RESET}$  signal until 3 clocks are input. Figure 3.19 shows the timing of clearing the halt state caused by power down. By using TLCS-Z80's clock generator/controller (TMPZ84C60P or TMPZ84C61AP), above-stated operation is realized easily.

For the reset operation, see (8) "Reset operation". Note that the  $\overline{INT}$  and  $\overline{NMI}$  signals are shown on the same diagram in Figures 3.18 and 3.19 for convenience.



Figure 3.18 Timing of Clearing Halt State Caused by Interrupt Acknowledge



Figure 3.19 Timing of Clearing Halt State Caused By Power Down



#### (8) Reset operation

Figure 3.20 shows the basic timing of reset operation.

To reset the MPU, the  $\overline{\text{RESET}}$  signal must be kept at "0" for at least 3 clocks. When the  $\overline{\text{RESET}}$  signal goes "1", instruction execution starts from address 0000H after a dummy cycle of at least 2 clock states.





## 3.4 TMPZ84C00A INSTRUCTION SET

This subsection lists the TMPZ84C00A instruction codes and their functions. The table below lists the symbols and abbreviations used to describe the instruction set. The symbols which require special attention are described in the locations in which they appear.

### • Symbols (1/2)

| Classification | Symbol          | Meaning                                       |
|----------------|-----------------|-----------------------------------------------|
| Register       | r, g            | Register B, C, D, E, H, L, A,                 |
|                | t               | Register pair BC, DE, HL                      |
|                |                 | Stack pointer SP                              |
|                | q               | Register pair BC, DE, HL, AF                  |
|                | р               | Register pair BC, DE                          |
|                |                 | Index register IX                             |
|                |                 | Stack pointer SP                              |
|                | s               | Register pair BC, DE                          |
|                |                 | Index register IY                             |
|                |                 | Stack pointer SP                              |
|                | t <sub>H</sub>  | Higher register of register pair              |
|                |                 | (B, D, H)                                     |
|                |                 | Higher 8 bits of stack pointer (SP)           |
|                | qн              | Higher register of register pair              |
|                |                 | (B, D, H, A)                                  |
|                | IX <sub>H</sub> | Higher 8 bits of index register IX            |
|                | IY <sub>H</sub> | Higher 8 bits of index register IY            |
|                | PCH             | Higher 8 bits of program counter (PC)         |
|                | tL              | Lower register of register pair               |
|                |                 | (C, E, L)                                     |
|                |                 | Lower 8 bits of stack pointer (SP)            |
|                | qL              | Lower register of register pair               |
|                |                 | (C, E, L, F)                                  |
|                | IXL             | Lower 8 bits of index register IX             |
|                | IYL             | Lower 8 bits of index register IY             |
|                | PCL             | Lower 8 bits of program counter (PC)          |
|                | rb              | Bit b (0-7) of register (B, C, D, E, H, L, A) |

• Symbols (2/2)

| Classification     | Symbol                                                                    | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory             | mn<br>(HL) <sub>b</sub><br>(IX + d) <sub>b</sub><br>(IY + d) <sub>b</sub> | Memory address represented in 16 bits.<br>m indicates higher 8 bits and n, lower 8 bits.<br>Bit b (0-7) of the contents of the memory<br>address indicated by register pair HL.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IX.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IX. |
| Flag change symbol | 0<br>1<br>-<br>*<br>X<br>P                                                | Reset to "0" by operation.<br>Set to "1" by operation.<br>No change<br>Affected by operation<br>Undefined<br>Handled as parity flag.<br>P = 0: odd parity<br>P = 1: even parity<br>Handled as overflow flag.<br>V = 0: No overflow<br>V = 1: Overflow                                                                                                                                                                                                                                               |
| Operator           | ↔<br>+<br>-<br>\<br>V                                                     | Transfer<br>Exchange<br>Add<br>Subtract<br>Logical and between bits.<br>Logical or between bits.<br>Exclusive or between bits                                                                                                                                                                                                                                                                                                                                                                       |
| Others             | IFF<br>CY<br>Z                                                            | Interrupt enable flip-flop<br>Carry flag<br>Zero flag                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## TMPZ84C00A Instruction Set (1/9)

| ITEM/<br>CLASSI | Assembler                | Object                                 | code          |                    |                     |       |        | F |        |          | NO.<br>OF | No.<br>OF |               |         |                |
|-----------------|--------------------------|----------------------------------------|---------------|--------------------|---------------------|-------|--------|---|--------|----------|-----------|-----------|---------------|---------|----------------|
| -FICA-          | mnemonic                 | Binary<br>76 543 210                   | Hex           | Function           | s                   | z     |        | н |        | P/V      | N         | c         | CY.<br>CLES   | STA-    |                |
|                 | LD r,g                   | 01 rrr ggg                             | 40+r × 8+g    | r←g                | <del>.</del>        |       | X      | - | . X    |          |           | -         | 1             | 4       |                |
|                 |                          | nn nnn nnn<br>01 ccc 110               | n<br>46+r×8   | ····               |                     |       | Ŷ      | _ | ^<br>  | _        |           |           | 2<br>2        | ,,<br>7 | g ggg          |
|                 | LD r,(IX+d)              | 11 011 101<br>01 rrr 110               | DD<br>46+r×8  | r←(IX+d)           | -                   | -     | x      | - | x      | -        | -         | -         | 5             | 19      | C 001          |
|                 | LD r,(IY+d)              | dd ddd ddd<br>11 111 101               | d<br>FD       |                    |                     | -     | x      | - | <br>Х  | _        | _         | -         | 5             |         | E 011<br>H 100 |
| [               |                          | 01 rrr 110<br>dd ddd ddd               | 46+r×8<br>d   |                    |                     |       |        |   |        |          |           |           |               |         | L 101<br>A 111 |
|                 | LD (HL),r<br>LD (IX+d),r | 01 110 rrr<br>11 011 101               | 70+r<br>DD    | (HL)←r<br>(IX+d)←r | <del>.</del> .<br>- | -     | X<br>X | - | X<br>X | -        | -         | -         | <u>2</u><br>5 | 7<br>19 |                |
|                 | LD (IY+d),r              | dd ddd ddd<br>11 111 101               | d<br>FD       |                    | <br>-               |       | x      |   | x      |          |           | -         | 5             |         |                |
| ΑD              |                          | 01 110 rrr<br>dd ddd ddd               | 70+r<br>d     |                    |                     |       |        |   |        |          |           |           |               |         |                |
| ۲ O             | LD (HL),n                | 00 110 110<br>nn nnn nnn               | 36<br>n       | (HL)+n             | -                   | -     | x      | - | X      | -        | -         | -         | 3             | 10      |                |
| A T A           | LD (IX+d), n             | 11 011 101<br>00 110 110               | DD<br>36      | (IX+d)←n           | -                   | -     | x      | - | х      | -        | -         | -         | 5             | 19      |                |
| 0               | LD (IY+d),n              | nn nnn nnn<br>11 111 101               | n<br>FD       |                    | <br>_               | ····· | x      | - | <br>X  | -        | -         | -         | 5             |         |                |
| 8 1             |                          | 00 110 110<br>dd ddd ddd               | 36<br>d       |                    |                     |       |        |   |        |          |           |           |               |         |                |
| ,<br>∞          | LD A,(BC)                | nn nnn nnn<br>00 001 010               | n<br>OA       | A←(BC)             | <u>.</u> .          |       | x      | - | x      |          | -         | -         | 2             | 7       |                |
|                 | LD A,(DE)<br>LD A,(mn)   | 00 011 010<br>00 111 010<br>nn nnn nnn | 1A<br>3A<br>n | A←(DE)<br>A←(mn)   | . <u>-</u><br> -    | -     | x      | - | x      | -        | -         | -         | <u>2</u><br>4 | 7<br>13 |                |
|                 | LD (BC),A                | mm mmm mmm<br>00 000 010               | m<br>02       | (BC)+A             | <u>-</u>            |       | x      |   | x      | <u>-</u> |           | -         | 2             | 7.      |                |
|                 | LD (DE),A<br>LD (mn),A   | 00 010 010<br>00 110 010               | 12<br>32<br>n | (DE)←A<br>(mn)←A   | -                   | -     | x      | - | x      | -        | -         | -         | 2<br>4        |         |                |
|                 | LD A,I                   | mm mmm mmm<br>11 101 101               | m<br>ED       | A←I                | •                   | *     | x      | 0 | x      | IFF      | 0         | -         | 2             | 9       |                |
|                 | LD A,R                   | 01 010 111                             | 57<br>ED      | A←R                | •                   | ٠     | x      | 0 | x      | IFF      | 0         | -         | 2             | 9       |                |
|                 | LD I,A                   | 11 101 101<br>01 000 111               | ED<br>47      | I←A                | -                   | -     | x      | - | x      | -        | -         | -         | 2             | 9       |                |
|                 | LD R,A                   | 11 101 101<br>01 001 111               | ED<br>4F      | R←A                | -                   | -     | x      | - | x      | -        | -         | -         | 2             | 9       |                |
| DATA<br>LOAD    | LD t,mn                  | 00 tt0 001<br>nn nnn nnn               | 01+t×10<br>n  | t←mn               | -                   | -     | х      | - | х      | -        | -         | -         | 3             | 10      | t tt<br>BC 00  |
| E - 1           | LD IX,mn                 | 11 011 101<br>00 100 001               | DD<br>21      | IX←mn              | -                   | -     | x      | - | x      | -        | -         | -         | 4             | 14      | DE 01<br>HL 10 |
| 16-             |                          | ոռ որը որը<br>տա ատա տատ               | n<br>m        |                    |                     |       |        |   |        |          |           |           |               |         | SP 11          |

Note : r,g means any of the registers A, B, C, D, E, H, L.

IFF in "Flag" column indicates that the content of the interrupt enable flip-flop is copied into the P/V flag.

120489

----

# TMPZ84C00A Instruction Set (2/9)

| ITEM/            | Assembler   | Object code Flag |       |     |           |                                               |       |       |          |          |          |                    |         |     | No.        | No.        |       |
|------------------|-------------|------------------|-------|-----|-----------|-----------------------------------------------|-------|-------|----------|----------|----------|--------------------|---------|-----|------------|------------|-------|
| CLASSI<br>-FICA- | mnemonic    |                  | Bin   | ary | Hex       | Function                                      |       |       |          |          |          |                    |         |     | OF<br>CY-  | OF<br>STA- |       |
| TION             | 1           | 76               | 543   | 210 |           |                                               | s     | Z     |          | н        |          | P/V                | N       | с   | CLES       | TES        |       |
|                  | LD IY,mn    | 11               | 111   | 101 | FD        | IY←mn                                         | -     | -     | X        | -        | Х        | -                  | -       | -   | 4          | 14         |       |
|                  |             | 00               | 100   | 001 | 21        |                                               |       |       |          |          |          |                    |         |     | ]          |            |       |
|                  |             | nn               | nnn   | nnn | n         |                                               | 1     |       |          |          |          |                    |         |     | l          |            |       |
|                  |             | mm               | mmm   |     | _ m       | U: / (1)                                      | ļ     |       |          |          | <u>.</u> |                    |         |     | <u>.</u> . |            |       |
|                  | LD HL,(mn)  | 00               | 101   | 010 | ZA        |                                               | -     | -     | ×        | -        | ×        | -                  | -       |     | 5          | 16         | BC 00 |
|                  |             | <br>             | mmm   | mmm | m         |                                               | l     |       |          |          |          |                    |         |     |            |            | DE 01 |
|                  | LD t.(mn)   | 11               | 101   | 101 | ED        | <br>tu←(mn+1)                                 | ····· |       | x        |          | x        |                    | _       | _   | 6          | 20         | HL 10 |
| 1                |             | 01               | tt1   | 011 | 4B+t × 10 | tl+(mn)                                       |       |       |          |          |          |                    |         |     |            |            | SP 11 |
|                  |             | nn               | nnn   | nnn | n         |                                               |       |       |          |          |          |                    |         |     | ļ          |            |       |
|                  |             | mm               | mmm   | mmm | m         |                                               | l     |       |          |          |          | [                  |         |     | l          |            |       |
|                  | LD IX,(mn)  | 11               | 011   | 101 | DD        | IX <sub>H</sub> ←(mn+1)                       | -     | -     | Х        | -        | Х        | -                  | -       | -   | 6          | 20         |       |
|                  |             | 00               | 101   | 010 | 2A        | IXL←(mn)                                      |       |       |          |          |          |                    |         |     |            | 1          |       |
| l                |             | nn               | nnn   | nnn | n         |                                               |       |       |          |          |          |                    |         |     |            | 1          |       |
| 0                |             | mm               | mmm   | mmm | _ m       |                                               | l     |       |          |          |          |                    |         |     |            |            |       |
| ∢                | LU IY, (mn) | 11               | 111   | 101 | FU        | [ 1YH←(mn+1)                                  | -     | -     | ×        | -        | ×        | -                  |         | -   | 6          | 20         |       |
| Ľ.               |             | 00               | 101   | 010 | 24        | [11[~(mn)                                     | 1     |       |          |          |          |                    |         |     |            |            |       |
|                  |             | mm               | mmm   |     | m         |                                               | 1     |       |          |          |          |                    |         |     |            |            |       |
| ∢                | LD (mn).HI  | 00               | 100   | 010 | 22        | (mn+1) ←H                                     | ····· | ·     | ¥        | ·        | y        | · · · <u>-</u> · · | · · _ · |     | 5          |            |       |
|                  |             | nn               | nnn   | nnn | n         | (mn)+L                                        |       |       | î        |          | î        |                    |         |     | ľ          |            |       |
|                  |             | mm               | mmm   | mmm | m         | 4                                             |       |       |          |          |          |                    |         |     |            |            |       |
|                  | LD (mn),t   | 11               | 101   | 101 | ED        | (mn+1)←t <sub>H</sub>                         | -     | -     | X        | -        | X        |                    | -       | -   | 6          | 20         |       |
| ⊢                |             | 01               | tt0   | 011 | 43+t×10   | (mn)←tL                                       |       |       |          |          |          |                    |         |     | ļ          | , i        |       |
|                  |             | nn               | nnn   | nnn | n         |                                               |       |       |          |          |          |                    |         |     |            |            |       |
|                  | }           | mm               | mmm   | mmm | m         |                                               | l     | i     | <u>.</u> | <u>.</u> |          | <u>.</u>           |         |     |            |            |       |
| v                | LD (mn),IX  | 11               | 011   | 101 | DD        | (mn+1)←IX <sub>H</sub>                        | -     | -     | X        | -        | Х        | -                  | -       | -   | 6          | 20         |       |
| -                |             | 00               | 100   | 010 | 22        | (mn)←IXL                                      |       |       |          |          |          |                    |         |     |            |            |       |
| 1                |             | nn               | nnn   | nnn | n         |                                               |       |       |          |          |          |                    |         |     | 1          |            |       |
|                  |             |                  | 111   | 101 | <br>      | (mp+1) (TV)                                   | l     | ····· |          |          |          |                    |         |     |            |            |       |
|                  | (),11       |                  | 100   | 010 | 22        | (mn) + IY                                     | -     | -     | ^        | -        | ^        | -                  | -       |     | 0          | 20         |       |
|                  |             |                  | 000   | nnn | 1         |                                               |       |       |          |          |          |                    |         |     | 1          |            |       |
|                  |             | mm               | ៣៣៣   | mmm | m         | 1                                             |       |       |          |          |          |                    |         |     | 1          |            |       |
|                  | LD SP,HL    | 11               | 111   | 001 | F9        | SP←HL                                         | - 1   | -     | X        | _        | x        | -                  | -       | -   | 1          | 6          |       |
|                  | LD SP,IX    | 11               | 011   | 101 | DD        | SP←IX                                         | - 1   | -     | X        | -        | X        | -                  | -       | -   | 2          | 10         |       |
|                  |             | 11               | 111   | 001 | F9        | }                                             | l     |       |          |          |          |                    |         |     | l          | l          | l     |
|                  | LD SP,IY    | 11               | 111   | 101 | FD        | SP+IY                                         | -     | -     | X        | -        | х        | -                  | -       | -   | 2          | 10         |       |
|                  |             | 11               | .111  | 001 | F9        |                                               | l     | ļ     |          | ļ        |          | ļ                  |         |     |            |            |       |
|                  | PUSH q      | 11               | qq0   | 101 | C5+q×10   | (SP-2)←qL,(SP-1)←qH,                          | -     | -     | X        | -        | X        | -                  | -       | -   | 3          | 11         | 9 99  |
|                  |             |                  |       |     |           | SP←SP−2                                       | Į     | ļ     |          |          |          | ļ                  |         |     |            |            | BC UU |
|                  | PUSH IX     | 11               | 011   | 101 | 00        | (SP-2)←IXL,(SP-1)←IXH                         | -     | -     | X        | -        | X        | -                  | -       | -   | 4          | 15         |       |
|                  |             |                  | 111   | 101 | 50        | (SD_2)_TV. (SD_1)_TV.                         | ł     | ļ     |          |          |          |                    |         |     |            |            | AF 11 |
| 1                | POSIT IT    | 111              | 100   | 101 | 55        | SD_SD_2                                       | -     | -     | : ^      | -        | : ^      | -                  | : -     | -   | 4          | 15         |       |
|                  | POP a       | 111              | 000   | 001 | C1+a × 10 | $a_{\mu \pm}(SP\pm 1), a_{\mu} \pm (SP)$      | ····· | ·     | y Y      | ·        | <br>Y    | ··· <u> </u>       |         |     |            | 10         |       |
|                  |             | [ ]              | 190   |     |           | SP←SP+2                                       | 1     |       | : ^      |          | : ^      |                    | :       |     | ľ          | 1          |       |
|                  | POP IX      | 11               | 011   | 101 | DD        | IX <sub>H</sub> ←(SP+1),IX <sub>I</sub> ←(SP) | 1 -   |       | X        | <br>     | X        | ;                  | <br>    | -   | 4          | 14         |       |
|                  |             | 11               | 100   | 001 | E1        | SP+SP+2                                       | 1     |       |          |          |          |                    |         |     | 1          | 1          |       |
|                  | POP IY      | 11               | 111   | 101 | FD        | IY <sub>H</sub> ←(SP+1),IY <sub>L</sub> ←(SP) | -     | :     | X        | -        | X        | [ -                | - 1     | -   | 4          | 14         | 1     |
|                  |             | 11               | . 100 | 001 | E1        | SP←SP+2                                       |       |       | :        |          |          |                    | 1       |     |            |            |       |
| -1               | EX DE,HL    | 11               | 101   | 011 | EB        | DE⇔HL                                         | -     | -     | X        | -        | X        | -                  | -       | -   | 1          | 4          | ]     |
| 1 *'             | EX AF, AF'  | 00               | 001   | 000 | 08        | AF⇔AF′                                        | -     | -     | X        | -        | X        | -                  | -       | -   | 1          | 4          | l I   |
| I I              | EXX         | 11               | 011   | 001 | D9        | BC⇔BC',DE⇔DE',HL↔HL'                          | 1 -   | : -   | ΞX       | : - '    | ΞX       | : - `              | : - ·   | - 1 | 1 1        | 4          | 1     |

Note : t is any of the register pairs BC, DE, HL, SP.

q is any of the register pairs AF, BC, DE, HL. (PAIR)<sub>H</sub>, (PAIR)<sub>L</sub> refer to high order and low order eight bits of the register pair respectively. (Ex) BC<sub>L</sub> = C, AF<sub>H</sub> = A.

MPUZ80-36

120489

\*1 : EXCHANGE

# TMPZ84C00A Instruction Set (3/9)

| ITEM/<br>CLASSI        | Assembler                  | Object                                 | code           |                                                                                             |   |    |            | F      | lag    |           |        |   | No.<br>OF     | No.<br>OF |                          |
|------------------------|----------------------------|----------------------------------------|----------------|---------------------------------------------------------------------------------------------|---|----|------------|--------|--------|-----------|--------|---|---------------|-----------|--------------------------|
| -FICA-                 | mnemonic                   | Binary                                 | Hex            | Function                                                                                    |   | ., |            | ц      |        |           | N      |   | CY-           | STA-      |                          |
| U D N                  | EX (SP),HL<br>EX (SP),IX   | 11 100 011<br>11 011 101               | E 3<br>DD      | H⇔(SP+1),L⇔(SP)<br>IX <sub>H</sub> ⇔(SP+1)                                                  |   | -  | X<br>X     | -<br>- | x      | -         | -      | - | 5<br>6        | 19<br>23  |                          |
| хсна                   | EX (SP),IY                 | 11 100 011<br>11 111 101<br>11 100 011 | E3<br>FD       | $IX_{L} \leftrightarrow (SP)$ $IY_{H} \leftrightarrow (SP+1)$ $IX_{L} \leftrightarrow (SP)$ | - | -  | x          | -      | x      | -         | -      | - | 6             | 23        |                          |
| <u> </u>               | LDI                        | 11 101 101                             | ED             | (DE)←(HL),DE←DE+1                                                                           | - | -  | x          | 0      | x      | *м        | 0      | - | 4             | 16        |                          |
|                        | LDIR                       | 10 100 000<br>11 101 101<br>10 110 000 | A0<br>ED<br>B0 | HL+HL+1,BC+BC−1<br>(DE)+(HL),DE+DE+1<br>HL+HL+1,BC+BC−1 Repeatuntil<br>PC-0                 | - | -  | X          | 0      | x      | 0         | 0      | - | 5<br>4        | 21<br>16  | ←[BC< >0]<br>←[BC=0]     |
| ш<br>ш<br>ц Т          | LDD                        | 11 101 101                             | ED             | (DE)+(HL),DE+DE-1                                                                           | - | -  | x          | 0      | x      | *м        | 0      | - | 4             | 16        |                          |
| T R A N S<br>S E A R O | LDDR                       | 11 101 101<br>10 111 000               | ED<br>B8       | (DE)←(HL),DE+DE-1<br>HL+HL-1,BC+BC-1 Repeat until                                           | - | -  | x          | 0      | x      | 0         | 0      | - | 5<br>4        | 21<br>16  | ←[BC< >0]<br>←[BC=0]     |
| ××<br>v v              | CPI                        | 11 101 101<br>10 100 001               | ED<br>A1       | A-(HL)<br>HL←HL+1.BC←BC-1                                                                   | • | *N | x          | ٠      | x      | *м        | 1      | - | 4             | 16        |                          |
| B L O<br>B L O         | CPIR                       | 11 101 101<br>10 110 001               | ED<br>B1       | A-(HL),HL←HL+1,BC←BC-1<br>Repeat until A=(HL) or BC=0                                       | • | *N | X          | ٠      | X      | *м        | 1      | - | 5             | 21<br>16  | ←[BC< >0 &<br>A< > (HL)] |
|                        | CPD                        | 11 101 101<br>10 101 001               | ED<br>A9       | A-(HL)<br>HL←HL-1,BC←BC-1                                                                   | • | *N | X          | ٠      | x      | *м        | 1      | - | 4             | 16        | ⊾[BC=0 or<br>A= (HL)]    |
|                        | CPDR                       | 11 101 101<br>10 111 001               | ED<br>B9       | A-(HL),HL←HL-1,BC←BC-1<br>Repeat until A=(HL)or BC=0                                        | * | *N | х          | ٠      | х      | *м        | 1      | - | 5<br>4        | 21<br>16  | ←[BC< >0 &<br>A< > (HL)] |
|                        | ADD A,r<br>ADD A,n         | 10 000 rrr<br>11 000 110               | 80+r<br>C6     | A+A+r<br>A+A+n                                                                              | * | *  | X<br>X     | *      | X<br>X | v<br>v    | 0<br>0 | * | <u>1</u><br>2 | . 4<br>7  | ≮[BC≖0 or<br>A= (HL)]    |
|                        | ADD A,(HL)                 | 10 000 110                             | 86             | A←A+(HL)                                                                                    | * | *  | x          | ٠      | x      | v         | 0      | * | 2             | 7         |                          |
| ΑΓ                     | ADD A,(IX+d)               | 11 011 101<br>10 000 110<br>dd ddd ddd | DD<br>86<br>d  | A+A+(IX+d)                                                                                  | • | ٠  | х          | ٠      | х      | v         | 0      | ٠ | 5             | 19        | B 000<br>C 001           |
| 000                    | ADD A,(IY+d)               | 11 111 101<br>10 000 110               | FD<br>86       | A+A+(IY+d)                                                                                  | • | *  | x          | •      | х      | v         | 0      | * | 5             | 19        | E 011<br>H 100           |
| -                      | ADC A.r                    | 10 001 rrr                             | 88+r           | A+A+r+CY                                                                                    |   |    | ¥          |        |        | · · · · · | 0      | • | 1             |           | L 101                    |
| DND                    | ADC A,n                    | 11 001 110                             | CE             | A+A+n+CY                                                                                    | • | ٠  | x          | ٠      | x      | v         | 0      | • | 2             | 7         | A 111                    |
| ETIC                   | ADC A,(HL)<br>ADC A,(IX+d) | 10 001 110<br>11 011 101<br>10 001 110 | 8E<br>DD<br>8E | A+A+(HL)+CY<br>A+A+(IX+d)+CY                                                                | * | *  | X<br>X     | •      | X<br>X | V<br>V    | 0<br>0 | * | 2<br>5        | 7<br>19   |                          |
| RITHM                  | ADC A,(IY+d)               | dd ddd ddd<br>11 111 101<br>10 001 110 | d<br>FD<br>8E  | A+A+(IY+d)+CY                                                                               | • | •  | X          | •      | x      | v         | 0      | ٠ | 5             | 19        |                          |
| ∢                      | SUB r                      |                                        | 0<br>00+c      | Δ+Δ-r                                                                                       |   |    |            |        | ·      | ···       | ·····  |   |               |           |                          |
| 1 - 8                  | SUB n                      | 11 010 110                             | D6             | A←A~n                                                                                       | * | ٠  | x          | ٠      | <br>X  | v         | 1      | ٠ | 2             | 7         |                          |
| 8                      | SUB (HL)                   | 10 010 110                             | 96<br>DD       | A←A-(HL)<br>A←A-(IX+d)                                                                      | * | *  | . X<br>. Y |        | X      | V         |        | • | 2             | 7         | a second                 |
|                        | (10.0)                     | 10 010 110<br>dd ddd ddd               | 96<br>d        | ···· (-··-)                                                                                 |   |    | Â          |        | Â      |           | •      |   |               | 13        |                          |
|                        | SUB (IY+d)                 | 11 111 101<br>10 010 110<br>dd ddd ddd | FD<br>96<br>d  | A←A-(IY+d)                                                                                  | * | ٠  | x          | ٠      | X      | v         | 1      | ٠ | 5             | 19        |                          |

Note : \*M P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1.

\*N Z flag is 1 if A = (HL), otherwise Z = 0.

[ ]indicates the total condition of the number of cycles and states indicated by arrow.

r means any of the registers A, B, C, D, E, H, L.

## TMPZ84C00A Instruction Set (4/9)

| ITEM/ Object code                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | No. No.                                                                                             |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------|
| -FICA- mnemonic Binary Hex Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Plag OF OF CY- STA-                                                                                 |
| TION 76 543 210                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | S Z H P/V N C CLES TES                                                                              |
| SBC A, r 10 011 rrr 98+r A+A-r-CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | * * X * X V 1 * 1 4 r rrr                                                                           |
| SBC A,n 11 011 110 DE A+A-n-CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | * * X * X V 1 * 2 7 B 000                                                                           |
| SBC A (H) 10 011 110 0F A+A-(H) -CV                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                     |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | $\bullet$ |
| 10 011 110 9E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | H 100                                                                                               |
| dd ddd ddd d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | L 101                                                                                               |
| SBC A,(IY+d) 11 111 101 FD A←A−(IY+d)−CY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | * * X * X V 1 * 5 19 <u>A 111</u>                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | • • X 1 X P 0 0 1 4                                                                                 |
| ✓ AND n 11 100 110 E6 A+A∧n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | * * X 1 X P 0 0 2 7                                                                                 |
| U nn nnn nn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                     |
| AND (HL) 10 100 110 A6 A+A^(HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | * * X 1 X P 0 0 2 7                                                                                 |
| O AND (IX+d) 11 011 101 DD A+A∧(IX+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | * * X 1 X P 0 0 5 19                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | * * X 1 X P 0 0 5 19                                                                                |
| Z 10 100 110 A6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
| dd ddd dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                     |
| U OR r 10 110 rrr B0+r A+A∨r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | * * X 0 X P 0 0 1 4                                                                                 |
| - OR n  11 110 110 F6  A←A∨n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | * * X 0 X P 0 0 2 7                                                                                 |
| $\begin{array}{c} \cdot \\ \bullet \\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                     |
| $\geq$ OR (IX+d) 11 011 101 DD A+A $\vee$ (IX+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | * * X 0 X P 0 0 5 19                                                                                |
| 10 110 110 B6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                     |
| - dd ddd ddd d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                     |
| $ \begin{array}{c c} & & \\ \hline \\ \hline$ | * * X 0 X P 0 0 5 19                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
| $ \begin{array}{c c} & & & \\ \hline \\$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | * * X 0 X P 0 0 1 4                                                                                 |
| ∞ XOR n 11 101 110 EE A+A∀n                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | * : * : X : 0 : X : P : 0 : 0 2 7                                                                   |
| nn nnn nn                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                     |
| ∞         XOR         (HL)         10         101         110         AE         A←A∀(HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | • • X 0 X P 0 0 2 7                                                                                 |
| XOR (IX+d) 11 011 101 DD A←A∀(IX+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | * * X 0 X P 0 0 5 19                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
| XOR (IY+d) 11 111 101 FD A←A∀(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | • • X 0 X P 0 0 5 19                                                                                |
| 10 101 110 AE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                     |
| dd ddd dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                     |
| CP r 10 111 rrr B8+r A-r                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | * * X * X V 1 * 1 4                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
| CP (HL) 10 111 110 BE A-(HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | * * X * X V 1 * 2 7                                                                                 |
| CP (IX+d) 11 011 101 DD A-(IX+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | * * X * X V 1 * 5 19                                                                                |
| 10 111 110 BE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                     |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                     |
| 10 111 110   FD   A-(1Y+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | <b>* *</b> X <b>*</b> X <b>V 1 *</b> 5 19                                                           |
| dd ddd ddd d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                     |
| INC r 00 rrr 100 04+r×8 r+r+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * * X * X V 0 - 1 4                                                                                 |
| INC (HL) 00 110 100 34 (HL)+(HL)+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | * * X * X V 0 - 3 11                                                                                |
| INC (IX+d) 11 011 101 DD (IX+d)+(IX+d)+1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | *   *   X   *   X   V   0   -   6   23                                                              |
| 00 110 100 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                                                                     |

Note : r means any of the registers A, B, C, D, E, H, L.

## TMPZ84C00A Instruction Set (5/9)

| ITEM/<br>CLASSI | Assembler  | Object     | code        |                            |       |   |     | F         | lag       |                |          |                | No.<br>OF | No.<br>OF |         |
|-----------------|------------|------------|-------------|----------------------------|-------|---|-----|-----------|-----------|----------------|----------|----------------|-----------|-----------|---------|
| -FICA-          | mnemonic   | Binary     | Hex         | Function                   | s     | 7 |     | н         | :         | :<br>P/V       | N        | c              | CY-       | STA-      |         |
|                 |            | 11 111 101 | 50          | (TV) 4) (TV) 4) +1         | -     | - |     |           |           |                |          |                |           |           |         |
| -               | INC (11+0) |            | 34          |                            | Ť     | Ť | ^   | Ţ         | ^         | v              | U        | -              | 0         | 23        |         |
| H-              |            | 44 444 444 |             |                            |       |   |     |           |           |                |          |                |           |           |         |
| Σ               | DEC r      | 00 rrr 101 | 05+r×8      | r+r−1                      | *     | * | x   | *         | x         | v              | 1        | -              | 1         | 4         | r l crr |
| H J<br>H J      | DEC (HL)   | 00 110 101 | 35          | (HL)+(HL)−1                | *     |   | X   |           | x         | v              | 1        | -              | 3         | 11        | B 000   |
| - 0             | DEC (IX+d) | 11 011 101 | DD          | (IX+d)+(IX+d)-1            | *     | ٠ | X   |           | X         | v              | 1        | -              | 6         | 23        | C 001   |
| 4 U             |            | 00 110 101 | 35          |                            |       |   |     |           |           |                |          |                |           |           | D 010   |
| 0               |            | dd ddd ddd | d           |                            |       |   |     |           |           | 1              |          |                |           |           | E 011   |
| 12 -            | DEC (IY+d) | 11 111 101 | FD          | (IY+d)←(IY+d)-1            | *     | * | Х   | *         | Х         | v              | 1        | -              | 6         | 23        | H 100   |
| <u>ه</u> ۵      |            | 00 110 101 | 35          |                            |       |   |     |           |           |                |          |                |           |           | L 101   |
| ∞∡              |            | bbb bbb bb | d           |                            |       |   |     |           |           |                |          |                |           |           | A 111   |
| -               | DAA        | 00 100 111 | 27          | Decimal adjust accumulator | *     | * | Х   | *         | X         | Р              | -        | *              | 1         | 4         |         |
| R O             | CPL        | 00 101 111 | 2F          | A+Ā                        | -     | - | Х   | 1         | Х         | -              | 1        | -              | 1         | 4         |         |
| ۲.              | NEG        | 11 101 101 | ED          | A←0-A                      | *     | ٠ | Х   | ٠         | Х         | V              | 1        | *              | 2         | 8         |         |
| ō               |            | 01 000 100 | 44          |                            |       |   |     | <u>.</u>  |           | <u>.</u>       |          |                |           |           |         |
| Ĭ               | CCF        | 00 111 111 | 3F          | CY+CY                      |       |   | X   | X         | X         |                | 0        | *              | 1         | 4         |         |
| P U             | SCF        | 00 110 111 | 37          | CY+1                       |       | - | X   | 0         | X         | l              | 0        | 1              | 11        | 4         |         |
| Σ               | NOP        | 00 000 000 | 00          | no operation               |       |   | X   |           | X         | i              |          |                | 1         | 4         |         |
| S O             | HALT       | 01 110 110 | 76          | MPU Halted                 |       |   | X   |           | X         | l <u>-</u>     | -        | <del>.</del> . | 11        | 4         |         |
| 4 4             | DI         | 11 110 011 | F3          | IFF←O                      |       |   | Х   |           | Х         | ļ <del>.</del> |          | -              | 1         | 4         |         |
| μ               | EI         | 11 111 011 | FB          | IFF←1                      |       |   | Х   |           | X         | <del>.</del>   | -        | -              | 1         | 4         |         |
| a -             | IM O       | 11 101 101 | ED          | Set interrupt mode 0       | -     | - | х   | -         | х         | -              | -        | -              | 2         | 8         |         |
| ЧЧ              |            | 01 000 110 | 46          |                            |       |   |     |           |           | ;              |          |                |           |           |         |
| ΗĽ              | IM 1       | 11 101 101 | ED          | Set interrupt mode 1       | -     | - | х   | -         | х         | -              | -        | -              | 2         | 8         |         |
| ш н<br>2 -      |            | 01 010 110 | 56          |                            |       |   |     |           | ;<br>     | }              |          |                |           |           |         |
| E E             | IM 2       | 11 101 101 | ED          | Set interrupt mode 2       | -     | - | х   | -         | х         | -              |          | -              | 2         | 8         |         |
| <u> </u>        |            | 01 011 110 | 5E          |                            |       |   |     | ļ         | ļ         |                |          |                |           |           |         |
| 1               | ADD HL,t   | 00 tt1 001 | 09+t×10     | HL←HL+t                    |       |   | Х.  | X         | Х.,       | ļ <del></del>  | 0        | *              | 3         | . 11      | ttt     |
|                 | ADC HL,t   | 11 101 101 | ED          | HL+HL+t+CY                 | *     | * | х   | Х         | Х         | v              | 0        | *              | 4         | 15        | BC 00   |
| 0               |            | 01 tt1 010 | 4A+t×10     |                            |       |   |     |           |           | ļ              |          |                |           |           | DE 01   |
| -               | SBC HL,t   | 11 101 101 | ED          | HL+HL-t-CY                 | *     | * | х   | х         | X         | v              | 1        | •              | 4         | 15        | HL 10   |
| н<br>ш          |            | 01 tto 010 | 42+t × 10   | TV. TV                     |       |   |     |           |           | }              | ÷        | <u>.</u>       | ····;·    |           |         |
| Σ               | ADD IX,p   |            | 00          | 1X+1X+p                    | -     | - | × . | ×         |           | -              | . 0      |                | 4         | 15        |         |
| Ļ.              |            | 11 111 101 | 1 097p X 10 | TV+TV+c                    |       |   |     |           |           | · · · · · ·    |          |                | ·         | 15        |         |
| -               | 11,3       | 00 661 001 | 00+5 × 10   | 11,11,3                    | -     |   | ^   | ^         | ^         | -              | 0        |                | 1         | 15        | DE 01   |
| Ā               | TNC +      | 00 331 001 | 03+1 × 10   | ++++1                      | ····· |   | v   |           |           | ····-          | ÷        | ·····          | ·····     | 6         | TX 10   |
| -               |            | 11 011 101 |             | TX+TX+1                    |       |   | ÷   | <u></u> - | • • • • • | 1              | <u>.</u> | ·              | ·         | 10        | SP 11   |
| -               |            | 00 100 011 | 23          |                            |       |   | ſ^. |           | ^         | 1              |          |                | 1         | 10        |         |
| 8               | INC IY     | 11 111 101 | FD          | IY+IY+1                    |       |   | ¥   | <u>.</u>  | x         | <u></u>        | -        |                | 2         | 10        | 5 55    |
| 9               |            | 00 100 011 | 23          |                            |       |   | ^   |           | î.        |                |          |                | -         | 10        | BC 00   |
| -               | DEC t      | 00 tt1 011 | 0B+t × 10   | t+t−1                      | -     | - | х   | _         | x         |                | _        | _              | 1         | 6         | DE 01   |
|                 | DEC IX     | 11 011 101 | DD          | IX←IX-1                    | -     | - | х   | -         | X         | -              | - 1      | -              | 2         | 10        | IY 10   |
| 1               |            | 00 101 011 | 2B          |                            |       |   |     |           |           | 1              |          |                |           |           | SP 11   |
|                 | DEC IY     | 11 111 101 | FD          | IY←IY−1                    | -     | - | х   | -         | x         | -              | _        | -              | 2         | 10        |         |
|                 |            | 00 101 011 | 2B          |                            |       |   |     |           |           |                |          |                |           |           |         |
| DTATE           | RLCA       | 00 000 111 | 07          | CY < 7 + 0 <               | -     | - | x   | 0         | x         | -              | 0        |                | 1         | 4         |         |
| м               |            |            |             | A                          |       |   |     |           |           |                |          |                |           |           |         |

Note : ss is any of the register pairs BC, DE, HL, SP. PP is any of the register pairs BC, DE, IX, SP. rr is any of the register pairs BC, DE, IY, SP.

### TMPZ84C00A Instruction Set (6/9)

| ITEM/<br>CLASSI | Assembler  | Ot                                               | ject code                   | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   |   | F | lag   |     |   |   | No.<br>OF   | No.<br>OF   |         |                   |
|-----------------|------------|--------------------------------------------------|-----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|-------|-----|---|---|-------------|-------------|---------|-------------------|
| -FICA-<br>TION  | mnemonic   | 76 543 21                                        | 0 Hex                       | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | s | z |   | н |       | P/V | N | с | CY-<br>CLES | STA-<br>TES |         |                   |
|                 | RLA        | 00 010 11                                        | 1 17                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | - | - | x | 0 | x     | -   | 0 | * | 1           | 4           |         |                   |
|                 | RRCA       | 00 001 11                                        | 1 OF                        | $ \begin{array}{c} \hline & \hline & & \\ \hline \\ \hline$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | - | - | x | 0 | x     | -   | 0 | ٠ | 1           | 4           |         |                   |
|                 | RRA        | 00 011 11                                        | 1 1F                        | $ \begin{array}{c} \hline \hline \\ $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | - | - | x | 0 | x     | -   | 0 | • | 1           | 4           |         |                   |
|                 | RLC r      | 11 001 01                                        | 1 CB                        | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | • | * | х | 0 | x     | Р   | 0 | * | 2           | 8           | r<br>P  | rrr               |
|                 | RLC (HL)   | 11 001 01                                        | 1 CB                        | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | • | * | x | 0 | x     | Р   | 0 | ٠ | 4           | 15          | C       | 001               |
| _               | RLC (IX+d) | 11 011 10<br>11 001 01                           | 1 DD<br>1 CB                | CY - 0 -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | • | * | x | 0 | X     | р   | 0 | * | 6           | 23          | E<br>H  | 010<br>011<br>100 |
| ц.<br>—<br>Н    | RLC (IY+d) | dd ddd dd<br>00 000 11<br>11 111 10              | d d<br>0 06<br>1 FD         | r,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   | • | x | 0 | <br>X | p   | 0 | * | 6           | 23          | L<br>_A | 101<br>111        |
| E               |            | 11 001 01<br>dd ddd dd                           | 1 CB<br>d d                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   | Ŭ | 'n    |     | Ů |   |             | 20          |         |                   |
| ⊢<br>∀          | RL r       | 11 001 01                                        | 0 06<br>1 CB                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | • | x | 0 | <br>Х | р   | 0 | • | 2           | 8           |         |                   |
| R O T           | RL (HL)    | 00 010 rr<br>11 001 01                           | r 10+r<br>1 CB<br>0 16      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | * | x | 0 | x     | Р   | 0 | • | 4           | 15          |         |                   |
|                 | RL (IX+d)  | 11 011 10<br>11 001 01<br>dd ddd dd              | 1 DD<br>1 CB<br>d d         | $\begin{array}{c c} \hline \\ \hline $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | • | * | X | 0 | X     | Р   | 0 | ٠ | 6           | 23          |         |                   |
|                 | RL (IY+d)  | 00 010 11<br>11 111 10<br>11 001 01<br>dd ddd dd | 0 16<br>1 FD<br>1 CB<br>d d |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | • | x | 0 | x     | Р   | 0 | * | 6           | 23          |         |                   |
|                 | RRC r      | 00 010 11                                        | 0 16<br>1 CB                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | * | x | 0 | x     | Р   | 0 | • | 2           | 8           |         |                   |
|                 | RRC (HL)   | 11 001 01                                        | r 08+r<br>1 CB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | ٠ | x | 0 | <br>Х | P   | 0 | ٠ | 4           | 15          |         |                   |
|                 | RRC (IX+d) | 11 011 10<br>11 001 01<br>11 001 01<br>dd ddd dd | 0 0E<br>1 DD<br>1 CB<br>d d | $\frac{7 \rightarrow 0}{r, (HL), (IX+d), (IY+d)}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | * | * | x | 0 | x     | Р   | 0 | * | 6           | 23          |         |                   |
|                 | RRC (IY+d) | 00 001 11<br>11 111 10<br>11 001 01<br>dd ddd dd | 0 0E<br>1 FD<br>1 CB<br>d d |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | * | x | 0 | x     | Р   | 0 | * | 6           | 23          |         |                   |
|                 | RR r       | 00 001 11<br>11 001 01                           | 0 0E<br>1 CB                | · · · · · · · · · · · · · · · · · · ·                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | • | • | x | 0 | x     | P   | 0 | * | 2           | 8           |         |                   |
|                 | RR (HL)    | 00 011 rr<br>11 001 01                           | r 18+r<br>1 CB              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | • | x | 0 | x     | Р   | 0 | • | 4           | 15          |         |                   |
|                 | RR (IX+d)  | 00 011 11<br>11 011 10<br>11 001 01              | 0 1E<br>1 DD<br>1 CB        | $\left  \begin{array}{c} \begin{array}{c} \begin{array}{c} & \\ \end{array} \\ & \\ \end{array} \\ & \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ \\ & \begin{array}{c} \\ \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \begin{array}{c} \\ \\ \end{array} \\ & \begin{array}{c} \\ \end{array} \\ & \end{array} \\ & \begin{array}{c} \\ \end{array} \\ \\ \end{array} \\ \\ \end{array} \\ \\ \end{array} \\ \end{array} \\ \\ \end{array} \\ \end{array} \\ $ | • | • | x | 0 | x     | Р   | 0 | * | 6           | 23          |         |                   |
|                 |            | dd ddd do<br>00 011 11                           | d d<br>0 1E                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |       |     |   |   |             |             |         |                   |

Note : r means any of the registers A, B, C, D, E, H, L.

TMPZ84C00A

# TMPZ84C00A Instruction Set (7/9)

| ITEM/<br>CLASSI | Assembler  | Object                                               | code                     | Eurotion                                                                                                                                                 | Flag OF OF |   |   |   |   |     |   |   |             |             |                         |
|-----------------|------------|------------------------------------------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---|---|---|---|-----|---|---|-------------|-------------|-------------------------|
| -FICA-<br>TION  | mnemonic   | 76 543 210                                           | nex                      | , unction                                                                                                                                                | s          | z |   | н |   | P/V | N | с | CY-<br>CLES | STA-<br>TES |                         |
|                 | RR (IY+d)  | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d            | $ \begin{array}{c} \hline \hline$ | ٠          | * | X | 0 | x | Р   | 0 | • | 6           | 23          |                         |
|                 | SLA r      | 00 011 110<br>11 001 011<br>00 100 rrr               | 1E<br>CB<br>20+r         |                                                                                                                                                          | •          | ٠ | x | 0 | x | Р   | 0 | * | 2           | 8           | r rrr<br>B 000          |
|                 | SLA (HL)   | 11 001 011                                           | CB                       |                                                                                                                                                          | *          | ٠ | х | 0 | X | Р   | 0 | ٠ | 4           | 15          | C 001                   |
|                 | SLA (IX+d) | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d            | $\begin{array}{c} \hline CY \leftarrow 7 \leftarrow 0 \\ \hline r, (HL), (IX+d), (IY+d) \end{array}$                                                     | *          | * | x | 0 | x | Р   | 0 | * | 6           | 23          | E 011<br>H 100<br>L 101 |
|                 | SLA (IY+d) | 11 111 101<br>11 001 011                             | FD<br>CB                 |                                                                                                                                                          | •          | * | x | 0 | x | Р   | 0 | • | 6           | 23          | <u>A 111</u>            |
| нц              | SRA r      | dd ddd ddd<br>00 100 110<br>11 001 011               | d<br>26<br>CB            |                                                                                                                                                          | •          | • | x | 0 | x | Р   | 0 | * | 2           | 8           |                         |
| S H I           | SRA (HL)   | 00 101 rrr<br>11 001 011                             | 28+r<br>CB               |                                                                                                                                                          | •          | * | x | 0 | x | P   | 0 | • | 4           | 15          |                         |
| ш<br>Т          | SRA (IX+d) | 00 101 110<br>11 011 101<br>11 001 011               | ZE<br>DD<br>CB           | $7 \rightarrow 0 \rightarrow CY$                                                                                                                         | *          | ٠ | x | 0 | x | Р   | 0 | * | 6           | 23          |                         |
| A T O X         | SRA (IY+d) | dd ddd ddd<br>00 101 110<br>11 111 101               | d<br>2E<br>FD            | r,(HL),(IX+d),(IY+d)                                                                                                                                     |            | * | x | 0 | x | P   | 0 | • | 6           | 23          |                         |
| Ľ.              |            | 11 001 011<br>dd ddd ddd<br>00 101 110               | CB<br>d<br>2F            |                                                                                                                                                          |            |   |   |   |   |     |   |   |             |             |                         |
|                 | SRL r      | 11 001 011<br>00 111 ppp                             | CB<br>38+r               |                                                                                                                                                          | *          | ٠ | X | 0 | x | Р   | 0 | ٠ | 2           | 8           |                         |
|                 | SRL (HL)   | 11 001 011<br>00 111 110                             | CB                       |                                                                                                                                                          | *          | * | х | 0 | x | Р   | 0 | • | 4           | 15          |                         |
|                 | SRL (IX+d) | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d            | $0 \longrightarrow 7 \rightarrow 0 \longrightarrow CY$                                                                                                   | *          | * | X | 0 | x | Р   | 0 | * | 6           | 23          |                         |
|                 | SRL (IY+d) | 00 111 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 3E<br>FD<br>CB           | r,(HL),(IX+d),(IY+d)                                                                                                                                     | *          | * | x | 0 | x | Р   | 0 | * | 6           | 23          |                         |
|                 | RLD        | 00 111 110<br>11 101 101<br>01 101 111               | 3E<br>ED<br>6F           | A 7 43 0 7 43 0 (HL)                                                                                                                                     | *          | * | x | 0 | x | Р   | 0 | - | 5           | 18          | *1                      |
|                 | RRD        | 11 101 101<br>01 100 111                             | ED<br>67                 | A 7 43 0 7 43 0 (HL)                                                                                                                                     | •          | * | x | 0 | x | Р   | 0 | - | 5           | 18          | *1                      |
| EST             | BIT b,r    | 11 001 011                                           | CB                       | 7                                                                                                                                                        | Х          | * | х | 1 | x | X   | 0 | - | 2           | 8           | 0 000                   |
| SET<br>ET AND T | BIT b,(HL) | 11 001 011<br>01 bbb 110                             | 40+0×8+r<br>CB<br>46+b×8 | 2 <sup>-τ</sup> 1b<br>Ζ+(HL) <sub>b</sub>                                                                                                                | x          | * | x | 1 | x | x   | 0 | - | 3           | 12          | 2 010<br>3 011<br>4 100 |
| B I T<br>RES    |            |                                                      |                          |                                                                                                                                                          |            |   |   |   |   |     |   |   |             |             | 5 101<br>6 110<br>7 111 |

Note : \*1: Rotate digit left and right between the accmulator and location (HL).

The content of the upper half of the accumulator is unaffected.

The notation (HL)<sub>b</sub> indicates bit  $_{\rm b}$  (0 to 7) within the contents of the HL register pair. The notation  $r_b$  indicates bit  $_b$  (0 to 7) within the r register.

## TMPZ84C00A Instruction Set (8/9)

| ITEM/<br>CLASSI | Assembler                                      | Object                                                   | code                                                          |                                                                             |               |             |             | F           | lag         |        |     |             | No.<br>OF   | No.<br>OF    |                                                  |
|-----------------|------------------------------------------------|----------------------------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------------------|---------------|-------------|-------------|-------------|-------------|--------|-----|-------------|-------------|--------------|--------------------------------------------------|
| -FICA-<br>TION  | mnemonic                                       | Binary<br>76 543 210                                     | Hex                                                           | Function                                                                    | s             | z           |             | н           |             | P/V    | N   | с           | CY-<br>CLES | STA-<br>TES  |                                                  |
|                 | BIT b,(IX+d)                                   | 11 011 101<br>11 001 011                                 | DD<br>CB                                                      | Z←(IX+d)b                                                                   | x             | *           | x           | 1           | x           | x      | 0   | -           | 5           | 20           |                                                  |
|                 | BIT b.(IY+d)                                   | dd ddd ddd<br>01 bbb 110<br>11 111 101                   | d<br>46+b×8<br>FD                                             |                                                                             |               |             | Y           |             |             | Y      | 0   |             |             | 20           |                                                  |
| S T             |                                                | 11 001 011<br>dd ddd ddd                                 | CB<br>d                                                       | Z←(IY+d)b                                                                   | ĥ             |             |             |             |             |        | Ū   |             | Ū           | 20           |                                                  |
| -               | SET b,r                                        | 11 001 011<br>11 bbb ccc                                 | 46+0 × 8<br>CB<br>C0+b × 8+r                                  | rb←1                                                                        | -             | -           | x           | -           | X           | -      | -   | -           | 2           | 8            |                                                  |
| A N D           | SET b,(HL)                                     | 11 001 011<br>11 bbb 110                                 | CB<br>C6+b × 8                                                | (HL) <sub>b</sub> ←1                                                        | -             | -           | х           | -           | x           | -      | -   | -           | 4           | 15           | C 001<br>D 010                                   |
| SET             | SET b,(IX+d)                                   | 11 011 101<br>11 001 011<br>dd ddd ddd                   | DD<br>CB<br>d                                                 | (IX+d)b←1                                                                   | -             | -           | х           | -           | X           | -      | -   | -           | 6           | 23           | E 011<br>H 100<br>L 101                          |
| R               | SET b,(IY+d)                                   | 11 bbb 110<br>11 111 101<br>11 001 011                   | C6+b×8<br>FD<br>CB                                            | (IY+d)b←1                                                                   | -             | -           | x           | -           | x           | -      | -   | -           | 6           | 23           | A 111<br>b bbb                                   |
| S E ]           | RES b,r                                        | dd ddd ddd<br>11 bbb 110<br>11 001 011                   | d<br>C6+b×8<br>CB                                             | rь+0                                                                        |               |             | x           |             | x           |        | _   |             | 2           |              | 0 000<br>1 001<br>2 010                          |
|                 | RES b,(HL)                                     | 10 bbb rrr<br>11 001 011                                 | 80+b×8+r<br>CB                                                | (HL) <sub>b</sub> ←0                                                        | -             | -           | x           | -           | x           | -      | -   | <br>-       | - 4         | 15           | 3 011<br>4 100                                   |
|                 | RES b,(IX+d)                                   | 10 bbb 110<br>11 011 101<br>11 001 011<br>dd ddd ddd     | 86+b × 8<br>DD<br>CB<br>d                                     | (IX+d)b←0                                                                   | -             | -           | x           | -           | x           | -      | -   | -           | 6           | 23           | 5 101<br>6 110<br>7 111                          |
|                 | RES b,(IY+d)                                   | 10 bbb 110<br>11 111 101<br>11 001 011<br>dd ddd ddd     | 86+b×8<br>FD<br>CB<br>d                                       | (IY+d)b←0                                                                   | -             | -           | x           | -           | x           | -      | -   | -           | 6           | 23           |                                                  |
|                 | JP mn                                          | 10 bbb 110<br>11 000 011<br>nn nnn nnn                   | 86+b×8<br>C3<br>n                                             | PC←mn                                                                       | -             | -           | x           | -           | x           | -      | -   | -           | 3           | 10           |                                                  |
|                 | JP c,mn                                        | mm mmm mmm<br>11 ccc 010<br>nn nnn nnn                   | m<br>C2+c×8<br>n                                              | PC←mn<br>(Only when condition is met)                                       | -             | -           | x           | -           | x           | -      | -   |             | 3           | 10           | e represents the<br>extension in the<br>relative |
| ٩               | JR \$+e                                        | 00 011 000<br>aa aaa aaa                                 | m<br>18<br>a                                                  | PC←\$+e                                                                     | -             | -           | x           | -           | x           | -      | -   | -           | 3           | 12           | addressing<br>mode, a = e – 2.<br>e is a signed  |
| M U I           | JR C,\$+e                                      | 00 111 000<br>aa aaa aaa                                 | 38<br>a                                                       | lf C=0, continue<br>If C=1, PC+\$+e                                         | -             | -           | X<br>X      | -           | X<br>X      | -      | -   | -           | 2<br>3      | 7            | two's<br>complement                              |
|                 | JR NC,\$+e<br>JR Z.\$+e                        | 00 110 000<br>aa aaa aaa<br>00 101 000                   | 30<br>a<br>28                                                 | If C=0, PC←\$+e<br>If C=1, continue<br>If Z=0, continue                     |               |             | X<br>X      | -           | X<br>X<br>Y | -      |     | <br>        | 3<br>2      | 12<br>7      | number in the<br>range of<br>- 126≤ e ≤ 129      |
|                 | JR NZ,\$+e                                     | aa aaa aaa<br>00 100 000                                 | a<br>20                                                       | If Z=1, PC+\$+e<br>If Z=0, PC+\$+e                                          | -<br>-        | -<br>-      | X<br>X      | -<br>-      | X<br>X      | -      | -   |             | 3           | 12<br>12     |                                                  |
|                 | DJNZ \$+e                                      | aa aaa aaa<br>00 010 000<br>aa aaa aaa                   | a<br>10<br>a                                                  | IT Z=1, continue<br>B+B−1, If B=0, continue<br>B+B−1, If B<>0, continue     |               | -<br>-<br>- | X<br>X<br>X | -<br>-<br>- | X<br>X<br>X |        | -   | -<br>-<br>- | 2           | 7<br>8<br>13 |                                                  |
|                 | JP (HL)                                        | 11 101 001                                               | E9                                                            | PC+HL                                                                       | - [           | -           | X           | -           | Х           | -      | -   | -           | 1           | 4            |                                                  |
|                 | Note: ● a = e - 2                              | in the Opcode pro                                        | vides an effect                                               | ive address of PC + e as PC is increm                                       | entec         | l by 2      | 2 bef       | ore t       | he a        | ditior | ofe |             |             | z 00         | c Condition                                      |
|                 | <ul> <li>\$ indica</li> <li>The not</li> </ul> | tes the reference t<br>ation (HL) <sub>b</sub> , (IX + d | o the location (<br>) <sub>b</sub> indicates bit <sub>l</sub> | ounter value of the current segmen<br>(0 to 7) within the contents of the i | ιτ.<br>regist | er p        | air.        |             |             |        |     |             | N           | Z 00<br>C 01 | 1 Zero<br>10 No-carry                            |

• The notation r<sub>b</sub> indicates bit <sub>b</sub> (0 to 7) within the r register.

• a = e-2 in the op-code provides effective address of PC + e as PC is incremented by 2 prior to the addition of e.

270489

C 011 Carry P0 100 Odd Parity

PE 101 Even Parity P 110 Sign Positive M 111 Sign Negative

# TMPZ84C00A Instruction Set (9/9)

| ITEM/<br>CLASSI | Assembler | Object                   | code<br>Hex  | Function                                       | Flag     |              |     |               |        |             |               |   | No.<br>OF   | No.<br>OF   |                  |                 |
|-----------------|-----------|--------------------------|--------------|------------------------------------------------|----------|--------------|-----|---------------|--------|-------------|---------------|---|-------------|-------------|------------------|-----------------|
| -FICA-<br>TION  | mnemonic  | 76 543 210               |              |                                                | s        | z            |     | н             |        | P/V         | N             | с | CY-<br>CLES | STA-<br>TES |                  |                 |
| ۵<br>۲          | JP (IX)   | 11 011 101<br>11 101 001 | DD<br>E9     | PC←(IX)                                        | -        | -            | х   | -             | х      | -           | -             | - | 2           | 8           |                  |                 |
| n r             | JP (IY)   | 11 111 101               | FD           | PC←(IY)                                        | -        | -            | х   | -             | х      | -           | -             | - | 2           | 8           |                  |                 |
|                 | CALL mn   | 11 001 101               | CD           | (SP-1)+PC <sub>H</sub> ,(SP-2)+PCL             | -        | -            | x   | -             | x      | -           | -             | - | 5           | 17          | jk               | kk              |
| R               |           |                          | n<br>m       | PC←mn<br>SP←SP-2                               |          |              |     |               |        |             |               |   |             |             | 00H 0<br>08H 0   | 000             |
| ⊃               | CALL c,mn | 11 ccc 100               | C4+cX8       | If condition c is met, same as                 |          | -            | x   | -             | X      | -           | -             | - | 5           | 17          | 10H 0            | 010             |
| н<br>ш          |           | nn nnn nnn               | n            | CALL mn.                                       |          |              |     |               |        | · · · · · · |               |   | <u>.</u>    |             | 18H C            | 011             |
| ĸ               | RET       | 11 001 001               | С9<br>С9     | PC <sub>1</sub> ←(SP), PC <sub>H</sub> ←(SP+1) | <u>.</u> | -            | X.  |               | X      |             |               |   | 3           | 10          | 20H 1            | 01              |
| 07              |           |                          |              | SP←SP+2                                        |          |              | ļ   | ļ             |        |             | ļ             |   |             |             | 30H 1            | 10              |
| ۲<br>۲          | RET C     | 11 ccc 000               | C0+c×8       | If condition c is met, same as RET.            |          | . <u>-</u> . | X.  | ÷. <u>-</u> . | X<br>Y | <u>-</u>    | ÷. <u>-</u> . |   | 3           | .11         | <u>38H   1</u>   | 11              |
| _               | RETI      | 11 101 101               | ED           | Return from interrupt Processing               | -        | -            | x   |               | X      | -           | -             | - | 4           | 14          | n n              | r               |
|                 | DETN      | 01 001 101               | 4D           | routine<br>Roturn from non-markable            |          |              |     |               |        |             | ļ             |   |             |             | B 00             | 0               |
| Û               | REIN      | 01 000 101               | 45           | interrupt Processing routine                   | -        | -            |     | -             |        | -           | -             | - | 4           | 14          | D 01             | 0               |
|                 | RST j     | 11 kkk 111               | C7+k×8       | (SP-1)←PC <sub>H</sub> ,(SP-2)←PCL             | -        | -            | Х   | -             | Х      | -           | -             | - | 3           | 11          | E 01             | 1               |
|                 | IN A.(n)  | 11 011 011               | DB           | PCH←O,PCL←j,SP←SP-2                            | _        | _            | x   | _             | x      |             | -             | _ | 3           | 11          | H 10             | 0<br>1          |
|                 |           | nn nnn nnn               | n            | n→A0~A7,A→A8~A15                               |          |              |     | <u>.</u>      |        |             |               |   | l           |             | A 11             | 1               |
|                 | IN r,(C)  | 11 101 101               | ED           | r←(C) If r=110, only the flags                 | *        | ٠            | x   | *             | х      | Р           | 0             | - | 3           | 12          |                  | ٦               |
| H-              | INI       | 11 101 101               | 40+rx8<br>ED | (HL)←(C),B←B−1,HL←HL+1                         | <br>X    | •м           | x   | x             | x      | x           | 1             | x | 4           | 16          |                  |                 |
|                 |           | 10 100 010               | A2           |                                                |          |              |     |               |        | ļ           |               |   | ļ           |             |                  | - [             |
| F               | INIR      | 11 101 101               | ED           | (HL)←(C),B←B−1,HL←HL+1                         | X        | 1            | х   | x             | х      | х           | 1             | х | 5           | 21          | ←[B<>0           | 1               |
| ō               | IND       | 11 101 101               | ED           | (HL)+(C),B+B-1,HL+HL-1                         | <br>Х    | *м           | x   | x             | x      | x           | 1             | x | 44          | 16          | €[B=0]           |                 |
| ۵               |           | 10 101 010               | AA           |                                                |          |              |     |               |        |             |               |   |             |             |                  |                 |
| z               | INDR      | 11 101 101               | ED           | (HL)←(C),B←B−1,HL←HL−1<br>Ropest uptil B=0     | Х        | 1            | х   | X             | Х      | х           | 1             | х | 5           | 21          | ←[B<>0           |                 |
|                 | OUT (n),A | 11 010 011               | D3           | (n)←A                                          | ·····    | -            | x   | -             | x      | -           | -             | - | 3           | 10          | .[0-0]           |                 |
| L D             |           | nn nnn nnn               | n            | n→A0~A7,A→A8~A15                               |          |              |     | <u>.</u>      |        |             | ļ             |   | [           |             |                  |                 |
| ۵.              | 0UT (C),r |                          | ED<br>41+rX8 | (C)←r                                          | -        | -            | X   | -             | х      | -           | -             | - | 3           | 12          |                  |                 |
| -               | OUTI      | 11 101 101               | ED           | (C)+(HL),B+B−1,HL+HL+1                         | X        | *м           | x   | X             | Х      | X           | 1             | x | 4           | 16          |                  |                 |
|                 | OTTO      | 10 100 011               | A3           |                                                |          |              |     |               |        |             |               |   | [ <u>.</u>  |             |                  | ,               |
|                 | UTIK      | 10 110 011               | B3           | Repeat until B=0                               | X        | 1            | X   | X             | X      | X           | 1             | X | 5           | 21          | +6[()0<br>+[B=0] | •  <sup>۱</sup> |
|                 | OUTD      | 11 101 101               | ED           | (C)←(HL),B←B−1,HL←HL−1                         | X        | *м           | X   | X             | X      | X           | 1             | X | 4           | 16          |                  |                 |
|                 |           | 10 101 011               | AB<br>FD     | (C)+(HL) B+B-1 HL+HL-1                         | <br>v    |              |     |               |        |             | 1             | v |             |             | +FR(\∩           |                 |
|                 | 0.5%      | 10 111 010               | BB           | Repeat until B=0                               | ^        | 1            | ^   | <u> </u>      | ^      | ^           |               | ^ | 4           | 16          | +[B=0]           | í               |
|                 |           |                          |              |                                                |          | 1            | C→A | 0~A7          |        | c           | ccc           |   | onditi      | on          |                  |                 |

Note: \*M If the result of B – 1 is zero, the Z flag is set, otherwise it is reset.
A0 through A15 indicate the address bus.

• [ ] indicates the total condition of the number of cycles and states indicated by arrow.

|          | : |    |     |             | 4      | 16   | J |  |  |
|----------|---|----|-----|-------------|--------|------|---|--|--|
| C-→A0~A7 | - | с  | ccc | Co          | onditi | on   |   |  |  |
| B→A8~A15 |   | NZ | 000 | No          | on-Ze  | ro   |   |  |  |
|          |   | z  | 001 | Ze          | ro     |      |   |  |  |
|          |   | NC | 010 | No          | o-Cari | Y    |   |  |  |
|          |   | С  | 011 | Ca          | irry   |      |   |  |  |
|          |   | PO | 100 | 0           | dd Pa  | rity |   |  |  |
|          |   | PE | 101 | Εv          | en Pa  | rity |   |  |  |
|          |   | Р  | 110 | Sig         | sitive |      |   |  |  |
|          | _ | М  | 111 | Sign negati |        |      |   |  |  |

#### TOSHIBA

#### 3.5 USAGE

Basic TMPZ84C00A configurations using memory and peripheral LSIs are described below.

#### 3.5.1 Memory Address Assignment

When the memory is being accessed, the MPU outputs address and control signals. These signals are used as the memory chip enable signals.

The MPU uses 16-bit address signals to specify the addresses for 64K (0-FFFF). With systems having only one memory, memory addresses can be specified with these signals alone. When there are several memories, however, the memories must be arranged so that access is possible using 64K of space. Normally, several address buses are decoded to create this arrangement, several address buses are developed for use as one memory chip enable signal for all memories.

Example: The addresses for an  $8K \times 8$ -bit ROM and  $8K \times 8$ -bit RAM are arranged as shown in Figure 3.21. Figure 3.22 shows am example using the  $\overline{\text{MREQ}}$  signal,  $\overline{\text{RD}}$  signal and address signal A13 as the chip enable signals.



Figure 3.21 Address Assignment

## 3.5.2 Connection with TLCS-Z80 family peripheral LSI

TMPZ84C00A can connect with peripheral LSI directly. A simple connecting example of the TMPZ84C00A with peripheral LSI is shown in Figure 3.23.



Figure 3.22 Example Connection with Memories

TMPZ84C00A





# 4. ELECTRICAL CHARACTERISTICS

#### 4.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                             | RATING       | UNIT |
|---------------------|----------------------------------|--------------|------|
| V <sub>CC</sub>     | Supply Voltage                   | - 0.5~ + 7   | V    |
| V <sub>IN</sub>     | Input Voltage                    | -0.5~VCC+0.5 | V    |
| PD                  | Power Dissipation<br>(TA = 85°C) | 250          | mW   |
| T <sub>SOLDER</sub> | Soldering<br>Temperature (10sec) | 260          | °C   |
| TSTG                | Storage Temperature              | - 65~150     | °C   |
| TOPR                | Operating Temprature             | - 40~85      | °C   |

060489

## 4.2 DC ELECTRICLAL CHARACTERISTICS

#### DC Characteristics (1/2) T<sub>OPR</sub> = $-40^{\circ}$ C $\sim$ 85°C, V<sub>CC</sub> = 5V ± 10%, VSS = 0V

| SYMBOL | ITEM                                  | TEST CONDITION                          | MIN.                  | TYP. | MAX.                  | UNIT   |
|--------|---------------------------------------|-----------------------------------------|-----------------------|------|-----------------------|--------|
| VILC   | Low Level Clock<br>input Voltage      |                                         | - 0.3                 |      | 0.6                   | V      |
| VIHC   | High Level Clock<br>input Voltage     |                                         | V <sub>CC</sub> – 0.6 | _    | V <sub>CC</sub> + 0.3 | V      |
| VIL    | Input Low Voltage<br>(except CLK)     |                                         | - 0.5                 | _    | 0.8                   | V      |
| VIH    | Input High Voltage<br>(except CLK)    |                                         | 2.2                   |      | V <sub>CC</sub>       | V      |
| VOL    | Output Low Voltage                    | IOL = 2.0mA                             | -                     | _    | 0.4                   | V      |
| VOH1   | Output High Voltage<br>( I )          | IOH = -1.6mA                            | 2.4                   | _    | _                     | V      |
| VOH2   | Output High Voltage<br>(II )          | IOH = -250µА                            | V <sub>CC</sub> – 0.8 | _    | _                     | v      |
| ILI    | Input Leak Current                    | $V_{SS} \leq V_{IN} \leq V_{CC}$        | -                     | _    | ± 10                  | μA     |
| ILO    | 3 state Output current<br>in Floating | $V_{SS} + 0.4 \leq V_{OUT} \leq V_{CC}$ |                       | _    | ± 10                  | μА     |
|        |                                       |                                         |                       |      |                       | 060489 |

## DC Characteristics (2/2)

| SYMBOL                       | ITEM                         | TEST CONDI                                                                                 | ΓΙΟΝ                   | MIN. | TYP. | MAX. | UNIT        |
|------------------------------|------------------------------|--------------------------------------------------------------------------------------------|------------------------|------|------|------|-------------|
| lcc1                         | Supply Current               | V <sub>CC</sub> = 5V<br>fCLK = (Note1)<br>VIHC = VIH                                       | AP-6<br>/AM-6<br>/AT-6 | _    | 15   | 22   | m 4         |
|                              | (Operating)                  | $= V_{CC} - 0.2V$ $VILC = VIL$ $= 0.2V$                                                    | AP-8<br>/AM-8<br>/AT-8 | _    | 20   | 25   | , IIIA<br>, |
| (Note2)<br>I <sub>CC</sub> 2 | Supply Current<br>(Stand by) | $V_{CC} = 5V$<br>CLK = (Note2)<br>VIHC = VIH =<br>V <sub>CC</sub> -0.2V<br>VILC = VIL = 0. | 2V                     |      | 0.5  | 10   | μΑ          |

Note 1  $f_{CLK} = 1/T_C C$  (MIN.)

060489

Note 2 At T4 "LOW" state after the halt instruction fetch cycle.

#### 4.3 AC ELECTRICAL CHARACTERISTICS (1/3)

 $T_{OPR} = -40^{\circ}C \sim 85^{\circ}C, V_{CC} = 5V \pm 10\%, VSS = 0V$ 

| NO. SYMBOL |                  | ITEM                                               |      | AP-6/AM-6<br>/AT-6<br>(6MHz) |      | AP-8/AM-8<br>/AT-8<br>(8MHz) |        |
|------------|------------------|----------------------------------------------------|------|------------------------------|------|------------------------------|--------|
|            |                  | 1                                                  | MIN. | MAX.                         | MIN. | MAX.                         |        |
| 1          | T <sub>C</sub> C | Clock Cycle Time                                   | 165  | DC                           | 125  | DC                           | ns     |
| 2          | TwCh             | Clock Pulse Width (High)                           | 65   | DC                           | 55   | DC                           | ns     |
| 3          | TwC1             | Clock Pulse Width (Low)                            | 65   | DC                           | 55   | DC                           | ns     |
| 4          | TfC              | Clock Fall Time                                    | -    | 20                           | -    | 10                           | ns     |
| 5          | TrC              | Clock Rise Time                                    | —    | 20                           | _    | 10                           | ns     |
| 6          | TdCr (A)         | Clock ↑ to Address Valid Delay - 90                |      | -                            | 80   | ns                           |        |
| 7          | TdA (MREQf)      | Address Valid to MREQ ↓ Delay                      | 35   | -                            | 20   | -                            | ns .   |
| 8          | TdCf (MREQf)     | Clock↓to MREQ↓ Delay                               | -    | 70                           | -    | 60                           | ns     |
| 9          | TdCr (MREQr)     | $Clock \uparrow to \overline{MREQ} \uparrow Delay$ | -    | 70                           | -    | 60                           | ns     |
| 10         | TwMREQh          | MREQ pulse Width (High)                            | 65   | -                            | 45   | _                            | ns     |
| 11         | TwMREQ1          | MREQ pulse Width (Low)                             | 135  | -                            | 100  | -                            | ns     |
| 12         | TdCf (MREQr)     | Clock↓to MREQ↑Delay                                | -    | 70                           | -    | 60                           | ns     |
| 13         | TdCf (RDf)       | Clock↓to RD↓Delay                                  | _    | 80                           | -    | 70                           | ns     |
| 14         | TdCr (RDr)       | Clock ↑ to RD ↑ Delay                              | -    | 70                           | -    | 60                           | ns     |
| 15         | TsD (Cr)         | Data Setup Time to Clock↑                          | 30   | -                            | 30   | -                            | ns     |
| 16         | ThD (RDr)        | Data Hold Time to $\overline{RD}$ $\uparrow$       | 0    | -                            | 0    | -                            | ns     |
| 17         | TsWAIT (Cf)      | ₩AIT Setup Time to Clock↓                          | 60   | _                            | 50   | _                            | ns     |
|            |                  |                                                    |      |                              |      |                              | 060489 |

AC Electrical Characteristics (2/3)

| NO.     | SYMBOL        | ITEM                                                               | AP-6/AM-6<br>/AT-6<br>(6MHz) |      | AP-8/AM-8<br>/AT-8<br>(8MHz) |      | UNIT |
|---------|---------------|--------------------------------------------------------------------|------------------------------|------|------------------------------|------|------|
|         |               |                                                                    | MIN                          | MAX. | MIN                          | MAX. |      |
| 18<br>* | ThWAIT (Cf)   | ₩AIT Hold Time after Clock↓                                        | 10                           | -    | 10                           | _    | ns   |
| 19      | TdCr (M1f)    | Clock ↑ to M1 ↓ Delay                                              | -                            | 80   |                              | 70   | ns   |
| 20      | TdCr (M1r)    | Clock ↑ to M1 ↑ Delay                                              | -                            | 80   | -                            | 70   | ns   |
| 21      | TdCr (RFSHf)  | Clock ↑ to RFSH ↓ Delay                                            | -                            | 110  | —                            | 95   | ns   |
| 22      | TdCr (RFSHr)  | Clock ↑ to RFSH ↑ Delay                                            | -                            | 100  | -                            | 85   | ns   |
| 23      | TdCf (RDr)    | Clock↓to RD↑Delay                                                  | -                            | 70   | -                            | 60   | ns   |
| 24      | TdCr (RDf)    | Clock ↑ to RD ↓ Delay                                              | -                            | 70   | —                            | 60   | ns   |
| 25      | TsD (Cf)      | Data Setup to Clock ↓<br>during M2, M3, M4 or M5 Cycles            | 40                           | -    | 30                           | -    | ns   |
| 26      | TdA (IORQf)   | Address Stable prior to IORQ ↓                                     | 110                          | -    | 75                           |      | ns   |
| 27      | TdCr (IORQf)  | Clock ↑ to IORQ ↓ Delay                                            | -                            | 65   | -                            | 55   | ns   |
| 28      | TdCf (IORQr)  | Clock↓to IORQ↑Delay                                                | -                            | 70   |                              | 60   | ns   |
| 29      | TdD (WRf)     | Data Stable Prior to ₩R↓                                           | 25                           |      | 5                            | -    | ns   |
| 30      | TdCf (WRf)    | Clock↓to ₩R↓Delay                                                  |                              | 70   | -                            | 60   | ns   |
| 31      | TwWR          | WR Pulse Width                                                     | 135                          | -    | 100                          | -    | ns   |
| 32      | TdCf (WRr)    | Clock↓to WR↑Delay                                                  | -                            | 70   | -                            | 60   | ns   |
| 33      | TdD (WRf)     | Data Stable Prior to WR J                                          | -55                          | -    | -55                          | -    | ns   |
| 34      | TdCr (WRf)    | Clock ↑ to WR ↓ Delay                                              | _                            | 60   |                              | 55   | ns   |
| 35      | TdWRr (D)     | Data Stable from WR ↑                                              | 30                           | -    | 15                           | -    | ns   |
| 36      | TdCf (HALT)   | Clock↓to HALT↑or↓                                                  | -                            | 260  | -                            | 225  | ns   |
| 37      | TwNMI         | NMI Pulse Width                                                    | 70                           | -    | 60                           | —    | ns   |
| 38      | TsBUSREQ (Cr) | BUSREQ Setup Time to Clock ↑                                       | 50                           | —    | 40                           | -    | ns   |
| 39<br>* | ThBUSREQ(Cr)  | BUSREQ Hold Time after Clock ↑                                     | 10                           | _    | 10                           | -    | ns   |
| 40      | TdCr(BUSACKf) | Clock ↑ to BUSACK ↓ Delay                                          | _                            | 90   |                              | 80   | ns   |
| 41      | TdCf(BUSACKr) | Clockt↓to BUSACK↑Delay                                             |                              | 90   |                              | 80   | ns   |
| 42      | TdCr(Dz)      | Clock ↑ to Data Float Delay                                        |                              | 80   |                              | 70   | ns   |
| 43      | TdCr(CTz)     | Clock ↑ to Control Out-puts Float<br>Delay(MREQ, IORQ, RD, and WR) | -                            | 70   | _                            | 60   | ns   |
| 44      | TdCr(Az)      | Clock ↑ to Address Float Delay                                     |                              | 80   |                              | 70   | ns   |

AC Electrical Characteristics (3/3)

| NO. SYMBOL |              | ITEM                                                           |      | AP-6/AM-6<br>/AT-6<br>(6MHz) |      | AP-8/AM-8<br>/AT-8<br>(8MHz) |    |
|------------|--------------|----------------------------------------------------------------|------|------------------------------|------|------------------------------|----|
|            |              |                                                                | MIN. | MAX.                         | MIN. | MAX.                         |    |
| 45         | TdCr(A)      | MREQ, IORQ, RD, and WR to Address Hold Time                    | 35   |                              | 20   | _                            | ns |
| 46         | TsRESET(Cr)  | RESET to Clock ↑ setup Time                                    | 60   | -                            | 45   | -                            | ns |
| 47<br>*    | ThRESET(Cr)  | RESET to Clock ↑ Hold Time                                     | 10   | _                            | 10   |                              | ns |
| 48         | TsINTf(Cr)   | INT to Clock ↑ Setup Time                                      | 70   | -                            | 55   | _                            | ns |
| 49<br>*    | TsINTr(Cr)   | INT to Clock ↑ Hold Time                                       | 10   |                              | 10   | _                            | ns |
| 50<br>*    | TdM1f(lORQf) | $\overline{M1} \downarrow to \overline{IORQ} \downarrow Delay$ | 365  | _                            | 270  | _                            | ns |
| 51         | TdCf(IORQf)  | Clock↓to IORQ↓Delay                                            | -    | 70                           | -    | 60                           | ns |
| 52         | TdCr(lORQr)  | $Clock \uparrow to \overline{IORQ} \uparrow Delay$             | -    | 70                           |      | 60                           | ns |
| 53         | TdCf(D)      | Clock↓to Data Valid Delay                                      | -    | 130                          |      | 115                          | ns |

060489

Note 1 AC Test Condition

 $\label{eq:VIH} \begin{array}{l} VIH = 2.4 V, VIL = 0.4 V, VIHC = V_{CC} - 0.6 V, VILC = 0.6 V \\ VOH = 2.2 V, VOL = 0.8 V, CL = 100 PF \end{array}$ 

Note 2 Items with an asterisk (\*) are non-compatible with NMOS Z80.

#### 4.4 CAPACITANCE

 $\mathrm{TA}\,{=}\,25^{\circ}\mathrm{C}$ 

| SYMBOL | ITEM                    | TEST CONDITION    | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|-------------------|------|------|------|------|
| CCLOCK | Clock input Capacitance | f = 1MHz          | -    | . —  | 8    | РF   |
| CIN    | Input Capacitance       | I measured are    | —    | -    | 6    | рF   |
| COUT   | Output Capacitance      | connected to GND. | —    | —    | 10   | рF   |

#### 4.5 TIMING DIAGRAM

Figure 4.1 to 4.8 show the basic timings of respective operations. Numbers shown in the Figures correspond with those in the AC Electrical Characteristics Table in 4.3.





MPUZ80-51





Figure 4.3 Input/Output Cycle



Note 1 TL is the final state of the preceding instruction. Note 2 2 wait state (TW\*) is inserted automatically by MPU.





060489

Note:  $\overline{\text{NMI}}$  is asynchoronous input but in order to assure the positive response in the following cycle,  $\overline{\text{NMI}}$  trailing edge signal must be generated keeping abreast of the leading edge of the preceding TL state.





Note 1 : TL is the final state of any machine cycle

Note 2: TX is optional clock used by requested peripheral LSI.

Figure 4.6 Bus Request/Acknowledge Cycle











# TOSHIBA

# 5. PACKAGE DIMENSION

5.1 DIP PACKAGE

DIP40-P-600

Unit : mm



- Note 1 : This dimension is measured at the center of bending points of leads.
- Note 2: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.40 leads.

#### MPUZ80-55

### TOSHIBA

## 5.2 SOP PACKAGE

SSOP40-P-450

Unit : mm



270289

Note: Package Width and length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

### 5.3 PLCC PACKAGE

# QFJ44-P-S650



270289

15.76 ± 0.2

### TOSHIBA

## 6. CAUTIONS

Please observe the following cautions when using the TMPZ8400A.

- (1) The RESET signal input used for resetting must be held at "0" for at least 3 clocks.
- (2) When the MPU is not the bus master (BUSREQ=0), the memory is not refreshed because the RFSH signal is "1" and address signals are at high impedance. With systems using dynamic RAM, an external circuit is required for memory refresh if this condition persists for any length of time.

Also, interrupts cannot be received when the MPU is not the bus master.

- (3) When exiting a power down operation with the MPU in hold status, supply the prescribed stabilized clock.
- (4) Maskable interrupt mode 2 is only for use with Z80 family peripheral LSIs.
- (5) Only the program counter, interrupt enable flip-flop, internal NMI flip-flop, I register and R register of the MPU are initialized. All other registers must be initialized by program when necessary. Also, set the interrupt mode to mode 0.
- (6) The interrupt enable flip-flop is set to "1" by the instruction following the EI instruction to enable receipt of maskable interrupts.
- (7) Only the program counter register is saved during interrupt processing. Save and restore interrupt processing routines as necessary.
- (8) When using maskable interrupt mode 2, a data table for the vector addresses must be created in the memory.
- (9) When periphral LSIs and memory are connected with the MPU on a PCB, use wiring as large as possible and the shortest routing for connecting Vss (GND) and Vcc.

Caution is necessary because of the large spike currents which can occur when signals change  $(0\rightarrow 1, 1\rightarrow 0)$  with high-speed versions.

(10) As countermeasures for the above, connect a capacitor with good pulse response between Vcc and Vss (GND) of the MPU and other devices to absorb the pulse current.

# TMPZ84C01F, TMPZ84C02AF-6 TLCS-Z80MPU : 8-BIT MICROPROCESSOR CMOS Z80 8-BIT MICROPROCESSOR

## 1. OUTLINE AND FEATURES

The TMPZ84C01F/02AF-6 is an 8-bit microprocessor (hereinafter referred to as MPU) with a built-in clock generator/controller, which provides low power operation and high performance.

Built into the TMPZ84C01F/02AF-6 are a control function and clock generator for the standby function in addition to paired 6 general purpose registers, accumulator, flag registers, an arithmetic-and-logic unit, bus control, memory control and timing control circuits. TMPZ84C02AF-6 can insure duty 50% clock output easily with Internal Oscillation Divider.

The TMPZ84C01F/02AF-6 is fabricated using Toshiba's CMOS Silicon Gate Technology and molded in a 44-pin mini-flat package.

The principal functions and features of the TMPZ84C01F/02AF-6 are as follows.

- (1) Instruction Set compatible with the Zilog's Z80 MPU.
- (2) Low power consumption

| Product name  | Operating<br>frequency      | RUN MODE | IDLE1 MODE | IDLE2 MODE | STOP MODE |
|---------------|-----------------------------|----------|------------|------------|-----------|
| TMPZ84C01F    | fosc = 4MHz<br>fCLK = 4MHz  | 15mA     | 1mA        | 3mA        | 0.5µA     |
| TMPZ84C02AF-6 | fosc = 12MHz<br>fCLK = 6MHz | 20mA     | 1.5mA      | 4.5mA      | 0.5µA     |

#### Table 1.1 Operation modes and Supply Current (Vcc = 5v.TYPICAL)

- (3) DC to 6MHz operation (at  $5V \pm 10\%$ )
- (4) Single 5V power supply (at  $5V \pm 10\%$ )
- (5) Operating temperature  $(-40^{\circ}C \text{ to } 85^{\circ}C)$
- (6) On-chip clock generator
- (7) In the HALT state, the following 4 modes are selectable:
  - Run mode
  - IDLE 1 mode
  - IDLE 2 mode
  - STOP mode

In the following explanation for the same content, IDLE1 Mode and IDLE2 Mode are referred to as IDLE1/2.

- (8) Powerful set of 158 instructions available
- (9) Powerful interrupt function
  - (a) Non-maskable interrupt terminal (NMI)
  - (b) Maskable interrupt terminal  $(\overline{INT})$

The following 3 modes are selectable ;

- 8080 compatible interrupt mode (interrupt by Non-Z80 family peripharal LSI) (Mode 0)
- Restart interrupt (Mode 1)
- Daisy chain structure interrupt using Z80 family peripheral LSI (Mode 2)
- (10) An auxiliary register provided to each of general purpose registers.
- (11) Two index registers
- (12) 10 addressing modes
- (13) Built-in refresh circuit for dynamic memory.
- (14) Molded in 44-pin mini flat package
- (15) Built-in clock divider for insuring duty 50% easily (TMPZ84C/02AF-6)
- (16) Low voltage oparation  $Vcc = 2.7V \sim 5.5V$  (TMPZ84C01F)

Further, in the following text and explanations for charts and tables, hexadecimal numbers are directly used without giving an identification to explanation of address, etc. to the extent not to cause confusions.

Note: Z80 is a trademark of Zilog Inc., U.S.A.

## 2. PIN CONNECTIONS AND PIN FUNCTIONS

The pin connections and I/O pin names and brief functions of the TMPZ84C01/02A are shown below.

#### 2.1 PIN CONNECTIONS

The pin connections of the TMPZ84C01/02A are as shown in Figure 2.1.



060489

Note: Connect Pin 39 and Pin 17 externally.

## Figure 2.1 Pin Connections (Top View)

### 2.2 PIN NAMES AND FUNCTIONS

I/O pin names and functions are as shown in Table 2.1.

| Pin Name | Number<br>of Pin | Input/Output<br>3-state | Function<br>16-bit address bus.<br>Specify addresses of memories and I/O to be accessed. During the<br>refresh period, addresses for refreshing are output. |  |
|----------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| A0~A15   | 16               | Output<br>3-state       |                                                                                                                                                             |  |
| MS1, MS2 | 2                | Input                   | Mode selection input.<br>One of 4 modes (RUN, IDLE1/2, STOP) is selected according to the<br>state of these 2 pins.                                         |  |

| Table 2.1 | Pin Names and Functions (1 | /3) |
|-----------|----------------------------|-----|
|-----------|----------------------------|-----|

| Number<br>of Pin | Input/Output<br>3-state                                                                                                 | Function                                                                                                                                                                                                                                                                                                                                                |  |
|------------------|-------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 8                | I/O<br>3-state                                                                                                          | 8-bit bidirectional data bus.                                                                                                                                                                                                                                                                                                                           |  |
| 1                | Input                                                                                                                   | Maskable interrupt request signal.<br>Interrupt is generated by peripheral LSI. This signal is accepted if the<br>interrupt enable flip-flop (IFF) is set at "1".<br>INT is normally used on Wired-OR. In this case, a pull-up resistor is<br>externally connected.                                                                                     |  |
| 1                | Input                                                                                                                   | Non-maskable interrupt request signal.<br>This interrupt request has the higher priority than the maskable<br>interrupt request and does not rely upon the state of the interrupt<br>enable flip-flop (IFF).                                                                                                                                            |  |
| 1                | Output                                                                                                                  | Halt signal.<br>MPU execute HALT instruction and when the halt state is resulted.<br>"0" is output.                                                                                                                                                                                                                                                     |  |
| 1 '              | Output<br>3-state                                                                                                       | Memory request signal.<br>When an effective address for memory access is on the address bus<br>"0" is output.<br>I/O request signal.                                                                                                                                                                                                                    |  |
| 1                | Output<br>3-state                                                                                                       | I/O request signal.<br>When addresses for I/O are on the lower 8 bits (A0-A7) of the<br>address bus in the I/O operation, "0" is output. In addition, IORC<br>signal is output together with M1 signal at time of interrup<br>acknowledge cycle to inform peripheral LSI of the state that the<br>interrupt response vector may be put on the data bus. |  |
| 1                | Output<br>3-state                                                                                                       | Read signal<br>"O" signal is output for a period when MPU can receive data from a<br>memory or peripheral LSI. It is possible to put data from a specified<br>peripheral LSI or memory on the MPU data bus after gating by this<br>signal.                                                                                                              |  |
| 1                | Output<br>3-state                                                                                                       | Write signal.<br>This signal is output when data to be stored in a specified memory<br>or peripheral LSI is on the MPU data bus.                                                                                                                                                                                                                        |  |
| 1                | Output                                                                                                                  | Bus acknowledge signal.<br>In response to $\overline{\text{BUSREQ}}$ signal, this signal informs a peripheral LSI of<br>the fact that the address bus, data bus, $\overline{\text{MREQ}}$ , $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ and $\overline{\text{WR}}$<br>signals have been placed in the high impedance state.                       |  |
| 1                | Input                                                                                                                   | Wait signal.<br>WAIT signal is a signal to inform MPU of specified memory or<br>peripheral LSI which is not ready for data transfer. As long as WAIT<br>signal as at "0" level, MPU is continuously kept int the wait state.                                                                                                                            |  |
|                  | Number   of Pin   8   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1   1 | NomberInput Output3-state3-state1Input1Input1Output1Output1Output1Output1Output1Output1Output1Output3-state3-state1Output1Output1Output1Output1Output1Input1Input1Input                                                                                                                                                                                 |  |

Table 2.1 Pin Names and Functions (2/3)

| Pin Name                            | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                               |  |  |
|-------------------------------------|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| BUSREQ                              | 1                | Input                   | Bus request signal.<br>BUSREQ signal is a signal requesting placement of the address bus ,<br>data bus, MREQ, IORQ, RD and WR signals in the high impedance<br>state. BUSREQ signal is normally used on wired-OR. In this case, a<br>pull-up resistor is externally connected.                         |  |  |
| RESET                               | 1                | Input                   | Reset signal.<br>RESET signal is used for initialization MPU and must be kept in active<br>state ("0") for a period of at least 3 clocks.                                                                                                                                                              |  |  |
| MI                                  | 1                | Output                  | Signal showing machine cycle 1.<br>"0" is output together with MREQ signal in the operation code fetch<br>cycle.<br>This signal is output for every opcode fetch when 2byte opcode is<br>executed.<br>In the maskable interrupt acknowledge cycle, this signal is output<br>together with IORQ signal. |  |  |
| XTAL 1<br>(XIN)<br>XTAL 2<br>(XOUT) | 2                | Input<br>output         | Crystal oscillator connecting terminal.<br>For 01F, connects an oscillator having the oscillation frequency as<br>high as the system clock (CLK) frequency.<br>For 02AF/02AF-6, connects an oscillator having the oscillation<br>frequency 2 times as high as the system clock (CLK) frequency.        |  |  |
| CLK                                 | 1                | Output                  | Single-phase clock output.<br>When the HALT instruction in STOP Mode is executed, MPU stops its<br>operation and holds clock output at "0" level.                                                                                                                                                      |  |  |
| Vcc (1),<br>(2)                     | 2                | Power<br>supply         | + 5<br>Connent 39 pin and 17 pin externally.                                                                                                                                                                                                                                                           |  |  |
| Vss                                 | 1                | Power<br>supply         | 0V                                                                                                                                                                                                                                                                                                     |  |  |

Table 2.1 Pin Names and Functions (3/3)

## 3. FUNCTIONAL DESCRIPTION

The system configuration, functions and basic operation of the TMPZ84C01F/02AF-6 are described here.

#### 3.1 BLOCK DIAGRAM

The block diagram of the interval configuration is shown in Figure 3.1.





### 3.2 SYSTEM CONFIGURATION

The TMPZ84C01F/02AF-6 has a built-in system clock generator for CMOS Z80 in addition to the standard functions of the TMPZ84C00A CMOS Z80 MPU.

The explanation is provided here with emphases placed on the halt function relative to the clock generator, which is an additional function. The internal register group, reset and interrupt function are identical to those of the TMP84C00A. For details please refer to the data sheet for the TMP284C00A.

In this section, the following principal components and functions will be described,

- (1) Generation of clock
- (2) Operation mode
- (3) Warming-up time at time of restart

### 3.2.1 Generating the system clock

The TMPZ84C01F/02AF-6 has a built-in oscillation circuit and required clock can be easily generated by connecting an oscillator to the external terminals (XTAL1, XTAL2). For the TMPZ84C01F, Clock in the same frequency as input oscillation frequency is generated. As the TMPZ84C02AF-6 has a built-in divider, Clock in the half frequency as input oscillation frequency is generated.

Examples of oscillator connection are shown in Figure 3.2.



Figure 3.2 Example of Oscillator Connection

| rable off                |      |      | ang capacitance        |
|--------------------------|------|------|------------------------|
| Oscillation<br>Frequency | CIN  | соит | Application<br>Product |
| 4MHz                     | 22PF | 33PF | TMPZ84C01F             |
| 8MHz                     | 22PF | 33PF | TMPZ84C02AF-6          |
| 12MHz                    | 33PF | 33PF | TMPZ84C02AF-6          |

Table 3.1 External connecting capacitance

In case of using Crystal oscillator, please use products with the following characteristics or use the following maker's products.



Figure 3.2 Crystal oscillator equivalent circuit

| -                        |          |                  |                        |
|--------------------------|----------|------------------|------------------------|
| Oscillation<br>Frequency | CS       | Rs               | Application<br>Product |
| 4MHz                     | under4PF | under50 $\Omega$ | TMPZ84C01F             |
| 8MHz                     | under4PF | under $30\Omega$ | TMPZ84C02AF-6          |
| 12MHz                    | under4PF | under25 $\Omega$ | TMPZ84C02AF-6          |

Table 3.2 Crystal oscillator necessary characteristics

Table 3.3 Crystal oscillator of recommendation

| Oscillation<br>Frequency | Product name | Maker            |
|--------------------------|--------------|------------------|
| 4MHz                     | MR4000-C20   |                  |
| 8MHz                     | MR8000-C20   | Tokyo Denpa Inc. |
| 12MHz                    | MR12000-C20  |                  |

170489

#### 3.2.2 Operation modes

There are 4 kinds of operations modes available for the TMPZ84C01F/02AF-6 in connection with generation of clock; RUN Mode, IDLE1/2 Modes and STOP Mode. One of these modes is selected by the mode select inputs (MS1, MS2).

The operation mode is effective when the halt instruction is executed and when the halt instruction is not executed, clock is supplied continuously. Restart of MPU from the stopped state under IDLE1/2 Mode or STOP Mode is effected by inputting either  $\overline{\text{RESET}}$  signal or interrupt signal ( $\overline{\text{INT}}$  or  $\overline{\text{NMI}}$ ).

Operations of these modes in the halt state are shown in Table 3.4.

| Operation<br>Mode | MS1 | MS2 | Description at HALT State                                                                                                                                                                           |  |
|-------------------|-----|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| RUN Mode          | 1   | 1   | MPU continues the operation and supplies clock to the outside continuously.                                                                                                                         |  |
| IDLE1 Mode        | 0   | 0   | The internal oscillator's operation only is continued and clock (CLK) output as well as internal operation are stopped at "0" level of T4 state in the halt instruction operation code fetch cycle. |  |
| IDLE2 Mode        | 0   | 1   | The internal oscillator's operation and clock (CLK) output are continued but the internal operation are stopped at "0" level of T4-state in the halt instruction operation code fetch cycle.        |  |
| STOP Mode         | 1   | 0   | All operations of the internal oscillator, clock (CLK) output, and internal operation are stopped at "0" level of T4 state in the halt instruction operation code fetch cycle.                      |  |

Table 3.4 Clock Generating Operation Modes

#### 3.2.3 Warming-up time at time of restart (STOP Mode)

When MPU is released from the halt state by accepting an interrupt request, MPU, then, will execute an interrupt service routine. Therefore, when an interrupt request is accepted, MPU starts generation of internal system clock and clock output after a warming-up time by the internal counter  $(2^{14} + 2.5)$  TcC (TcC; Clock Cycle) to obtain a stabilized oscillation for MPU operation.

Further, in case of the restart by RESET signal, the internal counter does not operate for a quick operation at time of power ON.

#### 3.3 STATUS CHANGE FLOWCHART AND BASIC TIMING

In this section, the status change and basic timing when the TMPZ84C01F/02AF-6 is operating are explained.

### 3.3.1 Status change flowchart



Figure 3.4 (a) Status Change Flowchart



Figure 3.4 (b) Status Change Flowchart

#### 3.3.2 Basic timing

The basic timing is explained here with emphases placed on the halt function relative to the clock generator. Except  $\overline{\text{RFSH}}$  signal output, the following items are identical to those for the TMPZ84C00A. Refer to the data sheet for the TMPZ84C00A.

- Operation code fetch cycle
- Memory read/write operation
- Input/output operation
- Bus request/acknowledge operation
- Maskable interrupt request accepting operation
- Non-maskable interrupt request accepting operation
- Reset operation

Note that the TMPZ84C01F/02AF-6 dose not have the refresh terminal  $\overline{\text{RFSH}}$  but refresh address is output on the address bus in the operation code fetch cycle ( $\overline{\text{M1}}$ ) as in the TMPZ84C00A since the on-chip refresh control circuit is available.

(1) Operation when HALT instruction is execution

When MPU fetches a halt instruction in the operation code fetch cycle, HALT signal goes active (low level) in synchronous with falling edge of T4 state for the peripheral LSI and MPU stops the operation. The system clock generating operation after this differs depending upon the operation mode (RUN Mode, IDLE1/2 Mode or STOP Mode). If the internal system clock is running, MPU continues to execute NOP instruction even in the halt state.

(a) RUN Mode (MS1 = 1, MS2 = 1)

Shown in Figure 3.6 is the basic timing when the halt instruction is executed in RUN Mode.

In RUN Mode, system clock ( $\emptyset$ ) in MPU and clock output (CLK) to the outside of MPU are not stopped even after the halt instruction is executed. Therefore, until the halt state is released by the interrupt signal ( $\overline{\text{MNI}}$  OR  $\overline{\text{INT}}$ ) or  $\overline{\text{RESET}}$  signal, MPU continues to execute NOP instruction.



Figure 3.6 Timing of RUN Mode (at Halt Instruction Execution)

(b) IDLE1 Mode (ML1 = 0, MS2 = 0)

Shown in Figure 3.7 is the basic timing when the halt instruction is executed in IDLE1 Mode.

In IDLE1 Mode, system clock  $(\emptyset)$  in MPU and clock output (CLK) to the outside of MPU are stopped and MPU stops its operation after the halt instruction is executed.

However, the internal oscillator continues to operate.



Figure 3.7 IDLE1 Mode Timing (at Halt Instruction Execution)

(c) IDLE2 Mode (MS1 = 0, MS2 = 1)

Shown in Figure 3.8 is the basic timing when the halt instruction is executed in IDLE2 Mode.

In IDLE2 Mode, system clock ( $\phi$ ) in MPU is stopped and MPU stops its operation after the halt instruction is executed.

However, the internal oscillator and clock output (CLK) to the outside of MPU continues to operate.



Figure 3.8 IDLE2 Mode timing (at Halt Instruction Execution)

(d) STOP Mode (MS1 = 1, MS2 = 0)

Shown in Figure 3.9 is the basic timing when the halt instruction is executed in STOP Mode.

In STOP Mode, internal operation and internal oscillator are stopped after the halt instruction is executed. Therefore, system clock ( $\emptyset$ ) in MPU and clock output (CLK) to the outside of MPU are stopped.



Figure 3.9 STOP Mode Timing (at Halt Instruction Execution)

#### (2) Release from halt state

The halt state of MPU is released when "0" is input to  $\overline{\text{RESET}}$  signal and MPU is reset or an interrupt request is accepted. An interrupt request signal is sampled at the leading edge of the last clock cycle (T4 state) of NOP instruction. In case of the maskable interrupt, interrupt will be accepted by an active  $\overline{\text{INT}}$  signal ("0" level). In case of the non-maskable interrupt, if the internal  $\overline{\text{NMI}}$  F/F which is set at the leading edge of  $\overline{\text{MNI}}$  signal is set to "1", the interrupt is accepted.

However, in case of the maskable interrupt, the interrupt enable flip-flop must have been set to "1". The accepted interrupt process is started from next cycle.

Further, when the internal system clock is stopped (IDLE1/2 Mode, STOP Mode), it is necessary first to restart the internal system clock. The internal system clock is restarted when  $\overrightarrow{\text{RESET}}$  or interrupt signal ( $\overrightarrow{\text{NMI}}$  or  $\overrightarrow{\text{INT}}$ ) is input.

#### (a) RUN Mode (MS1, MS2 = 1)

The halt release operation by acceptance of interrupt request in RUN Mode is shown in Figure 3.10.

In RUN Mode the internal system clock is not stopped and therefore, if the interruption signal is recognized at the rise of T4 state of the continued NOP instruction, MPU will executes the interrupt process from next cycle.

The halt release operation by resetting MPU in RUN Mode is shown in Figure 3.11. After reset, MPU will execute an instruction starting from address 0000H. However, in order to reset MPU it is necessary to keep RESET signal at "0" for at least 3 clocks. In addition, if RESET signal becomes "1", after the dummy cycle for at least 2T states, MPU executes an instruction from address 0000H.







Figure 3.11 Halt Release Operation Timing by Reset in RUN Mode

#### (b) IDLE1 Mode (MS1 = 0, MS2 = 0), IDLE2 Mode (MS1 = 0, MS2 = 1)

The halt release operation by interrupt signal in IDLE1 Mode is shown in Figure 3.12 (a) and in IDLE2 Mode in Figure 3.12 (b).

When receiving  $\overline{\rm NMI}$  or  $\overline{\rm INT}$  signal, MPU starts the internal system clock operation. In IDLE1 Mode, MPU starts clock output to the outside at the same time. The operation stop of MPU in IDLE1/2 Mode is taken place at "0" level during T4 state in the halt instruction operation code fetch cycle. Therefore, after restarted by the interruption signal, MPU executes one NOP instruction and samples an interrupt signal at the rise of T4 state during the execution of this NOP instruction, and executes the interrupt process from next cycle.



Fig 3.12(b) IDLE2 Mode

Fig.3.12Halt Release Operation Timing by Interrupt Request Signal in IDLE1/2 Mode

If no interrupt signal is accepted during the execution of the first NOP instruction after the internal system clock is restarted, MPU is not released from the halt state and is placed in IDLE1/2 Mode again at "0" level during T4 state of the NOP instruction, stopping the internal system clock. If  $\overline{INT}$  signal is not at "0" level at the rise of T4 state, no interrupt request is accepted.

The halt release operation by resetting MPU in IDLE1 Mode is shown in Figure 3.13 (a) and that in IDLE2 Mode in Figure 3.13 (b).

When RESET signal at "0" level is input into MPU, the internal system clock is restarted and MPU will execute an instruction stored in address 0000H.

At time of  $\overline{\text{RESET}}$  signal input, it is necessary to take the same care as that in resetting MPU in RUN Mode.



Figure 3.13 (a) IDLE1 Mode





#### (c) STOP Mode (MS1 = 1, MS2 = 0)

The halt release operation by interrupt signal in STOP Mode is shown in Figure 3.14.

When MPU received an interrupt signal, the internal oscillator is restarted. In order to obtain stabillized oscillation, the internal system clock and clock output to the outside are started after a warming-up time of  $(2^{14}+2.5)$  TcC (TcC : Clock Cycle) by the internal counter passed.

MPU executes one NOP instruction after the internal system clock is restarted and at the same time, sampling an interrupt signal at the rise of T4 state during the execution of this NOP instruction. If the interrupt signal is accepted, MPU executes the interrupt process operation from next cycle.

At time of interrupt signal input, it is necessary to take the same care as that in the interrupt signal input in IDLE1/2 Mode. The halt release operation by MPU resetting in STOP Mode is shown in Figure 3.15.

When RESET signal at "0" level is input into MPU, the internal oscillator is restarted. However, since it performs a quick operation at time of power ON, the internal counter does not operate. Therefore, the operation may not be carried out properly due to unstable clock immediately after the internal oscillator is restarted. To restart the clock by RESET signal in STOP Mode, it is necessary to hold RESET signal at "0" level for sufficient time. When RESET signal becomes "1", after the dummy cycle for at least 2T states, MPU starts to execute an execution from address 0000H.



060489





Figure 3.15 Halt Release Operation Timing by Reset in STOP Mode

3.4 INSTRUCTION SET

Instruction set of the TMPZ84C01F/02AF-6 are the same as those for the TMPZ84C00A. For details refer to the data sheet for the TMPZ84C00A.

3.5 METHOD OF USE

A connecting example of the TMPZ84C01F/02AF-6 with the TLCS-Z80 family peripheral LSI's is shown in Figure 3.16. For the explanation and precautions for connection, refer to Section 3.5 Method of use of the data sheet for the TMPZ84C00A.



## 4. ELECTRICAL CHARACTERISTICS

### 4.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL  | ITEM                          | RATING                         | UNIT   |
|---------|-------------------------------|--------------------------------|--------|
| VCC     | Supply Voltage                | – 0.5 to + 7                   | V      |
| VIN     | Input Voltabe                 | – 0.5 to V <sub>CC</sub> + 0.5 | V      |
| PD      | Power Dissipation (TA = 85°C) | 250                            | mW     |
| TSOLDER | Soldering Temperature (10sec) | 260                            | °C     |
| TSTG    | Storage Temperature           | – 65 to 150                    | °C     |
| TOPR    | Operating Temperature         | – 40 to 85                     | °C     |
|         |                               |                                | 060489 |

### 4.2 DC ELECTRICAL CHARACTERISTICS

### 4.2.1 DC Chracteristics

## $T_A\!=\!10^\circ\!C$ to $+\,60^\circ\!C\,(TMPZ84C01F\,@$ Low voltage operation)

| SYMBOL | ITEM                                 | TEST CONDITION | MIN.    | TYP. | MAX.      | UNIT |
|--------|--------------------------------------|----------------|---------|------|-----------|------|
| VCC    | Supply Voltage                       |                | 2.7     |      | 5.5       | V    |
| VIHC   | Input High Voltage<br>(XTAL1)        |                | VCC-0.2 | -    | VCC + 0.3 | v    |
| VIH    | Input High Voltage<br>(Except XTAL1) |                | VCC-0.2 | -    | VCC + 0.3 | v    |
| VILC   | Input Low Voltage<br>(XTAL1)         |                | -0.3    | _    | 0.2       | v    |
| VIL    | Input Low Voltage<br>(Except XTAL1)  |                | -0.5    | _    | 0.2       | v    |

## 4.2.2 DC Chracteristics (I)

 $VCC\!=\!2.7V\,$  to 5.5V,  $T_A\!=\!-40^\circ\!C$  to  $+85^\circ\!C\,(TMPZ84C01F\,@$  Low voltage operation)

| SYMBOL | ITEM                                  | TEST CONDITION                            | MIN. | TYP. | MAX. | UNIT |
|--------|---------------------------------------|-------------------------------------------|------|------|------|------|
| ILI    | Input Leak Current                    | $VSS \le VIN \le VCC$                     | —    |      | ± 10 | μA   |
| ILO    | 3 State Output Current<br>in Floating | VSS≦VIN≦VCC                               | _    | _    | ± 10 | μA   |
| юн     | Output High Current<br>(Except XTAL2) | VOH = VCC-0.2V                            | 0.1  | _    | _    | mA   |
| IOL    | Output Low Current<br>(Except XTAL2)  | VOL = 0.2V                                | 0.4  | —    | _    | mA   |
| ICC1   | Supply Current<br>(@Run Mode)         | VCC = 3V, f = 1MHz<br>VIH = Vcc, VIL = 0V | _    | 2.5  | 5.0  | mA   |
| ICC2   | Supply Current<br>(@Stop Mode)        | VCC = 3V,<br>VIH = Vcc, VIL = 0V          | _    | 0.5  | 10   | μА   |
| ICC3   | Supply Current<br>(@IDLE1 Mode)       | VCC = 3V, f = 1MHz<br>VIH = Vcc, VIL = 0V | _    | 0.5  | 1.0  | mA   |
| ICC4   | Supply Current<br>(@IDLE2 Mode)       | VCC = 3V, f = 1MHz<br>VIH = Vcc, VIL = 0V | _    | 1.0  | 2.0  | mA   |

## 4.2.3 DC Chracteristics (II)

| $T_A = -40^{\circ}C$ to 85°C, VCC = 5 V $\pm 10^{\circ}$ , VS | S = 0V | VSS | $=5V \pm 10\%$ | VCC= | 85°C, | $-40^{\circ}$ C to | $T_A =$ |
|---------------------------------------------------------------|--------|-----|----------------|------|-------|--------------------|---------|
|---------------------------------------------------------------|--------|-----|----------------|------|-------|--------------------|---------|

| SYMBOL | ITEM                                       | TEST CONDIT                               | ION           | MIN.                  | TYP. | MAX. | UNIT |
|--------|--------------------------------------------|-------------------------------------------|---------------|-----------------------|------|------|------|
| VOLC   | Low Level Clock Output<br>Voltabe          | IOL = 2.0mA                               |               | -                     | _    | 0.4  | v    |
| voнc   | High Level Clock<br>Output Voltage         | IOH = - 2.0mA                             |               | V <sub>CC</sub> – 0.6 |      |      | v    |
| VIL    | Input Low Voltage                          |                                           |               | - 0.5                 |      | 0.8  | V    |
| VIH    | Input High Voltage                         |                                           |               | 2.2                   |      | VCC  | V    |
| VIHR   | Input High Voltage<br>(RESET)              |                                           |               | V <sub>CC</sub> – 0.6 | _    | vcc  | v    |
| VILR   | Input Low Voltage<br>(RESET)               |                                           |               | - 0.5                 | _    | 0.45 | v    |
| VOL    | Output Low Voltage<br>(Except Clock)       | IOL = 2.0mA                               |               | _                     | _    | 0.4  | v    |
| VOH1   | Output High Voltage<br>(I) (Except Clock)  | IOH = - 1.6mA                             | IOH = - 1.6mA |                       | _    | _    | v    |
| VOH2   | Output High Voltage<br>(II) (Except Clock) | IOH = - 250uA                             |               | VCC – 0.8             | _    | _    | v    |
| ILI    | Input Leak Current                         | VSS≦ VIN≦ VCC                             |               | -                     |      | ± 10 | μA   |
| ILO    | 3 State Output<br>Current in Floating      | VSS + 0.4≦ VOUT≦<br>VCC                   |               | -                     | _    | ± 10 | μA   |
| ICC1   | Supply Current<br>(@ RUN Mode)             | VCC = 5V,<br>fCLK = (NOTE1)<br>VIHC = VIH | 01F           | -                     | 15   | 20   | mA   |
|        |                                            | = VCC – 0.2,<br>VILC = VIL = 0.2V         | 02AF<br>-6    | -                     | 20   | 24   |      |

170489

| SYMBOL | ITEM                             | TEST CONDITION                                                                    |        | MIN. | TYP. | MAX. | UNIT |  |
|--------|----------------------------------|-----------------------------------------------------------------------------------|--------|------|------|------|------|--|
| ICC2   | Supply Current<br>(@ STOP Mode)  | VCC = 5V, fCLK = (Note2)<br>VIHC = VIH = VCC - 0.2V<br>VILC = VIL = 0.2V          |        | _    | 0.5  | 10   | μА   |  |
| ICC3   | Supply Current<br>(@ IDLE1 Mode) | VCC = 5V,<br>fCLK = (Note1)<br>VIHC = VIH =                                       |        | —    | 1.0  | 2.0  | mΔ   |  |
|        |                                  | VCC – 0.2V<br>VILC = VIL =<br>0.2V                                                | 02AF-6 | -    | 1.5  | 3.0  |      |  |
| ICC4   | Supply Current<br>(@ IDLE2 Mode) | VCC = 5V,<br>fCLK = (Note1)<br>VIHC = VIH =<br>VCC - 0.2V<br>VILC = VIL =<br>0.2V | 01F    | _    | 3.0  | 6.0  | m۸   |  |
|        |                                  |                                                                                   | 02AF-6 |      | 4.5  | 7.5  |      |  |
| 170489 |                                  |                                                                                   |        |      |      |      |      |  |

Note 1:  $fCLK = 1/T_{CC}$  (MIN) Note 2: At T4 "LOW" state of the halt instruction fetch cycle.

## 4.3 AC ELECTRICAL CHARACTERISTICS

## $\mathrm{TOPR}\!=\!-40\,^\circ\!\mathrm{C}$ to $85\,^\circ\!\mathrm{C}$ , $\mathrm{VCC}\!=\!5\mathrm{V}\!\pm\!10\%,\mathrm{VSS}\!=\!0\mathrm{V}$

|         |                   |                                                   |      |                                                     |      |                      |      |                         | (1/4) |
|---------|-------------------|---------------------------------------------------|------|-----------------------------------------------------|------|----------------------|------|-------------------------|-------|
| No.     | SYMBOL            | SYMBOL ITEM                                       |      | 01F<br>(V <sub>CC</sub> = 2.7V~5.5V<br>fCLK = 1MHz) |      | 01F<br>(fCLK = 4MHz) |      | 02AF-6<br>(fCLK = 6MHz) |       |
|         |                   |                                                   | MIN. | MAX.                                                | MIN. | MAX.                 | MIN. | MAX.                    |       |
| 1       | T <sub>C</sub> C  | Clock frequency                                   | 1000 | DC                                                  | 250  | DC                   | 165  | DC                      | ns    |
| 2       | T <sub>W</sub> Ch | High clock pulse width                            | 400  | DC                                                  | 110  | DC                   | 65   | DC                      | ns    |
| 3       | T <sub>W</sub> CI | Low clock pulse width                             | 400  | DC                                                  | 110  | DC                   | 65   | DC                      | ns    |
| 4       | TfC               | Clock falling time                                | -    | 200                                                 | -    | 30                   | —    | 20                      | ns    |
| 5       | TrC               | Clock rising time                                 |      | 200                                                 |      | 30                   | -    | 20                      | ns    |
| 6       | TdCr (A)          | Effective address output<br>delay from clock rise | _    | 400                                                 | _    | 110                  | -    | 90                      | ns    |
| 7       | TdA (MREQf)       | Address output definite time prior to MREQ        | 200  | _                                                   | 65   | -                    | 35   | -                       | ns    |
| 8       | TdCf (MREQf)      | Delay from clock fall to $\overline{MREQ} = "L"$  | -    | 300                                                 | -    | 85                   | -    | 70                      | ns    |
| 9       | TdCr (MREQr)      | Delay from clock rise to<br>MREQ = "H"            | _    | 300                                                 | _    | 85                   | _    | 70                      | ns    |
| 10      | TwMREQh           | MREQ high level pulse width                       | 400  | -                                                   | 110  | -                    | 65   | -                       | ns    |
| 11      | TwMREQI           | MREQ low level pulse width                        | 800  | -                                                   | 220  | -                    | 135  | -                       | ns    |
| 12      | TdCf (MREQr)      | Delay from clock fall to $\overline{MREQ} = "H"$  | _    | 300                                                 | _    | 85                   | -    | 70                      | ns    |
| 13      | TdCf (RDf)        | Delay from clock fall to $\overline{RD} = "L"$    | _    | 350                                                 |      | 95                   | _    | 80                      | ns    |
| 14      | TdCr (RDr)        | Delay from clock rise to<br>RD = "H"              | -    | 300                                                 | _    | 85                   | _    | 70                      | ns    |
| 15      | TsD (Cr)          | Data set-up time for clock<br>rise                | 180  | -                                                   | 35   | -                    | 30   | -                       | ns    |
| 16      | ThD (RDr)         | Data hold time for RD rise                        | 0    | - '                                                 | 0    |                      | 0    | -                       | ns    |
| 17      | TsWAIT (Cf)       | WAIT signal set-up time for clock fall            | 350  | -                                                   | 70   | —                    | 60   | -                       | ns    |
| 18<br>* | ThWAIT (Cf)       | WAIT hold time after clock fall                   | 10   | -                                                   | 10   | —                    | 10   | —                       | ns    |
| 19      | TdCr (M1f)        | Delay from clock rise to<br>M1 = "L"              |      | 400                                                 | _    | 100                  |      | 80                      | ns    |

### TMPZ84C01/02A

|         |               |                                                                         |                                                          |      |              |                      |      |                         | (2/4) |
|---------|---------------|-------------------------------------------------------------------------|----------------------------------------------------------|------|--------------|----------------------|------|-------------------------|-------|
| No.     | SYMBOL        | ITEM                                                                    | 01F<br>(V <sub>CC</sub> = 2.7V~5.5V<br>fCLK = 1MHz) (fCL |      | 0<br>(fCLK = | 01F<br>(fCLK = 4MHz) |      | 02AF-6<br>(fCLK = 6MHz) |       |
|         |               |                                                                         | MIN.                                                     | MAX. | MIN.         | MAX.                 | MIN. | MAX.                    |       |
| 20      | TdC r(M1r)    | Delay from clock rise to<br>M1 = "H"                                    | _                                                        | 400  | _            | 100                  | _    | 80                      | ns    |
| 21      | TdCf (RDr)    | Delay from clock fall to<br>RD = "H"                                    | -                                                        | 300  | _            | 85                   | —    | 70                      | ns    |
| 22      | TdCr (RDf)    | Delay from clock rise to RD = "L"                                       | _                                                        | 300  | _            | 85                   |      | 70                      | ns    |
| 23      | TsD (Cf)      | Data set-up time for clock<br>fall (at time of M2, M3, M4,<br>M5 cycle) | 250                                                      | -    | 50           | _                    | 40   | -                       | ns    |
| 24      | TdA (IORQf)   | Address definite time prior to IORQ fall                                | 550                                                      | —    | 180          | —                    | 110  | -                       | ns    |
| 25      | TdCr (IORQf)  | Delay from clock rise to<br>IORQ = "H"                                  | _                                                        | 300  | _            | 75                   | _    | 65                      | ns    |
| 26      | TdCf (IORQr)  | Delay from clock fall to<br>IORQ = "H"                                  | -                                                        | 300  | _            | 85                   | -    | 70                      | ns    |
| 27      | TdD (WRf)     | Data definit time prior to<br>WR fall                                   | 200                                                      | -    | 80           | —                    | 25   | _                       | ns    |
| 28      | TdCf (WRf)    | Delay from clock fall to<br>WR = "L"                                    | _                                                        | 300  | -            | 80                   | -    | 70                      | ns    |
| 29      | TwWR          | WR pulse width                                                          | 750                                                      | -    | 220          | -                    | 135  | -                       | ns    |
| 30      | TdCf (WRr)    | Delay from clock fall to<br>WR = "H"                                    | _                                                        | 300  | —            | 80                   | _    | 70                      | ns    |
| 31      | TdD (WRf)     | Data definit time prior to<br>WR fall                                   | 10                                                       |      | - 10         | _                    | - 55 |                         | ns    |
| 32      | TdCr (WRf)    | Delay from clock rise to<br>WR = "L"                                    | -                                                        | 250  |              | 65                   | -    | 60                      | ns    |
| 33      | TdWRr (D)     | Output data holding after<br>WR = "H"                                   | 200                                                      | -    | 60           | _                    | 30   | _                       | ns    |
| 34      | TdCf (HALT)   | Delay from clock fall to<br>HALT = "L" or"H"                            | _                                                        | 1000 | _            | 300                  | _    | 260                     | ns    |
| 35      | TwNMI         | NMI pulse width                                                         | 300                                                      | -    | 80           | -                    | 70   | -                       | ns    |
| 36      | TsBUSREQ (Cr) | Set-up time for clock rise                                              | 250                                                      | -    | 50           | -                    | 50   | -                       | ns    |
| 37<br>* | ThBUSREQ (Cr) | BUSREQ hold time after clock rise                                       | 10                                                       | _    | 10           | -                    | 10   | -                       | ns    |

|         |                |                                                                                |      |                                                     |      |                      |      |                         | (3/4) |
|---------|----------------|--------------------------------------------------------------------------------|------|-----------------------------------------------------|------|----------------------|------|-------------------------|-------|
| No.     | SYMBOL         | SYMBOL ITEM                                                                    |      | 01F<br>(V <sub>CC</sub> = 2.7V~5.5V<br>fCLK = 1MHz) |      | 01F<br>(fCLK = 4MHz) |      | 02AF-6<br>(fCLK = 6MHz) |       |
|         |                |                                                                                | MIN. | MAX.                                                | MIN. | MAX.                 | MIN. | MAX.                    |       |
| 38      | TdCr (BUSACKf) | Time from clock rise to<br>BUSACK = "L"                                        | —    | 400                                                 | _    | 100                  | -    | 90                      | ns    |
| 39      | TdCf (BUSACKr) | Time from clock fall to<br>BUSACK = "H"                                        | —    | 400                                                 |      | 100                  | _    | 90                      | ns    |
| 40      | TdCr (Dz)      | Delay from clock rise to data<br>bus float state                               | -    | 350                                                 | _    | 90                   | _    | 80                      | ns    |
| 41      | TdCr (CTz)     | Delay from clock rise to<br>control output float state<br>(MREQ, IORQ, RD, WR) | _    | 300                                                 |      | 80                   | _    | 70                      | ns    |
| 42      | TdCr (Az)      | Delay from clock rise to<br>address bus float state                            | _    | 350                                                 | _    | 90                   | _    | 80                      | ns    |
| 43      | TdCr (A)       | Address holding time from MREQ, IORQ, RD or WR                                 | 200  | -                                                   | 80   | _                    | 35   | _                       | ns    |
| 44      | TsRESET (Cr)   | RESET set-up time for clock rise                                               | 300  | —                                                   | 60   | _                    | 60   | -                       | ns    |
| 45<br>* | ThRESET (Cr)   | RESET hold time for clock rise                                                 | 10   | _                                                   | 10   | —                    | 10   |                         | ns    |
| 46      | TsINTf (Cr)    | INT set-up time for clock rise                                                 | 300  | -                                                   | 80   | -                    | 70   | —                       | ns    |
| 47<br>* | TsINTr (Cr)    | INT hold time after clock rise                                                 | 10   | _                                                   | 10   | _                    | 10   | _                       | ns    |
| 48<br>* | TdM1f (IORQf)  | M1 output ("L") definite time prior to IORQ fall                               | 2000 | -                                                   | 565  | -                    | 365  | _                       | ns    |
| 49      | TdCf (IORQf)   | Delay from clock fall to<br>IORQ = "L"                                         | -    | 300                                                 | _    | 85                   | _    | 70                      | ns    |
| 50      | TdCr (IORQr)   | Delay from clock rise to<br>IORQ = "H"                                         | _    | 300                                                 |      | 85                   | _    | 70                      | ns    |
| 51      | TdCf (D)       | Delay from clock fall to data<br>output                                        |      | 550                                                 | _    | 150                  | -    | 150                     | ns    |

|     |        |                                                   |                                                       |                                              |                      |                                                          |                         |                                              | (4/4) |  |
|-----|--------|---------------------------------------------------|-------------------------------------------------------|----------------------------------------------|----------------------|----------------------------------------------------------|-------------------------|----------------------------------------------|-------|--|
| No. | SYMBOL | ITEM                                              | 01F<br>(V <sub>CC</sub> = 2.7V~5.5V<br>fCLK = 1MHz) ( |                                              | 01F<br>(fCLK = 4MHz) |                                                          | 02AF-6<br>(fCLK = 6MHz) |                                              | UNIT  |  |
|     |        |                                                   | MIN.                                                  | MAX.                                         | MIN.                 | MAX.                                                     | MIN.                    | MAX.                                         |       |  |
| 52  | TRST1S | Clock (CLK) restart time by<br>INT (STOP mode)    |                                                       | (**)<br>(214<br>+ 2.5)<br>× T <sub>C</sub> C |                      | (**)<br>(214<br>+ 2.5)<br>x T <sub>C</sub> C             | <b></b>                 | (**)<br>(214<br>+ 2.5)<br>× T <sub>C</sub> C | ns    |  |
| 53  | TRST2S | Clock (CLK) restart time by<br>NMI (STOP mode)    | _                                                     | (**)<br>(214<br>+ 2.5)<br>× T <sub>C</sub> C | _                    | (**)<br>(2 <sup>14</sup><br>+ 2.5)<br>× T <sub>C</sub> C | _                       | (**)<br>(214<br>+ 2.5)<br>x T <sub>C</sub> C | ns    |  |
| 54  | TRST1I | Clock (CLK) restart time by<br>INT (IDLE1/2 mode) | -                                                     | (**)<br>2.5 T <sub>C</sub> C                 |                      | (**)<br>2.5 T <sub>CC</sub>                              | —                       | (**)<br>2.5 T <sub>CC</sub>                  | ns    |  |
| 55  | TRST2I | Clock (CLK) restart time by<br>NMI (IDLE1/2 mode) | _                                                     | (**)<br>2.5 T <sub>C</sub> C                 |                      | (**)<br>2.5 T <sub>C</sub> C                             | —                       | (**)<br>2.5 T <sub>C</sub> C                 | ns    |  |

170489

Note 1: Test conditions (1)  $@VCC = 5V \pm 10\%$ 

VIH=2.4V, VIL=0.4V, VIHC=VCC-0.6V, VILC=0.6V, VOH=2.2V, VOL=0.8V Test conditions (2) TMPZ84C01F @Low Voltage Operation

VIH=VCC-0.2V, VIL=0.2V, VIHC=VCC-0.2V, VILC=0.2V, VOH=VCC/2V, VOL=VCC/2V

Note 2: Items with an asterisk (\*) are non-compatible with NMOS Z80.

Note 3 : \*\*TYPICAL

#### 4.4 CAPACITANCE

 $TA = 25^{\circ}C$ 

| SYMBOL | ITEM                    | TEST CONDITION           | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|--------------------------|------|------|------|------|
| CCLOCK | CLOCK input capacitance | f = 1MHz                 | —    | -    | 8    | РF   |
| CIN    | input capacitance       | All pins except measured | -    | -    | 6    | рF   |
| COUT   | output capacitance      | pin are connected to GND | -    | -    | 10   | рF   |

#### 4.5 TIMING DIAGRAM

Figures 4.1 to 4.10 show the basic timings of respective operations. Numbers shown in the figures correspond with those in the AC Electrical Characteristics Table in 4.3.



Figure 4.1 Operation Code Fetch Cycle























070489





Note :

TL is the final state of any machine cycle.
TX is optional clock used by requested peripheral LSI.

070489







Note: INT signal is also used for releasing from the halt state.

070489

### Figure 4.7 Halt Acknowledge Cycle







Figure 4.9 Clock Restart Timing (STOP Mode)



Figure 4.10 Clock Restart Timing (IDLE1/2 Mode)

## 5. PRECAUTIONS

(1) To reset MPU, it is necessary to hold RESET signal input at "0" level for ; least 3 clocks.

In particular, to release the HALT state by  $\overline{\text{RESET}}$  signal in STOP Mode, hold  $\overline{\text{RESET}}$  signal at "0"level for sufficient time in order to stabilize output from the internal oscillator.

(2) In releasing MPU from the HALT state by interrupt signal in IDLE1/2 Mode and STOP Mode, MPU will not be released from the HALT state and the internal system clock will stop again unless an interrupt signal is accepted during the execution of NOP instruction even when the internal system clock is restarted by the interrupt signal input. In particular, care must be taken when INT is used.

Other precautions are identical to those for the TMPZ84C00A except those for  $\overline{\text{RFSH}}$  terminal. Refer to the data sheet for the TMPZ84C00A.

## 6. OUTLINE DRAWING

QFP44-P-1414F

Unit : mm



170489

Note: Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

# TMPZ84C10AP-6 / TMPZ84C10AM-6 / TMPZ84C10AT-6 CMOS-Z80 DMA : DIRECT MEMORY ACCESS CONTROLLER

## 1. GENERAL DESCRIPTION AND FEATURES

TMPZ84C10A (hereinafter referred to as DMA) is the CMOS Z80 DMA (Direct Memory Access Controller) which provides low power consuming but powerful and versatile operations.

This DMA is designed to improve system performance by allowing the system memory and peripheral LSI's to directly transfer data between them.

Memory-to-memory and I/O-to-I/O (I/O devices as peripheral LSI or I/O devices such as printer, etc.) data transfer capability is also provided.

The TMPZ84C10A is fablicated using Toshiba's CMOS Silicon Gate Technology. The principal functions and features of the TMPZ84C10A are as follows.

- (1) Compatible with the Zilog Z80 DMA.
- (2) DC to 6MHz operatio
- (3) Single 5V power supply (at  $5V \pm 10\%$ )
- (4) Data transfer rate 3M bytes/sec (at 6MHz)
- (5) Data transfer in max. 64K byte block length.
- (6) Address generation with incrementing, decrementing, or fixed address by source and destination.
- (7) Built-in daisy chain structure interrupt circuit.
- (8) Low power consumption10µA MAX (5V, stand-by)
- (9) Extended operating temperarure  $-40^{\circ}$ C to  $85^{\circ}$ C
- (10) Transfer, search, or transfer/search operations can be specified.
- (11) Byte, burst or continuous modes can be specified.
- (12) Bit maskable byte searching function.
- (13) Built-in Reset logic that is synchronized external signal, Software and when powered on.

Further, in the following text and explanations for charts and tables, hexadecimal numbers are directly used without giving an identification to explanation of address, etc. to the extent not to cause confunctions.

Note: Z80 is a trademark of Zilog Inc., U.S.A.
# 2. PIN ASSIGNMENTS AND PIN FUNCTIONS

The pin assignments and I/O pin names and brief functions of the TMPZ84C10A are shown below.

### 2.1 PIN ASSIGNMENTS

The pin assignments of the TMPZ80C10A are as shown in Figure 2.1, Figure 2.2.



#### Figure 2.2 PLCC Pin Assignments

## 2.2 PIN NAMES AND FUNCTIONS

| Table 2.1 Pin Names and Funct | ions (1/2) |  |
|-------------------------------|------------|--|
|-------------------------------|------------|--|

| Pin Name | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                    |
|----------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0~A15   | 16               | Output<br>3-state       | 16-bit address bus.<br>DMA output address bus to source port and destination port.                                                                          |
| CLK      | 1                | Input                   | Single phase clock signal.<br>Clock input to DMA. The same clock as that for MPU can be used.                                                               |
| WR       | 1                | l/O<br>3-state          | Write signal.<br>When used as input, MPU writes to DMA control register. When<br>used as output, DMA controls write to the memory or I/O port<br>address.   |
| RD       | 1                | l/O<br>3-state          | Read signal.<br>When used as input, MPU reads out of DMA status register. When<br>used as output, DMA controls read from the memory or I/O port<br>address. |

00489

| Pin Name   | Number<br>of Pin | Input/Output<br>3-state | Functions                                                                                                                                                         |
|------------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IORQ       | 1                | I/O<br>3-state          | I/O request signal.<br>When I/O data is read or written, DMA controls read/write.                                                                                 |
| MREQ       | 1                | Output<br>3-state       | Memory request signal.<br>When memory data is read or written, DMA controls read/write.                                                                           |
| BAO        | 1                | Output                  | Bus line enable output signal.<br>In the several DMA configuration, controls priority for the bus using<br>right.                                                 |
| BAI        | 1                | Input                   | Bus line enable input signal.<br>Indicates that the system bus using right is released for DMA control.                                                           |
| BUSREQ     | 1                | I/O                     | Bus line enable input signal.<br>Indicates that the system bus control are sent to MPU. Open drain.                                                               |
| CE/WAIT    | 1                | Input                   | Chip enable/wait signal.<br>Normally, operates as CE but it is possible to program to operate as<br>WAIT at time of data transfer.                                |
| RDY        | 1                | Input                   | Ready signal.<br>Monitored by DMA to determine effective polarity. Effective<br>polarity is programmable.                                                         |
| M1         | 1                | Input                   | Signal showing machine cycle 1.<br>Indicates that MPU is in the operation code fetch cycle or<br>interruption acknowledge.                                        |
| D0-D7      | 8                | I/O<br>3-state          | 8-bit bidirectional data bus.<br>Control byte from MPU, status byte from DMA and data from the<br>memory or I/O are transferred through these terminals.          |
| IEO        | 1                | Output                  | Interrupt enable output signal.<br>Using jointly with IEI, forms the daisy chain structure for interrupt<br>priority when several peripheral LSI's are connected. |
| IEI        | 1                | Input                   | Interrupt enable input signal.<br>Using jointly with IEO, forms the daisy chain structure for interrupt<br>priority when several peripheral LSI's are connected.  |
| INT/ PULSE | 1                | Output                  | Interrupt request signal.<br>For interrupt request and pulse generation. Open drain.                                                                              |
| VCC        | 1                | Power supply            | + 5V                                                                                                                                                              |
| VSS        | 1                | Power supply            | 0V                                                                                                                                                                |

Table 2.1 Pin Names and Functions (2/2)

100489

# 3. DESCRIPTION OF OPERATION

# 3.1 BLOCK DIAGRAM



Figure 3.1 Block Diagram

#### 3.2 SYSTEM CONFIGURATION

The architecture (system configuration and functions) which must be known in using DMA will be described here.

#### Components

- (1) Reset circuit
- (2) Control & status register group
- (3) Bus control circuit
- (4) Pulse circuit
- (5) Byte counter
- (6) Byte equality circuit
- (7) Port A address, Port B address
- (8) Interrupt priority circuit
- (9) Basic function
- (10) Interrupts

## 3.2.1 Reset logic

DMA has following three reset functions.

(1) Power on reset

DMA has reset circuit that is synchronized automaticaly when powered on.

(2) External signal reset

When  $\overline{M1}$  signal is active more than two system clocks without an active  $\overline{RD}$  or  $\overline{IORQ}$  signal, the DMA is reset at rising edge of  $\overline{M1}$  signal.

- (3) Soft ware reset
- 3.2.2 Control & status register group

The DMA is provided with 21 writable register control register group and 7 readable register status register group. Registers are all in 8 bits but 2 byte data is held in optional 2 continued registers. The Z80 Microprocessor (hereinafter referred to as MPU) is capable of setting and monitoring values in respective registers.

The control register group is classfied into 7 groups of WR0 to WR6 (Figure 3.2), each of which is consisting of the basic register and related registers. The operation of DMA is controlled by programming in the control register group.

The status regiser group consists of PR0 to PR6 (Figure 3.3) and are used to know state of execution or end of DMA operation.

Further, these registers are described in detail in 3.4 Commands.

| WR0             | 70                      |      | 7 0                                       |
|-----------------|-------------------------|------|-------------------------------------------|
| 15              | Basic register          | RRO  | Status byte                               |
| Port A Start ac | ddress                  |      | L                                         |
| Block length    |                         | RR1  | Byte counter (low order 8 bit)            |
| WR1             | Basic register          | RR2  | Byte counter (high order 8 bit)           |
|                 | Port A variable timing  |      |                                           |
| WR2             | Basic register          | RR3  | Port A Address counter (low order 8 bit)  |
|                 | Port B variable timing  | RR4  | Port A Address counter (high order 8 bit) |
| WR3             | Basic register          |      |                                           |
|                 | Mask byte               | RR5  | Port B Address counter (low order 8 bit)  |
|                 | Match byte              | RR6  | Port B Address counter (high order 8 bit) |
| WR4             | Basic register          |      | 100489                                    |
| Port B Start ad | ldress                  |      | Figure 3.3 Status Register                |
|                 | Interrrupt control byte |      |                                           |
|                 | Pulse control byte      |      |                                           |
|                 | Interruption vector     |      |                                           |
| WR5             | Basic register          |      |                                           |
| WR6             | Basic register          |      | ,<br>,                                    |
|                 | Read out mask           |      |                                           |
| Figure          | e 3.2 Control Register  | 0489 |                                           |

#### 3.2.3 Bus control circuit

The bus control circuit controls bus direction between DMA and system bus at time of programming, while controls the control bus at time to data transfer according to the data transfer direction between the memory and I/O devices. In addition, it controls updating of required address counter and byte counter.

- (1) Bus direction control
  - At time of programming, the bus master is MPU and the control bus and data bus (when data is written into the control regiser) are in the direction from the system bus to DMA. Further, when data (status, etc.) is read from the control register, the direction will be from DMA to the system bus. At this time, the address bus buffer is disabled.
  - At time data transfer, the bus master is DMA. The control bus buffer and address bus buffer are enabled, and the bus direction will become from DMA to the system bus.
  - When data is read out of the memory or I/O device, the data bus direction is from the system bus to DMA but it becomes in the direction from DMA to the system bus at time of data write.
- (2) Bus request

If DMA requested MPU to transfer the bus control right and received it, MPU cannot fetch commands from the memory and is placed in the completely idle state.

For DMA to request the bus control right to MPU, following 2 enable conditions are required:

- (a) Enable command from MPU
- (b) Active RDY condition

#### 3.2.4 Pulse circuit

The pulse circuit generates pulse signals in the INT line for every 256 bytes of 0 to 255 when data transfer is started. The details are described in 3.3.2 (2) (k).

### 3.2.5 Byte counter

The byte counter is cleared when data is transferred and is incremented by one whenever data is transferred for every 1 byte. A value of this counter is always compared with block length of WR0 and when they agree with each other, the DMA operation ends.

### 3.2.6 Byte equality circuit

DMA always monitors data being transferred during the data teansfer and when equality is detected, generation of interruption becomes possible.

3.2.7 Port A address, Port B address

Data transfer is performed between Port A and Port B. Either port is specified by the source and destination specified by WR0.

3.2.8 Interrupt priority circuit

The Z80 system used the daisy chain structure to control interrupt among peripheral LSI's and the bus priority among multiple DMA's. Further, for the interrupt timing, refer to 3.2.2 (2) (j).

(1) Interrupt daisy chain

When the interrupt priority is connected in the daisy chain structure, connect IEI and IEO. When the interrupt is acknowledged, the interrupt configuration of MPU is disabled. In order to allow other peripheral LSI to make the interrupt into MPU, it is necessary to enable the MPU's interrupt configuration by the interrupt enable command. The interrupt enable command is normally executed in the service routine. When the interrupt enable command is executed in the early part of the service routine, a peripheral LSI with higher priority can make the interrupt even when MPU is executing the service routine. (Interrupt in the nest structure is authorized.)



Figure 3.4 Interruption Daisay Chain

#### (2) Bus request daisy chain

When multiple DMA's are used, priority can be controlled by the daisy chain structure connection. Since BUSREQ signal of each DMA is bidirectional type, each DMA in the daisy chain is able to know bus requests as an input and until a DMA having the bus completes its operation, the bus requests of other DMA's are kept in wait state. Until completion of the operation, any DMA is not able to release the bus in operation by force. Further, the bus request daisy chain has no nesting function but is able to hold the bus until its process is completed. The priority among DMA 's in the daisy chain is in order from high order to low order corresponding to distances drom MPU. Priority is so decided that low order DMA will not receive BUSACK signal through BAI/BAO chain of DMA when multilpe DMA's made the bus request in the same clock cycle period.





## 3.2.9 Basic functions

DMA is provided with the following basic functions:

- (1) Data transfer paths
  - ① Transfer between memory and I/O
  - 2 Transfer between memories
  - ③ Transfer between I/O and I/O
  - ④ Memory search
  - ⑤ I/O search
- (2) Operating classes
- (3) Operation modes
  - ① Byte mode
  - ② Burst mode
  - ③ Continuous mode
- (4) Transfer speed
- (5) Operating conditions
- (6) Automatic restart
- (7) Variable cycle
- (8) Pulse generation

#### 3.2.9.1 Data transfer paths

The data transfer paths of DMA are as shown in Figure 3.6.



Figure 3.6 Transfer Paths of DMA

### (1) Transfer between memory and I/O

This is the most ordinary method of data transfer and data transfer with the high speed serial interfaces (Z80SIO, etc.) is possible.

(2) Transfer between memories

This method of transfer is used for relocation of the memory content and high speed transfer of voluminous data between memories. In addition, this method is used to support memory mapped I/O. It is possible to program to make RDY conditions active for this type of data transfer.

The same function as that of LDIR command (block transfer command) of the Z80 MPU is provided. Number of clocks required by MPU for transfer of data of single byte is 21 clocks in case of the LDIR command while it can be processed in 4 clocks when DMA is used (in case of 2 cycle variable timing). Further, when DMA is used, approx. 420 clocks are required for initialization but in transfering data of 25 bytes or above, DMA becomes advantageous.

(3) Transfer between I/O and I/O

This method of transfer can be used in such applications as acquisition of real time data requiring temporary storage of input data. For instance, in transfering data from a diskette to a line printer, a program only starts the DMA operation and data is transferred from I/O to I/O. However, if I/O error occurred, its recovery becomes necessary.

Further, when there is a byte equality, it is possible to branch into various operations by the search function.

# (4) Memory search

This memory search is used to search a large quantity of data at high spped. The same function as that of CPIR command (search command) of the Z80 MPU is provided. Number of clocks required by MPU for single byte memory search is 21 clocks when the CPTR command is used while the search is possible in 2 clocks ( in case of 2 cycle variable timing) when DMA is used. Further, approx. 376 clocks are required for initialization when DMA is used and therefore, DMA is advantageous for memory search of more than 19 bytes. In addition, the search of special bytes in the end of block and character check block is also possible.

# (5) I/O search

This is used for search of special bytes in the end of block and character check block. For instance, this is used for search of a file mark showing a file delimiter on a magnetic tape.

# 3.2.9.2 Operating classes

There are 3 kinds of basic operation classes for DMA. 2 out of these 3 kinds are further devided into 2 classes. In addition, the ports referred to here denote the data source and destination.

# (1) Data transfer between 2 ports

1 Transfer

Data transfer path in the flow of readout cycle followed by write cycle. This is executed without external logic circuit between DMA and MPU.

# ② Simultaneous transfer

Data transfer path for simultaneous read and write of data transferred between ports by generating required control signal through use of an external logic circuit. 2 times of effeciency of the transfer only class is obtained.

# (2) Search of special bit pattern in byte at one port

1 Search

This is a method to search special bit pattern by comparing data read from the source port with a matched byte. The matched byte is masked by another byte and can be compared with a special bit pattern (a certain bit in bytes).

- (3) Data transfer between 2 ports and search
  - ① Transfer/search

Data transfer is performed in the same transfer method as that of the only transfer class and at the same time, the same search as that for the search only class is performed.

2 Simultaneous transfer/search

Data transfer is performed in the same transfer method as that of the simultaneous transfer class and at the same time, the same search as that for the search only class is performed.

In this case, an external logic circuit is required.

#### 3.2.9.3 Operation modes

In the transfer methods for various operation classes, DMA can select the following modes:

- Byte mode
- Burst mode
- Continuous mode

The single byte transfer/search is shown in Figure 3.7 (commonly applicable to all modes).





The data transfer is started at the point of time when DMA is enabled. In the first single byte operation in any mode, RDY signal is first checked to determine if it is active.

Then, the bus request is made and single byte transfer/search is performed when DMA becomes the bus master. The same operation is continued until the end of block judgement is made. If it is not the end of block, however, a different operation is carried out after judgement of RDY signal. The operations in respective modes are as shown in Figure 3.8, 3.9 and 3.10.

(1) Byte mode

In the data transfer operation of DMA, the system bus control right is released whenever 1 byte is transferred at a time and the system bus control right is returned to MPU for at least one machine cycle period.

If RDY signal of DMA is active when one machine cycle passes after the system bus control right is returned to MPU, the bus request is made again to MPU and next one byte data transfer is performed. Further, when RDY signal is non-active, the system bus control right is retained by MPU. This operation is shown in Figure 3.8.



Figure 3.8 Byte Mode

### (2) Burst mode

In the burst mode, after one byte data is transferred, RDY signal is checked to determine if it is active without releasing the system bus control right. If RDY signal is active, data transfer is continued until RDY signal becomes non-active and after the data transfer is completed, DMA stops to operate. Since MPU is ready to operate during the period in which I/O device does not transfer data (when RDY signal is non-active), data transfer rate and bus using efficiency are effective.

This operation is shown in Figure 3.9.



Figure 3.9 Burst Mode

## (3) Continuous mode

When the data transfer is commenced, DMA retains the system bus control right until the transfer of last byte of a data block is completed or the stop condition of RDY signal becomes non-active during the operation, DMA is simply put in the idle state and still retains the system bus control right while waiting that RDY signal becomes active again. What must be taken care of is that if number of data bytes is smaller than that set in the byte counter, DMA cannot end the block transfer forever and the system is impeded to operate properly.

This operation is shown in Figure 3.10.



Figure 3.10 Continuous Mode

### 3.2.9.4 Transfer speed

Shown in Table 3.1 are the comparison of max. transfer rates in 5 transfer classes of DMA operation and that of max. transfer rates in block transfer command of MPU. The max. speed transfer rate is accomplished in the simultaneous transfer operation of DMA and at least one external logic circuit is required. DMA transfers shown in the table are based on the assumption that interruption is not involved in the burst or continuous mode, and that the read and write cycle is 2 cycles.

| Operation                                                                       | Z – 80<br>(6.0MHz) |  |
|---------------------------------------------------------------------------------|--------------------|--|
| Simultaneous transfer of DMA<br>DMA search only<br>Simultaneous transfer/search | 3M byte/s          |  |
| DMA transfer<br>DMA transfer/search                                             | 1.5M byte/s        |  |
| Block transfer command of MPU                                                   | 0.300M byte/s      |  |
|                                                                                 | 100489             |  |

Table 3.1Transfer and Search Max. Speed<br/>(Burst and continuous modes)

Shown in Table 3.2 is the comparison of the Z80 throughput reduction rate (per transfer K baud) in the byte mode of data transfer by DMA with the throughput reduction rate in the byte transfer using the interrupt service routine by six commands (actual minimum) by MPU. The DMA transfer in this data is based on the assumption that read and write cycle timing is longer than 2 cycles (min.). Therefore, MPU throughput reduction rate in the 2 cycle simultaneous transfer is further reduced.

| Operation                           | Z – 80<br>(6.0MHz) |  |
|-------------------------------------|--------------------|--|
| DMA transfer<br>DMA transfer/search | 0.027%             |  |
| MPU transfer by interrupt           | 0.142%             |  |
|                                     | 100489             |  |

Table 3.2Z-80 MPU Throughput Reduction Per DMATransfer K Baud (Byte Mode)

### 3.2.9.5 Operating conditions

Programmable conditions to get DMA perform certain operations and these operations are shown in Table 3.3. The conditions referred to here are those conditions for the internal registers of DMA, signals from peripheral LSI's and commands to DMA on the data bus. For details refer to Table 3.3.

| Conditions                                                       | Operations that can be caused under conditions at left hand                           |
|------------------------------------------------------------------|---------------------------------------------------------------------------------------|
| End of block                                                     | a. Bus release<br>b. MPU interruption<br>c. Auto restart                              |
| Coincidence of byte                                              | <ul><li>a. Bus release</li><li>b. MPU interruption</li><li>c. Continuation</li></ul>  |
| Pulse control byte coincided with low order byte of byte counter | a. Pulse generation                                                                   |
| RDY signal is active                                             | a. Bus request<br>b. MPU interruption                                                 |
| RDY signal is non-active                                         | <ul><li>a. Bus release</li><li>b. Breaking<br/>(in case of continuous mode)</li></ul> |
| RETI command (interruption return command from MPU)              | a. Bus request                                                                        |
|                                                                  | 100489                                                                                |

Table 3.3 Operating Conditions

#### 3.2.9.6 Auto restart

In DMA data transfer, it is possible to automatically clear the byte counter, load the content of the start address register on the address counter again and restart the data transfer at the end of block.

The automatic restart function can reduce a burden of software on MPU in the CRT refresh or repeating operation. In addition, it is possible to write different start address into the buffer register during the data transfer (when RDY signal is non-active and the bus is released during the data transfer in the byte mode or burst mode). At this time, it becomes possible to commence the automatic restart of data transfer from a new start address.

### 3.2.9.7 Variable Cycle

DMA is capable of changing readout and write cycle lengths through programming. This function is effective in increasing data transfer rate and reducing a burden on a software, and an external logic circuit may be omitted. Refer to 3.3.2 (2) (i) where this function is described.

### 3.2.9.8 Pulse generation

DMA generates pulse signal on the  $\overline{INT}$  line for every 256 bytes for data transfer. This is described in detail in 3.3.2 (2) (k).

#### 3.2.10 Interrupt

DMA is able to make an interrupt request to MPU under the following conditions:

- After DMA's RDY signal becomes active and before DMA makes a bus request (BUSREQ="0")
- When the content of the byte counter coincides with that of the block length register and the end of block is detected.
- When the content of the coincided byte masked by the mask byte coincides with data in the transfer or search period when the byte coincidence is formed.

To make an interrupt request to MPU, it is necessary for DMA to release the bus. If DMA is the bus master, signal on the INT line generates periodic pulses to the peripheral LSI's, which are not sensed by MPU.

Therefore, at the end of block or after stop by byte coincidence, DMA releases the bus before interrupting MPU.

If interrupt at the enf of block and automatic restart at the end of block are set for DMA by programming, an interrupt is taken place at each end of block (at this point of time, it is acknowledged for the continuous operation). If the automatic restart is programmed in this case, the status flag at the end of block is not set. In this case, the interrupt vector cannot determine a factor for that interrupt.

On the Z80 system, interrupt is controlled through the daisy chain system. For the interrupt daisy chain, refer to 3.2.7 Interrupt/Priority Circuit. In addition, for the interrupt timing, refer to 3.3.2 (2) (j).

#### 3.3 Status change flowchart and basic timing

The status change flowchart and the basic data transfer timing by DMA are shown here. The status change flowchart is shown in 3.3.1 and the basic timing in 3.3.2.

## 3.3.1 Status change flowchart



Figure 3.11 (a) Status Change Flowchart

Figure 3.11 (b) Status Change Flowchart

100489



#### Note : The details for signal byte transfer/search is shown in Figure 3.11 (b) Status Change Flowchart.

Figure 3.11 (c) Status Change Flowchart

## 3.3.2 Basic timing

When DMA receives a command from MPU or reads the readout register, MPU has the system bus control right,  $\overline{\text{BUSACK}}$  = "1", and MPU is called the bus master. When DMA operation is data transfer by DMA proper,  $\overline{\text{BUSACK}}$  = "0", and DMA gets the system bus control right and becomes the bus master.

- (1) When the bus master is MPU:
  - (a) Write timing into the write register

To write data into the write register, it is necessary for 3 signals of  $\overline{CE}$ ,  $\overline{IORQ}$  and  $\overline{WR}$  to become "0" simultaneously at the rising edge of clock. At this leading edge, DMA latches these 3 signals. After latched,  $\overline{CE}$ ,  $\overline{IORQ}$  and  $\overline{WR}$  signals may change to the invalid level after certain hold time. Further, DMA writes the status of the data bus (D0 to D7) into necessary write registers at the rising edge of next clock.



Figure 3.12 Write Timing into the Write Register of DMA

## (b) Readout timing from the readout register

To readout the readout register it is necessary that 3 signals of  $\overline{CE}$ ,  $\overline{IORQ}$  and  $\overline{RD}$  are at "0" and stable for more than 2 clocks. At the rising edges of 2 clocks, the status data is on the data bus and kept as long as  $\overline{CE}$ ,  $\overline{IORQ}$  and  $\overline{WR}$  signals are active.





### (2) When DMA is the bus master:

(a) Transfer

Transfer and transfer/search operations are performed at the same timing. Data is latched at the rising edge of  $\overline{\text{RD}}$  signal (in case of the standard timing, the falling edge of T3 state) and held on the data bus during next write cycle. After  $\overline{\text{RD}}$  signal becomes "1", the data bus buffer of DMA is enabled.

The standard timing is 3 clock cycles for the memory operation while it is 4 clock cycles for the I/O operation. In addition, in the I/O operation, the timing is 4 clock cycles including TW\* which is automatically inserted between T2 and T3 state.

When  $\overline{\text{CE}/\text{WAIT}}$  signal is programmed as "Multiplex" in the write register WR5, DMA samples the status of this signal at the falling edge of T2 in case of the memory readout and at the falling edge of TW\* in case of the I/O write. If  $\overline{\text{WAIT}}$  signal is at "0" level at this time, DMA inserts one clock cycle (Tw) and if it is at "1" level, proceeds to next cycle. Further, when Tw is inserted,  $\overline{\text{WAIT}}$  signal is sampled again during this period and the same processing is performed.





#### Memory to I/O

In the memory readout, DMA put the memory address on the memory bus (A0 to A5) in the period of T1 rise and bring  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals to "0" level at the falling edge of T1 state. The memory data is read out at this point of time, put on the data bus (D0 to D7), latched by DMA at the falling edge of T3 immediately before the rise of  $\overline{\text{RD}}$  signal, and when  $\overline{\text{RD}}$  signal becomes "1" level, DMA data bus buffer is enabled and the latched data is output on the data bus.

In the I/O write cycle, DMA put I/O address on the addresss bus in the T1 rise period, makes  $\overline{IORQ}$  signal and  $\overline{WR}$  signal to "0" level in the T2 rise period, and writes the data on the data bus (data readout from the memory) into I/O.

• I/O to memory

In the I/O readout cycle, DMA put I/O address on the address bus in the T1 rise period and makes  $\overline{IORQ}$  signal and  $\overline{RD}$  signal to "0" in the T2 fall period. I/O data is read out and placed on the data bus at this time, and is latched by DMA at the trailing edge of T3 immediately before the rise of  $\overline{RD}$  signal. When  $\overline{RD}$  signal becomes "1" level, DMA data bus buffer is enabled and the latched data is output on the data bus.

In the memory write cycle, DMA places memory address on the address bus in the T1 fall period, makes  $\overline{\text{MREQ}}$  signal to "0" level at the falling edge of T1 and  $\overline{\text{WR}}$  signal to "0" level in the T2 rise period, and write data on the data bus (data readout from I/O) into the memory.



### Memory to memory

This operation is a combined operation of the memory read cycle and memory write cycle.



Figure 3.16 Transfer Timing of Memory to Memory

## I/O to I/O

This operation is a combined operation of the I/O read cycle and I/O write cycle.



#### (b) Search timing

The search operation is identical to the readout only operation and data is only read into DMA register for comparison with coincided byte.

The timing of search operation is identical to that of memory to I/O transfer shown in Figure 3.14 and that of I/O to memory transfer in Figure 3.15.

### (c) Simultaneous transfer

The simultaneous transfer operation and the simultaneous transfer/search operation are performed in the same timing.

When DMA is programmed in the search only mode, the read and write cycles are generated in one read cycle (source port readout period). Since only one address is generated on the address bus, the memory or I/O control signal is generated using an external logic circuit and DMA operation is performed according to this control signal. In addition, I/O ports are selected by hardware during the operation. Signals with (EXT) shown in Figure 3.18 through Figure 3.21 are those generated by an external logic circuit.

• Memory to I/O (Memory search cycle)

In this data transfer, the memory search mode is programmed and the memory readout and I/O write are performed in one read cycle by generating  $\overline{IORQ}$  signal and  $\overline{WR}$  signal in the memory readout cycle using an external logic circuit. The hardware performs the memory readout by  $\overline{MREQ}$  signal and  $\overline{RD}$  signal that are output by DMA and the I/O write by  $\overline{IORQ}$  signal and  $\overline{WD}$  signal that are generated using an external logic circuit.



• I/O to memory (Memory search cycle)

In this data transfer, the memory search mode is programmed and the I/O read and memory write operations are performed in one readout cycle by generating  $\overline{IORQ}$  signal and  $\overline{WR}$  signal in the memory readout cycle using an external logic circuit. The hardware performes the I/O readout using  $\overline{RD}$  signal output by DMA and  $\overline{IORQ}$  signal generated by an external logic circuit and the memory write using  $\overline{MREQ}$  signal generated by DMA and WR signal produced by an external logic circuit.



Figure 3.19 Simultaneous Transfer Timing of I/O to Memory (Memory search timing)

• Memory to I/O (I/O search cycle)

In this data transfer, the I/O search mode is programmed and the memory read and I/O write operations are performed in one readout cycle by generating  $\overline{\text{MREQ}}$ signal and  $\overline{\text{WR}}$  signal in the I/O readout cycle using an external logic circuit. The hardware performs the memory readout using  $\overline{\text{RD}}$  signal output by DMA and  $\overline{\text{MREQ}}$  signal generated by an external logic circuit and the I/O write using  $\overline{\text{IORQ}}$ signal generated by DMA and  $\overline{\text{WR}}$  signal produced by an external logic circuit.

• I/O to memory (I/O search cycle)

In this data transfer, the I/O search mode is programmed and the I/O read and memory write operations are performed in one readout cycle by generating  $\overline{\text{MREQ}}$ signal and  $\overline{\text{WR}}$  signal in the I/O readout cycle using an external logic circuit. The hardware performs the I/O readout using  $\overline{\text{IORQ}}$  and  $\overline{\text{RD}}$  signals output by DMA and the memory write using  $\overline{\text{MREQ}}$  signal and  $\overline{\text{WR}}$  signal produced by an external logic circuit.

100489



Note : Althrough addresses on A0-A15 are originally I/O addresses, they are handled as memory addresses.







Figure 3.21 Simultaneous Transfer Timing of I/O to Memory (I/O search timing)

### (d) Bus request timing

When RDY signal becomes active, DMA samples RDY signal at the rising edge of the clock and if the bus is not full ( $\overline{BUSREQ} = "1"$ ) DMA makes  $\overline{BUSREQ}$  signal to "0" level at the rising edge of next clock and request MPU to hand over the system bus control right.

MPU samples **BUSREQ** signal at the rising edge of the last state clock of the machine cycle which MPU is executing at that point of time and if it is "0", makes **BUSACK** signal to "0" level at the rising edge of next clock.

Therefore, maximum value of a time required for MPU to hand over the bus control right to DMA ( $\overline{BUSACK}$ ="0") after DMA detected that RDY signal becomes active is the sum of one machine cycle (valiable) and one clock period of MPU.

When detecting that  $\overline{\text{BAI}}$  (BUSACK) signal is at "0" level for 2 clock period, DMA start the DMA action. There is the delay time of max. One machine cycle +3 clock period after RDY signal becomes active till the DMA action is actually started.



Figure 3.22 Bus Request Timing

#### (e) Bus release timing - byte mode

In the byte mode, DMA makes <u>BUSREQ</u> signal to "1" level at the rising edge of the clock immediately before end of each data transfer cycle (the end of readout cycle in the search operation and the end of write cycle in the transfer and trasfer/search operation.)

Although  $\overline{\text{BUSREQ}}$  signal becomes "1" before the end of DMA cycle by one clock, MPU resumes the operation one clock after  $\overline{\text{BUSREQ}}$  signal becomes "1" level and therefore, there will be no trouble.

After the bus is released, next bus request is made at the leading edge of the clock immediately after both BUSREQ signal and BAI signal becomes "1" level. RDY signal being active is the conditions for this.





### (f) Bus release at the end of block in the burst mode or continuous mode

When it is programmed to stop DMA at the end of block in the burst mode or continuous mode,  $\overline{\text{BUSREQ}}$  signal is set to "1" level at the rising edge of the clock at the end of last data transfer. This last data is transferred even when RDY signal becomes non-active.



Figure 3.24 Bus Release Timing - at End of Block

(g) Bus release when coincidence is detected in the burst mode or continuous mode

When DMA is set in the burst mode or continuous mode and programmed to stop its operation at byte coincidence, DMA stops to operated when the byte coincidence is detected.

Since DMA operation is pipelined and the advance reading is performed, a check to determine if the n th data coincides with the coincidenced byte is carried out at the same time when the n + 1 st data is transferred. Therefore, data of N+1 byte is transferred and  $\overline{BUSREQ}$  signal is set to "1" level at the leading edge of the clock when this transfer ended.





#### (h) Bus release when RDY signal is non-active

If RDY signal becomes non-active in the burst mode,  $\overline{\text{BUSREQ}}$  signal is set to "1" level at the rising edge of next clock after end of the byte operation that is under execution at the time. For instance, this is done when the read of the search only or simultaneous transfer/search operation ended or when the write of the trasfer/search operation ended. Therefore, the action for  $\overline{\text{BUSREQ}}$  signal is slightly behind the action for RDY signal.

DMA always does not release the bus until the byte action at the time is completed.

In contrast with this, in the continuous mode BUSREQ signal is kept at "0" level even when RDY signal becomes non-active.

In addition, after the byte action at the time ended DMA is put in the idle state until RDY signal becomes active again.

This figure is shown in Figure 3.26.



Figure 3.26 Bus Release Timing when RDY Signal becomes Non-active

Timing of RDY signal with other signals are shown in Figure 3.27, 3.28 and 3.29. In these figures the memory search only operation by the Z80 standard timing by mode is assumed. In each of the operation modes, RDY signal is sampled at the rising edge of the last clock of the read or write cycle to determine its level.

RDY signal can become non-active before completion of the last byte operation withour affecting its operation. In the byte or burst mode,  $\overline{\text{BUSREQ}}$  signal and  $\overline{\text{BAI}}$  signal are set to "1" at the end of byte operation of RDY signal. In the byte or burst mode, the bus control signals ( $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ) are also kept at "1" level as long as RDY signal is non-active. Further, the address bus and data bus are kept in 3 state.

The continuous mode differs from other modes in that the address bus holds an address which is incremented in advance against next byte during the period when RDY signal is non-active. This address can be used immediately after RDY signal becomes ative again.



Figure 3.27 Timings of RDY Signal with Other Signals (Byte Mode)







Figure 3.29 Timings of RDY Signal with Other Signals (Continuous mode)

(i) Variable cycle

When programmed, DMA is capable of changing read and write cycle lengths. Source and destination can be programmed independently by the write register WR1 (designation of Port A) and WR2 (designation of Port B). This variable cycle function allows the read or write in 2, 3 or 4 clock cycles (more clock cycles if Tw is inserted) and further, can increase or decrease pulse widths of all signals generated by DMA. Four signals relative to the data transfer;  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ and  $\overline{\text{WR}}$  signals have the function to end the rising edge timing earlier by 1/2 clock independently.

Differing from the standard timing, in the variable cycle mode  $\overline{IORQ}$  signal becomes active earlier than  $\overline{MREQ}$ ,  $\overline{RD}$  and  $\overline{WR}$  signals by 1/2 clock. Further,  $\overline{CE/WAIT}$  signal can be used in the extension of 3 or 4 clock cycle variable memory cycle and 4 clock cycle variable I/O cycle only. In the 3 or 4 clock cycle memory operation,  $\overline{CE/WAIT}$  signal is sampled at the T2 falling edge while it is sampled at the T3 falling edge in the 4 clock cycle I/O operation. In the 2 clock cycle operation it is not sampled. Use of this variable cycle effective in increasing data transfer rate and reducing software burden and further, can eliminate an external logic circuit. In addition, this function provides more faster memory read/write speed than normal speed.

100489

# TOSHIBA

CE/WAIT (3 CYCLE AND 4 CYCLE MEMORY OPERATIONS)

CE/WAIT (4 CYCLE I/O OPERATION)





## (j) Interrupt

The timing for the interrupt acknowledge or return from interrupt is identical to that of other Z80 peripheral LSI's. INT signal is sampled by MPU at the rising edge of the last clock of all commands. If the interrupt enable is not set by the internal MPU software or when  $\overline{\text{BUSREQ}}$  signal is active, this  $\overline{\text{INT}}$  signal is not accepted. When  $\overline{\text{INT}}$  signal is accepted,  $\overline{\text{IORQ}}$  signal also becomes active at the same time (normally,  $\overline{\text{MREQ}}$  signal) in the period of its M1 cycle, indicating that the interrupting LSI can load its 8-bit vector on the data bus. At the same time, two wait status are automatically inserted into this cycle. This is to facilitate execution of the priority interrupt mechanism and the wait status of 2T gives a stabilizing time to IE1 and IE0 signals and thus, it becomes possible to identify which peripheral LIS will react.



#### Figure 3.32 Interrupt Acknowledge

Interrupt on RDY signal (interrupt before the bus request) does not directly affect  $\overline{\text{BUSREQ}}$  signal. The process in this case is carried out by giving following commands to the write register WR6 in the interrupt service routine.

- Enable after interrupt return (B7H)
- DMA enable (87H)

- Execution of REI instruction to reset IUS latch during the interrupt service in the Z80 DMA (ED4DH)
- (k) Pulse generation

In the pulse generation,  $\overline{INT}$  signal is set to "0" level (pulses are generated on the  $\overline{INT}$  line) every 256 bytes after offset value is loaded to the write register WR4 by the program.

INT signal is put to "0" level during the DMA cycle in which pulse control bytes coincide with low order bytes of the byte counter and kept at "0" level in the full period of transfer cycle. Here, the transfer cycle means the read cycle (the search only or simultaneous transfer operation) or read/write cycle and lengths of the read and write cycles can be set independently by variable cycle.



Figure 3.33 (a) Pulse Output (Standard timing at the time of transfer)





#### (I) Precautions

① Transfer timing

Although the DMA transfer timing is basically identical to the read/write timing of the Z80 MPU, care is required when variable cycle is used or in case of simultaneous transfer.

In the case of simultaneous transfer, all addresses which are output by DMA are interpreted to be memory addresses and I/O are selected by the hardware using an external logic circuit. It is normally programmed that I/O addresses are fixed and memory addresses are updated during the DMA operation. At this time, DMA controls memory addresses and outputs I/O select signal using an external logic circuit.

② Memory refresh

Since DMA has no refresh signal output function, the refresh of a dynamic RAM is performed normally using RFSH signal of MPU. If the transfer period becomes long in the DMA operation using the burst mode or continuous mode, another refresh method must be used.

③ Pulse generation

When the pulse generating function is used for transfer in the byte mode, pulse output is generated in two times. This is to avoid BAI signal from becoming nonactive and MPU from being put in HALT state. Further, when offset value and low order 8 bits of the block length are equal other, pulse is once generated and after DMA operation is completed, pulse is generated during the read cycle of the 1st byte when the DMA operation is performed again without changing the offset value.




## TOSHIBA

## 3.4 PERIPHERAL COMMANDS

To operate DMA, specify its operations by writing into the control register group through programming. In addition, the status of DMA can be known by reading the contents of the status register group.

To give effect to this on a program, write the operation into the write register by OTIR or OUT command to MPU and read out by INIR or IN command. In both cases, output of the I/O address decoder to DMA becomes "0" level. This output is connected to the  $\overline{\text{CE}/\text{WAIT}}$  pin.

The configurations of the control register group and status register group are as follows:

- (1) Control register group
  - ① Write register WR0
  - ② Write register WR1
  - ③ Write register WR2
  - ④ Write register WR3
  - 5 Write register WR4
  - 6 Write register WR5
  - ⑦ Write register WR6

- (2) Status register group
  - ① Readout register RR0
  - 2 Readout register RR1
  - ③ Readout register RR2
  - ④ Readout register RR3
  - 5 Readout register RR4
  - 6 Readout register RR5
  - ⑦ Readout register RR6

## 3.4.1 Control register group

The control registers consist of 7 groups of WR0 to WR6, each of which consists of a basic register and related registers. If the pointer bit of the basic redister is "1", related redisters are accessed by turns.

The basic registers WR0 to WR6 are identified by the combination of bits 0, 1, 2, 6 and 7. There may be pointer bits for related registers. BBH (followed by the readout mask) command of WR6 has no pointer bit but data that follows this command is limited to the readout mask.

## (1) Write register WR0

WR0 is identified by the condition that Bit 7 of the basic register is "0" and Bit 1, 0 are other than both "0".

WR0 has 4 pointer bits, each of which has related registers, respectively.

(a) Basic register bit 0, 1 (Designation of operating class)

Bit 0 and 1 designate the operating class; transfer, search only, and transfer/search operations. In addition, simultaneous transfer or transfer/search is obtained by selecting search and generating a proper bus control signal for complete transfer through external hardware.



Figure 3.35 Write Register WR0

(b) Basic register bit 2 (Designation of data transfer direction)

Bit 2 declears the source port, and by implication, the destination port, if the operation is a sequential transfer. In the search only operation, the source port only is designated and in the simultaneous transfer or transfer/search operation, the destination port is decided by external wiring.

```
(c) Basic register bit 3-6 (Pointer bits)
```

Bit 3-6 are the pointer bits which are used to designate four related registers following respective bits.

(d) Related register #0, #1 (Port A start address)

These registers are accessed by Bit 3 and 4 of the basic register byte. When Port A is used as a source or destination, it is necessary to write the start address. Low order byts are written into #0 and high order bytes in #1.

```
(e) Related register #2, #3 (Block length)
```

These registers are designated by Bit 5 and 6 of the basic register. Max. 64K bytes can be designated by writting low order bytes of block length into #2 and high order bytes into #3. However, as data read is pipe line type, number of bytes actually searched or transferred is more than that entered here by 1 or 2. In addition, if "zero" is set for these registers, the transfer or search of  $2^{16} + 1$  bytes is carried out.

(2) Write register WR1

> WR1 is identified by the condition that all of Bits 0, 1 and 7 of the basic register are "0" and Bit 2 is "1".

Basic register bit 3 (Port A designation) (a)

> A memory is designated by Port A when "0" is written for Bit 3, while I/O is designated when "1" is written. This designation makes the control signal (MREQ or IORQ) active against the cycle including this port.



Figure 3.36 Write Register WR1

Basic register Bit 4, 5 (Fixed or variable address designation) (b)

Fixed or variable Port A address is designated by Bit 4 and Bit 5 for each transfer or search byte.

Basic register Bit 6 (Pointer bit) (c)

> When Bit 6 is set to "1". next related register is accessed. In addition, when Bit 6 is set to "0", DMA's variable cycle is not used.

(d) Related register #0 (Port A variable timing byte)

> By setting values for this register, Port A cycle length and control signal timing can be designated.

MPUZ80-134

• Bit 0, 1 (Cycle length)

Length of data transfer cycle (memory read/write, I/O read/write) relative to Port A is designated. Timing can be changed in a range of 2 - 4 clocks.

• Bit 2, 3, 6, 7 (Early end)

The timing of the control signal  $\overline{IORQ},\ \overline{MREQ},\ \overline{RD}$  and  $\overline{WR}$  can be advanced by 1/2 clock.

(3) Write register WR2

WR2 is identified by the condition that all of Bits 0, 1, 2 and 7 of the basic register are "0".

(a) Basic register bit 3 (Port B designation)

A memory is designated by Port B when "0" is written for Bit 3, while I/O is designated when "1" is written. This designation makes the control signal ( $\overline{\text{MREQ}}$  or  $\overline{\text{IORQ}}$ ) active against the cycle including this port.



## Figure 3.37 Write Register WR2

(b) Basic register Bit 4, 5 (Fixed or variable address designation)

Fixed or variable Port B address is designated by Bit 4 and Bit 5 for each transfer or search byte.

(c) Basic register Bit 6 (Pointer bit)

When Bit 6 is set to "1", next related register is accessed. In addition, when Bit 6 is set to "0", DMA's variable cycle is not used.

(d) Related register #0 (Port B variable timing byte)

By setting values for this register, Port B cycle length and control signal timing can be designated.

• Bit 0, 1 (Cycle length)

Length of data transfer cycle (memory read/write, I/O read/write) relative to Port B is designated. Timing can be changed in a range of 2 - 4 clocks.

• Bit 2, 3, 6, 7 (Early end)

The timing of the control signal  $\overline{IORQ}$ ,  $\overline{MREQ}$ ,  $\overline{RD}$  and  $\overline{WR}$  can be advanced by 1/2 clock.

(4) Write register WR3

WR3 is identified by the condition that both Bit 0 and Bit 1 of the basic register are "0" and Bit 7 is "1".

(a) Basic register Bit 2 (Stop on match)

This bit is used for the search or transfer/search operation. When this bit is "1" and transferred data matches the match byte, the data transfer is stopped and the bus is released. When this bit is "0" and transferred data matches the match byte (if DMA is not stopped even when they matched), the status flag is set on the status byte to allow interrupt resulting from byte match.

(b) Basic register Bit 3 (Pointer bit)

When this bit is set at "1", the mask byte follows the basic register.

(c) Basic register Bit 4 (Pointer bit)

When this bit is set at "1", a match byte follows the basic register. This bit designates a match byte used for comparison with all data to be searched.

(d) Basic register Bit 5 (Interrupt enabled)

When this bit is set at "1", DMA interrupt is enabled.

(e) Basic register Bit 6 (DMA enable)

When this bit is set at "1", DMA operation is enabled and a bus request can be made to MPU.

## (f) Related register #0 (Mask byte)

This register is accessed by basic register Bit 3. It is possible to write a mask byte required for the search operation. The mask byte is capable of masking the match byte (data to be compared) during the search operation to extract bits to be compared.

When all bits of the mask byte are at "0", the comparison is made and when they are at "1", the masking is made. In addition, if no masking is required and all bits are compared, write 00H mask byte.

## (g) Related register #1 (match byte)

This register is accessed by basic register Bit 4. The match byte is used as data to be compared when the data transfer mode is search or transfer/search. The match byte is masked by the mask byte of related register #0.



Figure 3.38 Write Register WR3

## (5) Write register WR4

WR4 is identified by the condition that both Bit 0 and Bit 7 of the basic register are "1" and Bit 1 is "0".

(a) Basic register Bit 2 - 4 (Pointer bit)

When these bits are set at "1", the related registers #0 to #2 are accessed after the basic register.

(b) Basic register Bit 5, 6 (Operation mode designation)

Operation mode selected values can be set for Bit 5 and Bit 6. For values to be set, refer to Figure 3.39.

(c) Related register #0, #1 (Port B start address)

These registers are accessed by basic register Bit 2 and Bit 3. Related register #0 designates low order byte of Port B start address while related register #1 designated high order byte of Port B. Further, if low order 8 bits are sufficient for Port B start address, thr loading to related register #1 is not required.

(d) Related regiser #2 (Interrupt control byte)

This register control DMA interrupt or pulse generation. By setting Bit 3 and Bit 4, related registers #3 and #4 can be accessed.

• Bit 0 (Interrupt on match)

When Bit 0 is set at "1", DMA generates interrupt if transferred data matches the match byte in the search or transfer/search operation.

• Bit 1 (Interrupt on end of block)

When Bit 1 is set at "1", DMA generates interrupt if a value of the byte counter becomes "0" in DMA operation.

#### • Bit 2 (Pulse generation)

When Bit 2 is set at "1", pulse is generated on the INT line whenever data in number of bytes set on the pulse control byte is transferred.

• Bit 3, 4 (Pointer bits)

When Bit 3 is set at "1", pulse control byte is accessed after interrupt control byte. When Bit 4 is set at "1", the interrupt vector is accessed.

• Bit 5 (Vector value change by status)

When this bit is set at "1", interrupt vector value changes according to cause for generating interrupt. However, if the automatic restart or interrupt at the end of block was already set, this mode cannot be used.

• Bit 6 (Interrupt on RDY)

When this bit is set at "1", DMA generates interrupt prior to the bus request if it detects that RDY signal has become active. Therefore, the interrupt enable command becomes necessary and when RETI instruction is executed after the interrupt enable of WR6 (B7H) is sent out, the bus request is started.

(e) Related register #3 (Pulse control byte)

When Bit 3 of the interrupt control byte is set at "1", the pulse control byte is accessed after the interrupt control byte. The pulse control byte gives offset values to pulse that are first generated (Number of bytes shown by this control byte).

D7 D0 D6 D5 D4 D3 D2 D1 **Basic** register 1 0 1 Designation of data trasfer mode Byte mode 0 Continuous mode 0 1 Burst mode 1 0 Don't use 1 1 Related register #0 Port B Start address (Low order 8 bits) Related register #1 Port B Start address (High order 8 bits) Related register #2 0 Interrupt control byte Interrupt on RDY :1 1: Interrupt on match 1: Interrupt on end of block Status affects vector :1 1: Pulse generation Related register #3 Pulse control byte Related register #4 Interrupt vector 0 0 Interrupt on RDY 0 1 Interrupt on match Interrupt on end of block 1 0 1 Interrupt on match and end of 1 block 100489

The pulse control byte compares low order 8 bits of the byte counter and if both coincide each other, pulses are output on the  $\overline{\text{INT}}$  line.

Figure 3.39 Write Register WR4

## (f) Related register #4 (Interrupt vector)

When Bit 4 of the interrupt control byte is set at "1", the interrupt vector is accessed after the interrupt control byte. The interrupt vector is loaded on the data bus at time of the interrupt acknowledge by MPU ( $\overline{IORQ}$ ="0",  $\overline{MI}$ ="0"). If Bit 5 of the interrupt control byte is set at "1", Bit 1 and Bit 2 of the interrupt vector change according to the interrupt factor. However, when the automatic restart and interrupt on the end of block has been already programmed, the interrupt vector sent out at the end of block does not change and therefore, the mode for vector value change by status cannot be used.

## TOSHIBA

#### (6) Write register WR5

WR5 is identified by the condition that Bit 1 and 7 of the basic register are "1" and Bit 0, 2 and 6 are "0". WR5 has no related register.

• Bit 3 (Effective polarity of RDY signal)

When this bit is set at "0", RDY signal becomes "0" and active, and when it is set at "1", RDY signal becomes "1" and active.

• Bit 4 (Use of CE/WAIT pin)

When this bit is set at "0",  $\overline{CE}$  function only is available. When it is set at "1", both  $\overline{CE}$  and  $\overline{WAIT}$  functions become available. When  $\overline{BUSREQ}$  signal is at "1", CE function is available, while if  $\overline{BUSREQ}$  signal is at "0" level, WAIT function is available.

• Bit 5 (Automatic register)

When this bit is set at "0" level, DMA operation is stopped at time of the end of block (Byte counter="Zero"). When it is at "1" level, the contents of the address register and byte counter are automatically loaded on the address counter and byte counter, and DMA operation is continued.



Figure 3.40 Write Register WR5

#### (7) Write register WR6

WR6 is identified by the condition that Bit 0, 1 and 7 of the basic register are at "1" level. In the case of WR6, the functions (commands) are divided by the combination of Bits 2 to 6.

#### (a) Reset (C3H)

This command is used to reset DMA. By executing this command, DMA performs the followings;

- Disables the interrupt control circuit and bus request control circuit.
- Releases the interrupt latch.
- Releases the forced RDY condition.
- Releases the automatic restart condition.
- Releases  $\overline{CE}/\overline{WAIT}$  function (Bit 4 WR5) and retains  $\overline{CE}$  function only.
- Returns the timings of both Port A and B to the Z80 standard timing.

After turning power to DMA ON, and performing the programming, it is necessary to execute the reset command once. In addition, if the DMA operation is interrupted during its execution, it is necessry to execute the reset command 6 times successively (this is because there are 5 related registers that are capable of directing in WR4).

Further, DMA is not always reset completely by this reset command. The read sequence is reset only by the read sequence reset command.

(b) Port A timing reset (C7H)

This command resets Port A variable timing byte and returns Port A timing to the Z80 standard timing.

(c) Port B timing reset (CBH)

This command resets Port B variable timing byte and returns Port B timing to the Z80 standard timing.

(d) Load (CFH)

When this command is executed, the content of the address register is loaded on the address counter and the byte counter is cleared. In addition, the internal forced RDY condition is also released.

Further, an address counter to which the loading can be made immediately is the source port address counter only. The loading to the destination port address counter is made when a value of this counter is initially updated (incremented/decremented) but if "address if fixed", the loading is not performed. However, the loading by the "fixed address destination port programming" technique is possible. If DMA becomes non-active when the load command is written, another DMA control byte is written before the load command.

(e) Continue (D3H)

Although this command clears the byte counter to "zero", both port address counters do not change. This command is used in transferring several data blocks to continued positions in the many buffer if it is desirable to know a break of every block, and continues DMA operation which has been interrupted by detection of match at the end of block or search. In order to execute this command, interrupt at the end of each blocks is needed and new block length shall be entered in WR0 with the continue command.

In transferring data blocks, interrupt becomes necessary whenever transfer of each data block ended. In trasferring next data block after the interrupt, this continuity command is used inserted of the load command.



100489

Figure 3.41 Write Register WR6

#### (f) Interrupts disable (AFH)

This command is used to simulate the Z80 MPU's interrupt acknowledge when DMA is operated in a system other than the Z80 MPU. When DMA sends the interrupt signal into any MPU other than the Z80 MPU, if the inerrupt disable command is written into the beginning of the service routine, INT signal returns to "1" level but next interrupt signal of DMA cannot be sent during the service routine is continuously carried out. Generation of next interrupt signal becomes possible when the interrupt enable command is written into the end of the service routine.

#### (g) Interrupts enable (ABH)

This is a command used on the Z80 system to enable the interrupt when the power source is ON. This command enables the interrupt control circuit of DMA. When the interrupt disable command is not used, if the interrupt enable command is once written, next interrupt is enabled automatically when RETI instruction is executed at the final stage of the interrupt service routine. However, if the interrupt disable command is used, it becomes necessary to write the interrupt enable command at the final stage of the interrupt service routine.

#### (h) Reset and interrupt disable (A3H)

This command is used on such systems as 8080 and 8085 to interface DMA and MPU which is provided with the interrupt acknowledge function but has no RETI instruction. This command, when executed, performs the followings:

- Reset of the in-interrupt service routine (IUS) latch
- Reset of the interrupt pending (IP) latch
- Release of the internal forced RDY signal conditions
- Successing interrupt disable by DMA (same as the interrupt disable command)
- (i) Enable after RETI (B7H)

This command is used only when "interrupt on RDY signal" is programmed on WR4. DMA, when detecting that RDY signal becomes active, does not make the bus request but grenerates the interrupt signal. After the interrupt return, this command enables DMA to make the bus request again. This command is always used to make the bus request after the interrupt to RDY signal on the Z80 MPU system. This command also can be used on other MPU's, for instance, 8080.

The interrupt latch (IOR) to RDY signal is set during its interrupt cycle. This latch makes RDY signal active and DMA is not allowed to make the bus request until this latch is reset by Enable after RETI instruction.

The execution sequence of the Z80 MPU service routine is as follows and the bus request is mode after RETI instruction is executed:

Enable after RETI DMA Enable

**RETI** Instruction

#### (j) Read status byte (BFH)

This command indicates that next read command is the status byte access.

#### (k) Status byte initialization (8BH)

This command indicates the reinitialization of bit 4 and 5 of the status byte. The reinitialization of the interrupt pending status (Bit 3) of the status byte can be effected by the interrupt acknowledge, interrupt process, interrupt reset and disable command writing. The reinitialization of DMA operation status (Bit 0) can be effected by the load command.

## (I) Read mask continue (BBH)

This command denotes that next control byte which is to be written into DMA follows the read mask register. The read mask register is used for setting a new read sequence of RR0 to RR6 and is normally a part of the initial state setting when the power source for DMA is turned ON.

The read mask can be programmed by setting the related pointer bit of register to be read out "1" level. The read sequence start command is used for initialization.

#### (m) Read sequence initiate (A7H)

This command is used to initiate the read sequence pointer command as a measures to access the first (in low order) read register that is designated to be readable by the read mask for initialization of DMA by next MPU read command. Normally, this command is output to reset the read sequence immediately after loading of the read mask.

#### (n) Forced RDY (B3H)

In the burst mode or continuous mode, this command is used to make the internal RDY conditions active for the active RDY signal by an external logic circuit. This command is used for memory-to-memory transfer or memory search where RDY signals not required. It is not necessary to consider the effective polarity of RDY signal. Use of this command can eliminate an external logic circuit.

The forced RDY conditions are released by the following commands/conditions:

- Reset command
- Load command
- Interrurpt reset and disable command
- Ending by end-of-block
- Ending by byte match
- Bus release by DMA
- (o) DMA enable (87H)

This command is used to enable the bus control circuit of DMA. The interrupt circuit is not affected nor the function and latch are reset. This bus request enable function is identical to that of Bit 6 of WR3. In the interrupt service routine, DMA enable command is the last command to DMA before MPU executes RETI instruction.

(p) DMA disable (83H)

This command inhibits the bus request by DMA. This command is used to stop DMA operation by external events, end-of-block or match by bytes and when reinitialization of the status byte is required.

## 3.4.2 Status register group

There are 7 read registers RR0 to RR6 available for DMA to know the operation execution or end status.

The readout of MPU is made according to the method to access DMA as the peripheral I/O using I/O command. Commands to be written into DMA are as follows:

- ① Read status byte (BFH)
- 2 Read sequence initiate (A7H)
- ③ Status byte reinitialize (8BH)
- ④ Read mask continue (BBH)

The above commands are those which are shown for WR6.

- (1) Read register PR0 Status byte
  - (a) Bit 0 (DMA operation)

This bit indicates if DMA made the bus request after the last LOAD command. "1" indicates that DMA made the bus request while "0" indicates no bus request made.

(b) Bit 1 (RDY signal active)

"0" of this bit indicates that RDY signal is active. "1" indicates RDY signal being non-active.

(c) Bit 2 (Don't Care)

(d) Bit 3 (Interrupt pending)

This bit indicates the interrupt pending (IP) latch status. "0" indicates the interrupt pending.

(e) Bit 4 (Match detection)

When this bit is "0", it indicates the match after the last status byte reset or reintialization command.

(f) Bit 5 (End-of-block detection)

When this bit is "0", it indicates the end-of-block reached after the last status byte reset, load, continuity or reinitialization.

- (g) Bit 6, 7 (Don't Care)
- (2) Read register RR1, RR2 Byte counter

The 16-bit counter consisting of two register RR1 or RR2 are cleared to zero by the load, continuity or resest command.



When DMA starts the transfer or search, the byte counter is incremented by one at the end of each read cycle and judges the end-of-block by comparing with the program content of the block length register (WR0), when match is detected, DMA operation is stopped. If the pulse generation is used at this time, the content of the WR4 pulse control byte is, after transferred, compared with low order 4 byte (RR1) of the byte counter.

#### (3) Read register RR3, RR4 - Port A address counter

Write into the 16-bit counter consisting of two read registers RR3 and RR4 is made from WR0 port A start address register by the load command. Whenever one byte of DMA operation is carried out according to the designated content of WR0, this counter is updated (incremented or decremented) by one.

#### (4) Read register RR5, RR6 - Port B address counter

The 16-bit counter consisting of two read registers RR5 and RR6 indicates Port B address when DMA operation ended. Values in the port B address register (WR4) are loaded into this counter by the load command and the counter is updated by one every time when DMA operation is carried out by one byte. However, if address fix (Bit 4 and 5 of WR2) is programmed, the counter does not change. If port A or Port B is a fixed address destination port, in order to properly function the port it is necessary to program as described for the fixed address destination port.

#### 3.4.3 Address counter and byte counter values when DMA operation ended.

Values of these counters when DMA operation ended are shown in Table 3.4 (a) and Table 3.4 (b).

| Data<br>format | Data<br>transfer<br>mode | Value of<br>block length<br>register | Number of<br>byte to be<br>transferred | Value of<br>byte counter | Address<br>counter value<br>of source port | Address counter<br>value of destinaion<br>port |
|----------------|--------------------------|--------------------------------------|----------------------------------------|--------------------------|--------------------------------------------|------------------------------------------------|
|                | Byte                     | N                                    | N + 1                                  | N                        | As ± (N + 1)                               | As± (N)                                        |
| Transfer       | Burst                    | N                                    | N + 1                                  | N                        | As ± (N + 1)                               | As± (N)                                        |
|                | Continuity               | N                                    | N + 1                                  | N                        | As ± (N + 1)                               | As± (N)                                        |
|                | Byte                     | N                                    | N + 1                                  | N                        | As ± (N + 1)                               |                                                |
|                |                          |                                      | N + 1                                  | N                        | As ± (N + 1)                               |                                                |
| Search         | Burst                    | N                                    | N + 2*                                 | N + 1*                   | As ± (N + 2)*                              |                                                |
|                | Continuity               |                                      |                                        | N                        | As ± (N + 1)                               |                                                |
|                |                          | Continuity                           | N                                      | N + 2*                   | N + 1*                                     | As ± (N + 2)*                                  |

Table 3.4 (a) Values of Those Counters when DMA Operation Ended

As: Start address \*: The values when N+1 byte data is trasferred and RDY signal is active using 2cycle valiable timing.

100489

100489

| Data<br>format | Data<br>transfer<br>mode | Byte no. to be<br>detected | Number of<br>byte to be<br>transferred | Value of<br>byte counter | Address<br>counter value<br>of source port | Address counter<br>value of<br>destination port |            |            |            |            |     |    |      |
|----------------|--------------------------|----------------------------|----------------------------------------|--------------------------|--------------------------------------------|-------------------------------------------------|------------|------------|------------|------------|-----|----|------|
|                | Byte                     | м                          | м                                      | M-1                      | As± (M)                                    | As ± (M-1)                                      |            |            |            |            |     |    |      |
| Transfer       | Burst                    | М                          | М                                      | M-1                      | As ± (M)                                   | As ± (M-1)                                      |            |            |            |            |     |    |      |
|                | Continuity               | м                          | м                                      | M-1                      | As± (M)                                    | As ± (M-1)                                      |            |            |            |            |     |    |      |
|                | Byte                     | М                          | м                                      | M-1                      | As± (M)                                    |                                                 |            |            |            |            |     |    |      |
|                | Durat                    |                            | M + 1                                  | М                        | As ± (M + 1)                               |                                                 |            |            |            |            |     |    |      |
| Search         | Burst                    | IVI                        | M*                                     | M-1*                     | As ± (M)*                                  |                                                 |            |            |            |            |     |    |      |
|                | Continuity               |                            |                                        | М                        | As ± (M + 1)                               |                                                 |            |            |            |            |     |    |      |
|                |                          | Continuity                 | Continuity                             | Continuity               | Continuity                                 | Continuity                                      | Continuity | Continuity | Continuity | Continuity | IVI | M* | M-1* |

Table 3.4 (b) Values of Those Counters when DMA Operation Ended

As: Start address \*: The values when match is detected and RDY signal is active.

## 3.4.4 List of command (1/3)



100489

## List of command (2/3)



## List of command (3/3)



## TOSHIBA

## 3.5 METHOD OF USE

(1) Example of interface



As the method of use of DMA using the Z80 family, a simple example of the Z80 system interface is shown below. Figure 3.43 shows the connection employing the Z80MPU, Z80DMA, Z80PIO, and MEMORY.

On the Z80 sistem, signal lines of MPU and peripheral devices are connected almost directly. In Figure 3.43, priority is in the order of DMA and PIO. This is because the connection is made according to the daisy chanin method which is peculiar to the Z80 system. In the case of DMA, espescially, in order to operate as a bus controller, <u>BUSACK</u> signal, which is the output of MPU, is input to BAI of DMA by the bus request daisy chain. When several units of DMA are used, BAO is connect to BAI of DMA which has the next higher priority. Hardware can be easily connected as shown in Figure 3.43. In addition, memory mapped I/O also can be connected to DMA.

#### (2) Program example

As a program example of DMA operation, an example of transfer from  $\,$  I/O to memory using PIO is shown.

|               |    | ı.    | ;          |     | .280<br>Z80 DM | A DATA TRANSFER  |                      |   |
|---------------|----|-------|------------|-----|----------------|------------------|----------------------|---|
|               |    |       | ;          |     | 1/0 10         | MEMORY           |                      |   |
|               |    |       | ;          |     | (PIO P         | ORT B)           |                      |   |
| 0020          |    |       | ;<br>DPIOB |     | EQU            | 20H              | ;DATA PIO CHANNEL B  |   |
| 0021          |    |       | DPIOB      |     | EQU            | DPIOB+1          | ;CONTROL PIO CHANNEL | B |
| 0030          |    |       | DMA        |     | EQU            | 30H              | ;DMA ADDRESS         |   |
| 2000          |    |       | DSTN       |     | EQU            | 2000H            | ;DESTINATION         |   |
| 0100          |    |       | LENGTH     | ł   | EQU            | 256              | ;BLOCK LENGTH        |   |
|               |    |       |            |     | ORG            | 1000H            |                      |   |
| 1000′         | F3 |       | STRT:      |     | DI             |                  |                      |   |
| 1001′         | 3E | 10    |            |     | LD             | A,10H            |                      |   |
| 1003 <i>'</i> | ED | 47    |            |     | LD             | I,A              |                      |   |
| 1005′         | ED | 5E    |            |     | IM             | 2                | ;INTERRUPT MODE 2    |   |
|               |    |       | ;          |     |                |                  |                      |   |
|               |    |       | ; F        | 9I0 | B INIT         | TIALIZATION      |                      |   |
| 1007′         | 3E | 4F    |            |     | LD             | A,4FH            | ;MODE 1              |   |
| 1009′         | D3 | 21    |            |     | OUT            | (CPIOB),A        |                      |   |
| 100B′         | 3E | 07    |            |     | LD             | A,07H            |                      |   |
| 100D′         | D3 | 21    |            |     | OUT            | (CPIOB),A        |                      |   |
|               |    |       | ;.         |     |                |                  |                      |   |
|               |    |       | ; [        | DMA | RESET          |                  |                      |   |
| 100F′         | 3E | C3    |            |     | LD             | A,0C3H           |                      |   |
| 1011'         | 06 | 06    |            |     | LD             | В,06Н            |                      |   |
| 1013′         | D3 | 30    | DMRT:      |     | OUT            | (DMA),A          |                      |   |
| 1015′         | 10 | FC    |            |     | DJNZ           | DMRT             |                      |   |
|               |    |       | ;          |     |                |                  |                      |   |
|               |    |       | ; [        | OMA | INITI          | LIZATION         |                      |   |
| 1017′         | 06 | 12    |            |     | LD             | B, DMAFIN-DMACTA | l                    |   |
| 1019′         | 0E | 30    |            |     | LD             | C,DMA            |                      |   |
| 101B'         | 21 | 104E' |            |     | LD             | HL,DMACTA        |                      |   |
| 101E′         | ED | B3    |            |     | OTIR           |                  |                      |   |
|               |    |       |            |     |                |                  |                      |   |

| 1020'<br>1021'                                                                                                             | FB<br>C9                                                                         |                                                |                             | EI<br>RET                                                                                                     |                                                                                          |                |                                                        |                                                                                                                                                                                                             |
|----------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------|------------------------------------------------|-----------------------------|---------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------|----------------|--------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1022′                                                                                                                      | 76                                                                               |                                                | ;<br>;<br>IOR:              | INTERRUPT<br>HALT                                                                                             | ON READY                                                                                 |                |                                                        |                                                                                                                                                                                                             |
| 1023′                                                                                                                      | 76                                                                               |                                                | ;<br>;<br>IOM:              | INTERRUPT<br>HALT                                                                                             | ON MATCH                                                                                 |                |                                                        |                                                                                                                                                                                                             |
| 1024'<br>1027'<br>1029'<br>102C'<br>102E'<br>1030'<br>1033'<br>1035'                                                       | CD<br>3E<br>32<br>06<br>0E<br>21<br>ED<br>C9                                     | 1037'<br>8B<br>0030<br>04<br>30<br>105C'<br>B3 | ;<br>;<br>IOE:              | INTERRUPT<br>CALL<br>LD<br>LD<br>LD<br>LD<br>LD<br>UD<br>OTIR<br>RET                                          | ON END OF<br>SAV<br>A,8BH<br>(DMA),A<br>B,DMAFIN-D<br>C,DMA<br>HL,DMACTB                 | BLOCK<br>MACTB |                                                        |                                                                                                                                                                                                             |
| 1036'                                                                                                                      | 76                                                                               |                                                | ;<br>;<br>IME:              | INTERRUPT<br>HALT                                                                                             | ON MATCH,E                                                                               | ND OF          | BLOCK                                                  |                                                                                                                                                                                                             |
| 1037'<br>1038'<br>1039'<br>103A'<br>103B'<br>103F'<br>1042'<br>1044'<br>1046'<br>1047'<br>1048'<br>1048'<br>1048'<br>1048' | E3<br>D5<br>C5<br>F5<br>DD<br>FD<br>CD<br>FD<br>CD<br>F1<br>C1<br>E1<br>FB<br>ED | E5<br>E5<br>104D'<br>E1<br>E1                  | ;<br>;<br>SAV:<br>;<br>RUN: | REGISTER<br>EX<br>PUSH<br>PUSH<br>PUSH<br>PUSH<br>CALL<br>POP<br>POP<br>POP<br>POP<br>POP<br>EI<br>RETI<br>JP | SAVE<br>(SP),HL<br>DE<br>BC<br>AF<br>IX<br>IY<br>RUN<br>IY<br>IX<br>AF<br>BC<br>DE<br>HL |                |                                                        |                                                                                                                                                                                                             |
|                                                                                                                            |                                                                                  |                                                | ;;;;                        | DMA COMMA<br>PORT A<br>PORT B                                                                                 | ND TABLE<br>- MEMORY<br>- PIO CHANN                                                      | EL B           |                                                        |                                                                                                                                                                                                             |
| 104E'<br>104E'<br>104F'<br>1050'<br>1052'<br>1054'<br>1055'<br>1056'<br>1057'<br>1058'                                     | C3<br>7D<br>200<br>00F<br>14<br>28<br>A0<br>95<br>20                             | 0<br>F                                         | DMACT                       | A EQU<br>DEFB<br>DEFB<br>DEFW<br>DEFW<br>DEFW<br>DEFW<br>DEFB<br>DEFB<br>DEFB<br>DEFB                         | \$<br>0C3H<br>7DH<br>DSTN<br>LNGTH-1<br>14H<br>28H<br>0A0H<br>95H<br>DPI0B               |                | ;WR6<br>;WR0<br>;<br>;WR1<br>;WR2<br>;WR3<br>;WR4<br>; | RESET COMMAND<br>PORT A TO PORT B (TEMP)<br>DESTINATION ADDRESS<br>BLOCK LENGTH<br>PORT A - "INCREMENT" ADDRESS<br>PORT B - "FIXED" ADDRESS<br>ENABLE INTERRUPT<br>BYTE MODE TRANSFER<br>PORT B ADDRESS (L) |

| 1059'<br>105A'<br>105B'<br>105C'<br>105C' | 32<br>FF<br>82<br>CF | DMACTB | DEFB<br>DEFB<br>DEFB<br>EQU<br>DEFB | 32H<br>INTV-STRT<br>82H<br>\$<br>OCFH | ;<br>;INTV<br>;WR5<br>;WR6 | IOE,STATUS AFFECTS VECTOR<br>INTERRUPT VECTOR<br>RDY ACTIVE 'LOW', CE/ ONLY<br>LOAD ADDRESS TO PORT A |
|-------------------------------------------|----------------------|--------|-------------------------------------|---------------------------------------|----------------------------|-------------------------------------------------------------------------------------------------------|
| 105D′                                     | 01                   |        | DEFB                                | 01H                                   | ;WRO                       | PORT B TO PORT A                                                                                      |
| 105E'                                     | CF                   |        | DEFB                                | 0CFH                                  | :WR6                       | LOAD ADDRESS TO PORT B                                                                                |
| 105F′                                     | 87                   |        | DEFB                                | 87H                                   | :WR6                       | ENABLE DMA                                                                                            |
| 1060′                                     |                      | DMAFIN | EQU                                 | \$                                    | ,                          |                                                                                                       |
|                                           |                      | ;      |                                     |                                       |                            |                                                                                                       |
|                                           |                      |        | ORG                                 | STRT+0FFH                             |                            |                                                                                                       |
| 10FF′                                     | 1022′                | INTV:  | DEFW                                | IOR                                   |                            |                                                                                                       |
| 1101′                                     | 1023′                |        | DEFW                                | IOM                                   |                            |                                                                                                       |
| 1103′                                     | 1024′                |        | DEFW                                | IOE                                   |                            |                                                                                                       |
| 1105′                                     | 1036′                |        | DEFW                                | IME                                   |                            |                                                                                                       |
|                                           |                      |        | END                                 |                                       |                            |                                                                                                       |

# 4. ELECTRICAL CHARACTERISTICS

## 4.1 ABSOLUTE MAXIMUM RATINGS

| Symbol              | ltem                           | Rating             | Unit   |
|---------------------|--------------------------------|--------------------|--------|
| V <sub>CC</sub>     | Supply Voltage                 | - 0.5 to + 7       | V      |
| V <sub>IN</sub>     | Input Voltage                  | - 0.5 to VCC + 0.5 | V      |
| PD                  | Power Diddipation (TA = 85°C)  | 250                | mW     |
| T <sub>SOLDER</sub> | Soldering Temperature (10 sec) | 260                | °C     |
| T <sub>STG</sub>    | Storage Temperature            | – 65 to 150        | °C     |
| T <sub>OPR</sub>    | Operating Temperature          | – 40 to 85         | °C     |
|                     |                                |                    | 100489 |

## 4.2 DC ELECTRICAL CHARACTERISTICS

 $T_A = -40^{\circ}C$  to 85°C,  $V_{CC} = 5V \pm 10\%$ ,  $V_{SS} = 0V$ 

| SYMBOL | PARAMETER                       | TEST CO                                                                                        | MIN.               | TYP.                  | MAX. | UNIT                  |    |
|--------|---------------------------------|------------------------------------------------------------------------------------------------|--------------------|-----------------------|------|-----------------------|----|
| VILC   | Low Clock Input Voltage         |                                                                                                |                    | - 0.3                 |      | 0.6                   | V  |
| VIHC   | High Clock Input Voltage        |                                                                                                |                    | V <sub>CC</sub> – 0.6 | -    | V <sub>CC</sub> + 0.3 | V  |
| VIL    | Low Inpur Voltage (Except CLK)  |                                                                                                |                    | - 0.5                 | _    | 0.8                   | V  |
| VIH    | High Input Voltage (Except CLK) |                                                                                                |                    | 2.2                   |      | Vcc                   | V  |
| VOL    | Output Low Voltage              | IOL = 2.0mA<br>BUSREQ only                                                                     | _                  |                       | 0.4  | V                     |    |
| VOH1   | Output High Voltage ( I )       | IOH = - 1.6n                                                                                   | nA                 | 2.4                   | _    | _                     | V  |
| VOH2   | Output High Voltage (II )       | IOH = -250μA                                                                                   |                    | V <sub>CC</sub> – 0.8 | —    | _                     | V  |
| ILI    | input Leak Current              | $V_{SS} \leq V_{IN} \leq V_{CC}$                                                               |                    | —                     | _    | ± 10                  | μA |
| ILO    | Output Leak Current             | $V_{SS} + 0.4 \leq V_{IN} \leq V_{CC}$                                                         |                    | —                     |      | ± 10                  | μA |
| ICC1   | Power Supply Current            | $V_{CC} = 5V$ $f_{CLK} = (1)$ $V_{IHC} = V_{IH}$ $= V_{CC} - 0.2V$ $V_{ILC} = V_{IL}$ $= 0.2V$ | AP-6/AM-6<br>/AT-6 | _                     | 6    | 10                    | mA |
| ICC2   | Standby Supply Current          | $V_{CC} = 5V$ $V_{IHC} = V_{IH} = V$ $V_{ILC} = V_{IL} = 0$                                    | _                  | 0.5                   | 10   | μА                    |    |

100489

Note 1 : fCLK = 1/TcC (MIN.)

## TOSHIBA

## 4.3 AC ELECTRICAL CHARACTERISTICS

## 4.3.1 AC characteritics (I)

When operate as peripheral devices (inactive state)

## $\mathrm{TA}\!=\!-40\,^\circ\!\mathrm{C}$ to $85\,^\circ\!\mathrm{C}$ , $\mathrm{VCC}\!=\!5\mathrm{V}\!\pm\!10\%,\mathrm{VSS}\!=\!0\mathrm{V}$

| NO. | SYMBOL           | PARAMETER                                                                                                           | AP-6/AN<br>(6M | /l-6/AT-6<br>lHz) | UNIT   |
|-----|------------------|---------------------------------------------------------------------------------------------------------------------|----------------|-------------------|--------|
|     |                  |                                                                                                                     | MIN.           | MAX.              |        |
| 1   | T <sub>C</sub> C | CLock cycle time                                                                                                    | 165            | DC                | ns     |
| 2   | TwCh             | High clock pulse width                                                                                              | 65             | DC                | ns     |
| 3   | TwCl             | Low clock pulse width                                                                                               | 65             | DC                | ns     |
| 4   | TrC              | Clock rise time                                                                                                     |                | 20                | ns     |
| 5   | TfC              | Clock fall time                                                                                                     | _              | 20                | ns     |
| 6   | Th               | Hold time                                                                                                           | 0              | -                 | ns     |
| 7   | TsC (Cr)         | $\overline{\text{IORQ}}$ , $\overline{\text{WR}}$ and $\overline{\text{CE}}$ signals set-up time for clock rise     | 60             | -                 | ns     |
| 8   | TdD0 (RDf)       | Delay from $\overline{RD}$ rise to data output                                                                      | -              | 300               | ns     |
| 9   | TsWM (Cr)        | Data input set-up time for clock rise (write and $\overline{\text{M1}}$ cycle)                                      | 30             | -                 | ns     |
| 10  | TdCf (D0)        | Delay from IORQ fall to data output<br>(INTA cycle)                                                                 | -              | 100               | ns     |
| 11  | TsRD (Dz)        | Delay from $\overline{RD}$ rise to data bus float state                                                             | -              | 70                | ns     |
| 12  | TsIEI (IORQ)     | IEI set-up time for IORQ fall (INTA cycle)                                                                          | 100            | -                 | ns     |
| 13  | TdIEOr (IEIr)    | Delay from IEI rise to IEO rise                                                                                     |                | 70                | ns     |
| 14  | TdIEOf (IEIf)    | Delay from IEI fall to IEO fall                                                                                     | -              | 70                | ns     |
| 15  | TdM1 (IEO)       | Delay from $\overline{M1}$ fall to IEO fall (When interrupt is generated immediately before $\overline{M1}$ cycle.) | _              | 100               | ns     |
| 16  | TsM1f (Cr)       | M1 signal set-up time for clock rise                                                                                | 70             | -                 | ns     |
| 17  | TsM1r (Cf)       | $\overline{M1}$ signal set-up time for clock fall                                                                   | - 10           | -                 | ns     |
| 18  | TsRD (Cr)        | $\overline{\text{RD}}$ signal set-up time for clock rise ( $\overline{\text{M1}}$ cycle)                            | 60             | -                 | ns     |
| 19  | Tdl (INT)        | Delay from interruption generation to $\overline{\text{INT}}$ fall (at inactive state)                              | -              | 450               | ns     |
| 20  | TdBAIr (BAOr)    | Delay from BAI rise to BAO rise                                                                                     | _              | 100               | ns     |
| 21  | TdBAIf (BAOf)    | Delay from $\overline{BAI}$ fall to $\overline{BAO}$ fall                                                           | -              | 100               | ns     |
| 22  | TsRDY (Cr)       | RDY signal set-up time for clock rise                                                                               | 50             | -                 | ns     |
|     |                  |                                                                                                                     |                |                   | 100489 |

## 4.3.2 AC charateristics (II) (1/2)

When operate as bus controller (active state)

## $TA = -40^{\circ}C$ to $85^{\circ}C$ , $VCC = 5V \pm 10\%$ , VSS = 0V

| NO. | SUMBOL           | PARAMETER                                                                                                |      | Л-6/АТ-6<br>1Hz) | UNIT   |
|-----|------------------|----------------------------------------------------------------------------------------------------------|------|------------------|--------|
|     |                  |                                                                                                          | MIN. | MAX.             |        |
| 1   | T <sub>C</sub> C | Clock cycle time                                                                                         | 165  | DC               | ns     |
| 2   | TwCh             | High clock pulse width                                                                                   | 65   | DC               | ns     |
| 3   | TwCl             | Low clock pulse width                                                                                    | 65   | DC               | ns     |
| 4   | TrC              | Clock rise time                                                                                          | -    | 20               | ns     |
| 5   | TfC              | Clock fall time                                                                                          | -    | 20               | ns     |
| 6   | TdA              | Delay of address output                                                                                  | -    | 90               | ns     |
| 7   | TdC (Az)         | Delay from clock rise to address bus float state                                                         | -    | 80               | ns     |
| 8   | TsA (MREQ)       | Address set-up time for MREQ fall (memory cycle)                                                         | 35   |                  | ns     |
| 9   | TsA (IRW)        | Address set-up time for IORQ, RD, WR fall<br>(I/O cycle)                                                 | 110  | _                | ns     |
| 10  | TdRW (A)         | Address hold time from RD, WR rise                                                                       | 35   | -                | ns     |
| 11  | TdRW (Az)        | Address hold time from RD, WR rise<br>(at float state)                                                   | 65   | _                | ns     |
| 12  | TdCf (D0)        | Delay from clock fall to data output                                                                     | -    | 130              | ns     |
| 13  | TdCr (Dz)        | Delay from clock rise to data bus float state<br>(write cycle)                                           | _    | 70               | ns     |
| 14  | TsDI (Cr)        | Data input set-up time up to clock rise (read cycle in which $\overline{\text{RD}}$ ended at clock rise) | 30   | _                | ns     |
| 15  | TsDI (Cf)        | Data input set-up time up to clock fall<br>(read cycle in which RD ended at clock fall)                  | 40   | -                | ns     |
| 16  | TsDO (WfM)       | Data output set-up time up to WR fall<br>(memory cycle)                                                  | 25   | -                | ns     |
| 17  | TsDO (WfI)       | Data output set-up time up to WR fall<br>(I/O cycle)                                                     | -55  | -                | ns     |
| 18  | TdWr (D0)        | Data hold time from WR rise                                                                              | 30   | -                | ns     |
| 19  | Th               | Hold time                                                                                                | 0    |                  | ns     |
| 20  | TdCr (Mf)        | Delay from clock rise to MREQ fall                                                                       |      | 70               | ns     |
| 21  | TdCf (Mf)        | Delay from clock fall to MREQ fall                                                                       | -    | 70               | ns     |
| 22  | TdCr (Mr)        | Delay from clock rise to MREQ rise                                                                       | -    | 70               | ns     |
| 23  | TdCf (Mr)        | Delay from clock fall to MREQ rise                                                                       | -    | 70               | ns     |
|     |                  |                                                                                                          |      |                  | 100489 |

## AC characteristics (II) (2/2)

| NO. SYMBOL |                   | PARAMETER                                                      | AP-6/AN<br>(6M | 1-6/AT-6<br>IHz) | UNIT   |
|------------|-------------------|----------------------------------------------------------------|----------------|------------------|--------|
|            |                   |                                                                | MIN.           | MAX.             |        |
| 24         | TwMI              | Low MREQ pulse width                                           | 135            | —                | ns     |
| 25         | TwMh              | High MREQ pulse width                                          | 65             | _                | ns     |
| 26         | TdCf (If)         | Delay from clock fall to IORQ fall                             | -              | 70               | ns     |
| 27         | TdCr (If)         | Delay from clock rise to IORQ fall                             | -              | 65               | ns     |
| 28         | TdCr (Ir)         | Delay from clock rise to IORQ rise                             | -              | 70               | ns     |
| 29         | TdCf (Ir)         | Delay from clock fall to IORQ rise                             |                | 70               | ns     |
| 30         | TdCr (Rf)         | Delay from clock rise to RD fall                               | -              | 70               | ns     |
| 31         | TdCf (Rf)         | Delay from clock fall to RD fall                               | -              | 80               | ns     |
| 32         | TdCr (Rr)         | Delay from clock rise to RD rise                               |                | 70               | ns     |
| 33         | TdCf (Rr)         | Delay from clock fall to RD rise                               | -              | 70               | ns     |
| 34         | TdCr (Wf)         | Delay from clock rise to WR fall                               |                | 60               | ns     |
| 35         | TdCf (Wf)         | Delay from clock fall to $\overline{WR}$ fall                  | -              | 60               | ns     |
| 36         | TdCr (Wr)         | Delay from clock rise to WR rise                               | -              | 70               | ns     |
| 37         | TdCf (Wr)         | Delay from clock fall to $\overline{WR}$ rise                  | -              | 70               | ns     |
| 38         | TwWI              | Low WR pulse width                                             | 135            |                  | ns     |
| 39         | TsWA (Cf)         | WAIT signal set-up time for clock fall                         | 60             | —                | ns     |
| 40         | TdCr (B)          | Delay from clock rise up to BUSREQ signal                      | _              | 90               | ns     |
| 41         | TdCr (Iz)         | Delay from clock rise to IORQ, MREQ, RD, WR signal float state | -              | 70               | ns     |
| A          | C Test conditions |                                                                |                |                  | 100489 |

 $\label{eq:VIH} \begin{array}{l} \rm VIH=2.4V, VIL=0.4V, VIHC=VCC-0.6V, VILC=0.6V\\ \rm VOH=2.2V, VOL=0.8V, CL=100 pF \end{array}$ 

## 4.4 CAPACITANCE

 $TA = 25^{\circ}C$ 

| SYNBOL | ITEM                    | TEST CONDITION                 | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|--------------------------------|------|------|------|------|
| CCLOCK | Clock Input Capacitance | f = 1MHz                       | —    | -    | 5    | рF   |
| CIN    | Input Capacitance       | All terminals except that to   | —    | -    | 5    | рF   |
| COUT   | Output Capacitance      | be measured should be earthed. |      |      | 10   | рF   |

100489

## 4.5 TIMING DIAGRAM

Numbers shown in the following figures correspond with those in the 4.3 A.C. Electrical Characteristics Table.

(1) When operate as peripheral devices (inactive state)



## TOSHIBA

## (2) When operate as bus controller (active state)



100489

# 5. EXTERNAL DIMENSION VIEW

## 5.1 DIP PACKAGE

DIP40-P-600

Unit : mm



Note 1: This dimension is measured at the center of bending point of leads.

Note 2: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.40 leads.

## 5.2 SOP PACKAGE

SSOP40-P-450

Unit : mm



270289

Note: Package Width and length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

## 5.3 44-PIN PLCC PACKAGE

QFJ44-P-S650





270289

## 6. PRECAUTIONS

No special care is required in the Z80 system designing employing DMA but it is necessary to fully understand the basic timings and commands shown in 3. Operational Description.

For the basic timings, please refer to the precautions in 3.3.2(1).

For the commands, care shall be taken to the programming as there are many registers and setup is considerably complicated.

As the precaution for the programming, the "fixed address destinaion port programming" is briefly described. When Port A is assumed to be the "fixed address destination port", address can be loaded in the following stepe:

- (1) Write Port A address into WR0.
- (2) Designate Port A as the source port. (Set up temporarily)
- (3) Load Port A address on the address counter. (Load command CFH)
- (4) Write Port B start address into WR4.
- (5) Convert Port A into the destination port.
- (6) Load Port B start address on the address counter. (source port address)

## TMPZ84C20AP-6 / TMPZ84C20AM-6 / TMPZ84C20AT-6 TMPZ84C20AP-8

## TLCS-Z80 PIO: PARALLEL INPUT / OUTPUT CONTROLLER

## 1. GENERAL DESCRIPTION AND FEATURES

The TMPZ84C20A (hereinafter referred to as PIO) is CMOS version of Z80 PIO and has been designed to provide low power operation.

The PIO is a general purpose parallel input/output port device with two programmable independent 8-bit ports, which provides a direct interface between the Z80 microprocessor (hereinafter referred to as MPU) and peripheral devices.

This PIO provides excellent data transfer processing by the interrupt and allows the interrupt in Mode 2 of MPU.

The TMPZ84C20A is fabricated using Toshiba's CMOS Silicon Gate Technology. The principal functions and features of the TMP84C20A are as follows.

- (1) Compatible with the functions and pin connections of Zilog Z80 PIO.
- (2) Low power consumption
   3mA Typ. (@5V @6MHz) … TMPZ84C20AP-6/AM-6/AT-6
   4mA Typ. (@5V @8MHz) … TMPZ84C20AP-8
   10µA Max.(@5V, Stand-by)

# (3) Operationg temperature -40 °C to 85°C 6MHz VERSION -10 °C to 70°C 8MHz VERSION

- (4) DC to 6MHz operation ··· TMPZ84C20AP-6/AM-6/AT-6
   DC to 8MHz operation ··· TMPZ84C20AP-8
- (5) 2 programmable independent 8-bit input/output ports with handshake functions.
- 4 operation modes for each port: Mode 0 (Byte Output Mode) Mode 1 (Byte Input Mode) Mode 3 (Byte Input/Output Mode) ..... Port A only Mode 4 (Bit Mode)
- (7) Built-in interrupt priority control circuit in daisy chain structure
- (8) Port B outputs capable of driving Darlington transistors
- (9) All input/output lines are TTL compatible.
- (10) Single 5V power supply. Single-phase clock
- (11) 40 pin DIP, SOP, 44pin PLCC Package.

Note: Z80 is a trademark of Zilog Inc., U.S.A.

## TOSHIBA

RD B7 B6 B5 B4 B3 B1 B1 B0 VCC

L CLK

100489

39 :

33 32 : 31 🗄 30 ::: 29 ::::

#### 2. PIN CONNECTIONS AND PIN FUNCTIONS

#### 2.1 PIN CONNECTIONS (Top View)

The pin connections of the TMPZ84C20A are as shown in Figure 2.1, Figure 2.2.

| D2 [   | 1  | $\bigcirc$    | 40 🛛 D3  |                                                   |
|--------|----|---------------|----------|---------------------------------------------------|
| D7 [   | 2  |               | 39 🛛 D4  | [9                                                |
| D6 [   | 3  |               | 38 🛛 D5  | <u>⊐</u> , 32 2 2 2 2 3 2 3 2 3 2 3 2 3 2 3 2 3 2 |
| CE [   | 4  |               | 37 🛛 M1  |                                                   |
| C/D [  | 5  |               | 36 TORQ  |                                                   |
| B/Ā    | 6  |               | 35 🛛 RD  | B/Ā [] 7                                          |
| A7 [   | 7  | TMPZ84C20AP-6 | 34 🛛 B7  | A7 [ 8                                            |
| A6 [   | 8  | /AM-6         | 33 🛛 Вб  | A6 []                                             |
| A5 [   | 9  |               | 32 🛛 B5  | A4 4 11                                           |
| A4 [   | 10 | TMPZ84C20AP-8 | 31 🛛 В4  | NC [ 12                                           |
| vss [  | 11 |               | 30 🛛 ВЗ  | VSS LL: 13 TMP284C20AT-6                          |
| A3 [   | 12 |               | 29 🛛 в2  | A2 4 15                                           |
| A2 [   | 13 |               | 28 🛛 B1  | A1 4 16                                           |
| A1 [   | 14 |               | 27 🛛 во  | A0 Ц: 17<br>1819202122232425262728                |
| A0 [   | 15 |               | 26 🛛 VCC |                                                   |
| ASTB [ | 16 |               | 25 🛛 СLК | <u> </u>                                          |
| BSTB [ | 17 |               | 24 🛛 IEI | L D C C C C C C C C C C C C C C C C C C           |
| ARDY [ | 18 |               | 23 🛛 ĪNT |                                                   |
| D0 [   | 19 |               | 22   IEO |                                                   |
| D1 [   | 20 |               | 21 BRDY  |                                                   |
|        |    |               | 10       | 00489                                             |

Figure 2.1 DIP, SOP Pin Connection

Figure 2.2 44-Pin PLCC Package

Indicates if signal on the data bus is control signal or data. Selects

data at L level and command at H level. Normally, connected to

#### 2.2 **PIN NAMES AND FUNCTIONS**

1

Input

CE

C/D

I/O pin names and functions are as shown in Table 2.1.

| Table 2.1 Pin Names and Functions (175) |                  |                         |                                                                                                                                                                                                                   |  |  |  |  |
|-----------------------------------------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Pin Name                                | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                          |  |  |  |  |
| D0~D7                                   | 8                | I/O<br>3-state          | 8-bit bidirectional data bus.<br>Data transfer between MPU and PIO.                                                                                                                                               |  |  |  |  |
| ĈĒ                                      | 1                | Input                   | Chip enable.<br>Used for accessing MPU and PIO.<br>When MPU selects this PIO, this terminal becomes L level<br>(Refer to 3.4 Basic timing.)<br>Normally, this terminal is connected to the address decoder output |  |  |  |  |

Control/data select.

address bit A1 of MPU.

| Fable 2.1 | Pin Nam | les and | Function | s (1/3) |
|-----------|---------|---------|----------|---------|
|-----------|---------|---------|----------|---------|

100489

100489

| Pin Name | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                                      |
|----------|------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| B/Ā      | 1                | Input                   | Port A/Port B select.<br>Selects Port A at L level and Port B at H level.<br>Normally, connected to address bit A0 of MPU.                                                                                                                                                                                                                                    |
| A0~A7    | 8                | l/O<br>3-state          | Port A bus.<br>Data transfer between Port A PIO and external device.                                                                                                                                                                                                                                                                                          |
| ASTB     | 1                | Input                   | Port A strobe input<br>Handshake signal from the external device.<br>Signal meaning differs depending upon operation mode.<br>(Refer to 3.4 Basic timing.)                                                                                                                                                                                                    |
| BSTB     | 1                | Input                   | Port B strobe input<br>Handshake signal from the external device.<br>Signal meaning is the same as ASTB but differs if Port A is in Mode 2.<br>(Refer to 3.4 Basic timing.)<br>Register A ready.                                                                                                                                                              |
| ARDY     | 1                | Output                  | Port A ready.<br>Handshake signal to the external device.<br>Signal meaning differs depending upon operation mode.<br>(Refer to 3.4 Basic timing.)                                                                                                                                                                                                            |
| M1       | 1                | Input                   | Machine cycle 1.<br>When both M1 and IORQ are at L level, indicates that MPU is<br>executing the interrupt acknowledge cycle.<br>(Refer to 3.4 Basic timing.)<br>Normally, connected to M1 of MPU.                                                                                                                                                            |
| IORQ     | 1                | Input                   | I/O request.<br>Used to access between MPU and PIO. This terminal becomes L level<br>when I/O addresses are on the address in the write cycle and read<br>cycle. Further, when IORQ and M1 are both at L level, it indicates<br>that MPU is executing the interrupt acknowredge cycle.<br>(Refer to 3.4 Basic timing.)<br>Normally, connected to IORQ of MPU. |
| RD       | 1                | Input                   | Read signal.<br>Used to access between MPU and PIO.<br>Controls the transfer direction.<br>(Refer to 3.4 Basic timing)<br>Normally, connected to RD of MPU.                                                                                                                                                                                                   |
| B0~B7    | 8                | l/O<br>3-state          | Port B bus.<br>Data transfer between Port B of PIO and external device. Capable of<br>driving – 1.5mA (@VoH = 1.5V) Darlington transistors.                                                                                                                                                                                                                   |
| CLK      | 1                | Input                   | System clock.<br>Signal-phase clock input.<br>In DC state (either at H or L level), PIO is in a stand-by state and<br>power consumption becomes extermely less.                                                                                                                                                                                               |

Table 2.1 Pin Names and Functions (2/3)
| Pin name        | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                          |
|-----------------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| IEI             | 1                | Input                   | Interrupt enable input.<br>Together with IEO and INT, forms daisy chain interrupt control<br>signal. Connected to IEO of high priority peripheral LSI.<br>However, to give higher priority than other peripheral LSI's to this<br>PIO, connect this terminal to the + 5V power.<br>(Refer to 3.3.2 Interruption.) |
| ĪNT             | 1                | Output                  | interrupt request.<br>interrupt request signal for MPU.<br>Connect to INT of MPU. (Open drain)                                                                                                                                                                                                                    |
| IEO             | 1                | Output                  | Interrupt enable output.<br>Together with IEI and INT, forms daisy chain interrupt control signal.<br>Connected to IEI or low prioirity peripheral LSI.<br>However, if this PIO has the lowest priority than any other<br>peripheral LSI's, this IEO is not used.<br>(Refer to 3.3.2 Interruption.)               |
| BRDY            | 1                | Output                  | Port B ready<br>Handshake signal to the external device.<br>Signal meaning is the same as that of ARDY.<br>However, it differs when Port A is in Mode 2.<br>(Rerfer to 3.4 Basic timing.)                                                                                                                         |
| V <sub>CC</sub> | 1                | Power supply            | + 5V                                                                                                                                                                                                                                                                                                              |
| V <sub>SS</sub> | 1                | Power supply            | 0V                                                                                                                                                                                                                                                                                                                |

| Table 2.1 | Pin Nar | nes and | Functions | (3/3) |
|-----------|---------|---------|-----------|-------|
|-----------|---------|---------|-----------|-------|

100489

#### 3. FUNCTIONAL DESCRIPTION

#### 3.1 **PIO BLOCK DIAGRAM**

Figure 3.1 shows the PIO block diagram.



Figure 3.1 PIO Block Diagram

#### **PIO SYSTEM CONFIGURATION** 3.2

The PIO system consists of the four logic circuits:

- (1)MPU bus I/O logic circuit
- (2)Internal control logic circuit
- (3)Interrupt control logic circuit
- Port I/O logic circuit (4)
- MPU Bus I/O Logic Circuit [1]

The MPU bus I/O logic circuit transfers data between the MPU and the PIO.

[2] Internal Control Logic Circuit

> The internal control logic circuit controls the PIO operating functions like the PIO selecting chip enable and the read/write circuits.

# [3] Interrupt Control Logic Circuit

The interrupt control logic circuit performs the MPU interrupt-associated processing such as determining interrupt priorities. The priorities with other LSI peripherals are determined by the physical location chain connection.

[4] Port I/O Logic Circuit

The port I/O logic circuits are used to directly connect to peripheral devices. Each consists of the following 7 registers and 1 flip-flop. Data are written in the registers by the MPU as specified in the program. Figure 3.2 shows the internal configuration of the ports.

- Data output register (8 bits)
- Data input register (8 bits)
- Mode control register (2 bits)
- Interrupt vector register (8 bits)
- Interrupt control register (2 bits)
- Mask control register (8 bits)
- Data I/O control register (8 bits)
- Handshake control logic circuit





# (1) Data Output Register

This register holds the data to be teansferred from the MPU to peripheral devices.

(2) Data Input Register

This register latches the data to be transferres from peripheral devices to the MPU.

The input data to the MPU is read through this register.

(3) Mode Control Register

This register specifies the operation mode. The operation mode is set by MPU control.

(4) Interrupt Vector Register

This register holds the vector which makes up the address of the table storing the start adress of the interrupt processing routine.

This register is used only for interrupt processing.

(5) Interrupt Control Register

This register specifies how the I/O ports are to be monitored. This register is used only in the PIO mode 3.

(6) Mask Control Register

This register specifies which I/O port pin is to be monitored. This register is used only in the PIO mode 3.

(7) Data I/O Control Register

This register specifies whether each port pin is to be used as output or input. This register is used only in PIO mode 3.

(8) Handshake Control Logic

This cirsuit controls the data transfer to the peripheral devices connected to the 8-bit I/O ports.

# 3.3 PIO BASIC OPERATIONS

[1] Reset

The PIO provides the following two reset capabilities:

When PIO is connected with the MPU (TMPZ84C00A, 01A, 02A) of Z80 series, or ASSP (TMPZ84C011A, 013A, 015A, 710A, 810A), it is necessary to connect with external logic as Figure 3.3.





#### (1) Power-on Reset

The PIO contains the circuit which automatically resets the PIO at the time of power-on.

#### (2) Hardware Reset

Making the  $\overline{\text{M1}}$  pin low for 2 system clock periods with the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins being high resets the PIO on the rising edge of the  $\overline{\text{M1}}$  pin.

#### Reset State

- (a) The operation mode is set to mode 1 for both ports.
- (b) Interrupt is disabled.
- (c) All the bits of the data I/O register of each port are reset.
- (d) All the bits of the mask control register of each port are set and masked.
- (e) The port I/O lines of each port are put in the high-impedance state (floating).
- (f) The RDY pin of each port goes low.

The reset state is held until the control word is written. For the function of the control word, see Subsection 3.5 "Operational Procedure".

[2] Interrupt

The PIO can cause an interrupt when the MPU is operating in mode 2. The interrupt request signal ( $\overline{INT}$ ) from the PIO is accepted when the MPU is in the inetrrupt enabled state (caused after the execution of EI instruction). Receiving the  $\overline{INT}$  signal, the MPU latches the interrupt vector (8-bit data) sent from PIO, specifies the start address of the interrupt processing routine based on the vector, and calls the routine to start the processing.

Thus, since the start address of the interrupt processing routine can be specified by the interrupt vector sent from the PIO, the user can change the vector value to call any desired address.

Interrupt processing is terminated when the MPU executes the RETI instruction. The PIO has the circuit to decode the RETI instruction to detect the termination of interrupt processing by constantly monitoring the data bus.

The interrupt priority among the Z80 peripharal LSIs is determined by the daisy chain structure. In daisy chain, the peripheral LSIs are connected one after another as shown in Figure 3.4. The more a peripheral LSIs is physically located near the MPU, the higher the priority of the peripheral is. Within the PIO, port A is given higher priority than port B. The Z80 peripheral LSIs have the signal lines IEO and IEI connected to the IEO of a higher peripheral LSIs and IEI of a lower peripheral LSI respectively. However, the IEI of the highest peripheral LSIs is connected to the IEI pin and the IEO of the lowest peripheral LSI is connected to the IEO pin. In this state, the PIO interrupt follows the conditions:

- When both IEI and IEO are high, no interrupt has occurred. This time, the interrupt request signal (INT) is high. In this state, the PIO can request interrupt.
- When the PIO sends the INT signal, it sets the IEO line to the low level. When the interrupt request is accepted by the MPU, INT goes back to the low level.
- When the IEI goes low, the IEO also goes low.
- When the IEI is low, the PIO cannot request an interrupt.
- If the IEI goes low during interrupt occurrence, the interrupt processing is suspended.

The operations of the four Z80 peripheral LSIs (the states of IEI, IEO and INT signal) daisy-chained as shown in Figure 3.4 are as follows:

(1) Before interrupt occurrence



# (2) Interrupt request from LSI-2 to the MPU



(3) The MPU acknowledges (enables) the interrupt. Interrupt processing for LSI-2 is performed.



(4) Interrupt request from LSI-1 to the MPU. The interrupt processing for LSI-2 is suspended.



(5) The MPU acknowledges (enables) the interrupt. Interrupt processing for LSI-1 is performed.



(6) Interrupt processing for LSI-1 terminates (upon execution of the RETI instruction). Interrupt processing for LSI-2 is restarted.



(7) Interrupt processing for LSI-2 terminates (upon execution of the RETI instruction).



Interrupt priority is given to LSI-1, LSI-2, LSI-3 and LSI-4 in this order.

100489

# Figure 3.4 Signal States in Daisy Chain Structure

# [3] Operation Modes

The PIO operates in one of the 4 operation modes. The mode is selected by writing the mode control word.

- Mode 0 (byte output mode)
- Mode 1 (byte input mode)
- Mode 2 (byte I/O mode)
- Mode 3 (bite mode)
- (1) Mode 0 (byte output mode)

In mode 0, the PIO sends the data received from the MPU to the external device through the port data output register. The contents of this register can be rewritten by using an output instruction. If the data on the bus change, the register contents remain unchanged until the next output instruction is executed. When the MPU executes an output instruction, the write signal is generated in the PIO in the write cycle. Using the signal, data on the data bus can be latched in the data output register.

(2) Mode 1 (byte input mode)

In this mode, the PIO sends the data received from the external device to the MPU through the port data input register. The data transfer to the MPU is suspended until the MPU has read the current data.

(3) Mode 2 (byte I/O mode)

Mode 2 is a combination of mode 0 and mode 1. This mode is used only for port A. In this mode, all 4 handshake control lines are used. Port A's handshake control lines are used for data output and the port B's handshake control lines are used for data input. For data transfer, port A is used. Port B is set in mode 3 (bit mode) in which no handshake control line is used.

In this mode, the interrupt timing occurs almost at the same time in mode 0 and mode 1. In an input operation, the port B's handshake control lines are used, so that the interrupt vetor written in port B is transferred. Therefore, the interrupts in input and output can be controlled by different vectors.

(4) Mode 3 (bit mode)

In mode 3, the 8-bit port I/O lines are controlled for each bit. Since no handshake control lines are used, ordinaly read/write operations can be performed. I/O operations can be performed on the port as well. In a write operation, the data sent from the MPU to the PIO are latched in the data output register corresponding to the bit set for output in the same timing as in mode 0.

An interrupt occurs in the interrupt enabled state and when the bit set for input satisfies the condition specified in the interrupt control word. However, if port A is operating in mode 2, port B cannot cause an interrupt in the bit mode. Note that, to use the interrupt capability, the mask control register bit corresponding to the bit set for output must be set to "1" to disable its interrupt.

### 3.4 PIO STATUS TRANSITION AND BASIC TIMING

#### [1] Status Transition

Figure 3.5 shows the PIO status transition diagram.





TMPZ84C20A



Figure 3.5 (b) PIO Status Transition

#### [2] Write Cycle

The  $\overline{IORQ}$ ,  $\overline{RD}$ ,  $C/\overline{D}$  (A0), and  $\overline{CE}(A7 \text{ through A0})$  signals generate the write signal (\* $\overline{WR}$ ) inside the PIO.

The MPU sets the PIO's  $\overline{IORQ}$  signal to the low level at system clock T2, to start the write cycle. At this time, to indicate that this cycle is a write sycle, the PIO's  $\overline{M1}$  signal must be set to the high level. At the same time, the MPU sends signals to the PIO's  $\overline{B/A}$  (A1) and  $\overline{C/D}$  (A0) to specify the port or select control signal or the data. This allows the port data ouput register of the PIO's selected port to latch the data at system clock T3. TW is a wait state automatically inserted by the MPU.



Figure 3.6 Write Cycle Timing

[3] Read Cycle

The MPU sets the PIO's,  $\overline{\text{RD}}$  pin,  $\overline{\text{CE}}$  signal, and  $\overline{\text{IORQ}}$  pin to the low level at system clock T2 to start the read cycle. At this time, to indicate that this cycle is a read cycle, the PIO's M1 pin must be set to the high level. The PIO outputs data in the  $\overline{\text{CE}}$ ,  $\overline{\text{IORQ}}$ , and  $\overline{\text{RD}}$  signals. TW is a wait state automatically inserted by the MPU.

#### TMPZ84C20A





#### Figure 3.7 Read Cycle Timing

[4] Mode 0 (Byte Output Mode)

The mode 0 output cycle starts when the MPU executes an output instruction. When an output instruction is executed, he write signal (\* $\overline{WR}$ ) is generated in the PIO in the write cycle. This signal latches the data on the data bus to the data output register of the selected port. The RDY pin goes high on the first falling edge of the system clock after the rise of the write signal (\* $\overline{WR}$ ). This indicates that the data in the data output register are already on the port I/O pin. The peripheral device sets the RDY pin to the low level on the first falling edge of the system clock after the rise of the  $\overline{STB}$  pin to be input to the PIO to indicate that the peripheral device has received the data from the port I/O pin, waiting for the next output instruction. If, at this time, the PIO is enabled for interrupts, it sets the  $\overline{INT}$  pin to the low level on the rising edge of the  $\overline{STB}$  signal to output the interrupt request signal to the MPU. Figure 3.8 shows the timing chart of mode 0.

# [5] Mode 1 (Byte Input Mode)

The input cycle starts when the MPU has completed the previous data read operation. The peripheral device sets the PIO's  $\overline{\text{STB}}$  pin to the lower level, putting data on the port I/O line.

The RDY pin is driven low on the first falling edge of the system clock after the rise of the  $\overline{\text{STB}}$  pin, disabling the peripheral device to send the next data. If, at this time, the

PIO is enabled for interrupts, it sets the  $\overline{INT}$  pin to the low level on the rising edge of the  $\overline{STB}$  pin, making an interrupt request to the MPU. When the MPU executes the input instruction in the interrupt processing routine, the read signal (\* $\overline{RD}$ ) is generated in the PIO in the read cycle. This signal puts the data in the data input register of the selected port on the data bus. The MPU receives this data. The PIO sets the RDY pin to the high level on the first falling edge of the system clock after the rise of the read signal (\* $\overline{RD}$ ) to wait for the input of the next data. Figure 3.9 shows the mode 1 timing chart.



Figure 3.8 Mode 0 Timing Chart





### [6] Mode 2 (Byte I/O Mode)

Mode 2 is a combination of mode 0 and mode 1. The timing for output operation is generally the same as in mode 0 except that, in mode 2, data is output only when the  $\overline{\text{ASTB}}$  pin is low while, in mode 0, data is always on the port I/O line. The peripheral device can receive data on the rising edge of the  $\overline{\text{ASTB}}$  signal being used as the latch signal.

The input timing is the same as in mode 1.

The port A handshake line is used as output control and the port B handshake line is as input control.

The value of the interrupt vector generated by the BSTB signal during port A input operation is the same as the value of the interrupt vector generated when port B is used in mode 3. Hence, all port B bits are masked by setting the mask control word to disable port B for the interrupt capability.





[7] Mode 3 (Bit Mode)

In this mode, no handshake line is used. Therefore, the ordinary port read/write operations can be performed, permitting access to the ports any time. The write data from the MPU is latched to the data output register corresponding to the bit set for output in the same timing as in mode 0. Except when port B is used in mode 2, the STB pin of the port operating in mode 3 is fixed to the low level. The transfer data consists of the data in the data output register and in the data input register. That is, the data of the bit set for output and the data of the bit set for input make up the transfer data.

An interrupt occurs when the interrupt enabled state is on and the bits set for input safety the condition specified by the mask control word, etc. However, if port A is operating in mode 2, port B is disabled for interrupt in the bit mode. Note that, to use the interrupt capability, the bit on the mask register corresponding to the bit set for output must be set to "1" to disable it for interrupts.

An interrupt request occurs when the logic condition becomes true. If the logic condition becomes true immediately before the  $\overline{M1}$  pin becomes low or while  $\overline{M1}$  pin low, an interrupt request occurs on the rising edge on the  $\overline{M1}$  pin.



Figure 3.11 Mode 3 Timing Chart

[8] Interrupt Acknowredge Cycle

Outputting the interrupt request signal (INT), the PIO sets the IEO signal to the low level, disabling the low-priority peripheral LSIs for interrupt requests.

Receiving the interrupt request signal ( $\overline{INT}$ ) from the PIO, the MPU sets the PIO's  $\overline{M1}$  and  $\overline{IORQ}$  pins to the low level to indicate that the MPU has acknowledged the interrupt request. The  $\overline{IORQ}$  pin goes low 2.5 system clocks later than the  $\overline{M1}$  pin. To stabilize the daisy-chained signal lines (IEI and IEO), the ports and peripheral LSIs cannot change the interrupt request.

The  $\overline{\text{RD}}$  pin remaines high to make distinction between the instruction fetch and interrupt acknowledge cycles. While the  $\overline{\text{RD}}$  pin is high, the interrupt control logic in the PIO determines the interrupt requesting port of the highest priority. When the  $\overline{\text{IORQ}}$  pin goes low with the IEI pin being high, the interrupt vector is put on the data bus from the interrupt requesting port. At the same time, two system clocks are automatically inserted by the MPU as a wait state to stabilize the daisy chain structure.



Figure 3.12 Interrupt Acknowledge Cycle Timing Charts

#### [9] Return from Interrupt Cycle

Return from interrupt processing is performed when the MPU executes the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When the MPU executes this instruction, the PIO's IEI and IEO return to the states active before interrupt processing.

The RETI instruction consists of two bytes and its code EDH and 4DH. The PIO decodes the RETI instruction to determine whether there is any interrupt requesting port. In the daisy chain structure, the IEI and IEO of the interrupting LSI remain high and low respectively at the time the instruction code EDH has been decoded. If the code following EDH is 4DH, only the peripheral LSI which has sent an interrupt vector immediately before, that is, the LSI whose IEI is high and IEO is low, returns from interrupt processing. This restarts the interrupt processing of the supended peripheral LSIs of lower interrupt priory.



Figure 3.13 Interrupt Cycle Return Timing Chart

# 3.5 PIO OPERATIONAL PROCEDURE

To operate the PIO the control words shown below must be written in it as the initial settings. They must be wrriten in the PIO's ports, A and B, separately. Spesify the I/O address listed in Table 3.1 to write control words and data in the PIO.

| I/O function   | B/A | C/D | ĊĒ     |
|----------------|-----|-----|--------|
| Port A data    | 0   | 0   | 0      |
| Port B command | 0   | 1   | 0      |
| Port B data    | 1   | 0   | 0      |
| Port B command | 1   | 1   | 0      |
|                |     |     | 100489 |

Table 3.1 I/O Adreesses

# (1) Interrupt Vector Word



200489

- Using this vector and the contents of the address indicated by the MPU's register, the MPU generates the start address of the interrupt processing routine.
- D0 through D7 are written in the interrupt processing register.
- This word is not needed when the interrupt capability is not used.

100489

100489

### (2) Mode Control Word



- This word specifies an operation mode.
- D7 and D6 are written in the mode control register.
- (3) Data I/O Control Word



- This word is needed only in mode 3.
- When mode 3 is specified by the mode control word, the data I/O control word is written after it.
- Each port is specified for output or input.
- D0 through D7 are written in the data I/O register.
- (4) Interrupt Control Word



- This word is for interrupt control such as interrupt condition setting.
- D4, D5, and D6 are used only in mode 3.
- With D6=0, interrupt occurs when one of the bits not masked (the bit to be monitored) by the mask control word goes active.
- With D6=1, interrupt occurs when all bits not masked (the bit to be monitored) by the mask control word goes active.
- With D4 = 1, the suspended interrupts are all reset regardless of the mode.
- D5 and D6 are written in the control register.

### (5) Mask Control Word



100489

- This word is needed only in mode 3.
- When D4=1 is set by the interrupt control word, the mask control word must be written after it.
- This word specifies whether to monitor the port I/O line specified for input by the data I/O control word.
- When the bit is set to 0, the corresponding input line is monitored and regarded as the input associated with interrupt occurrence.
- When the bit is set to 1, the corresponding input line is masked to provide the input not related to interrupt occurrence.
- The PIO checkes only the input line with the bit being 0 to see if the interrupt condition is satisfied. If the condition is satisfied, the PIO requests an interrupt.
- D0 through D7 are written in the mask control register.

When port A is put in mode 2, all 4 handshake lines are used, so that port B must be set in mode 3 which uses no handshake lines. At the same time, all mask control word bits must be set to 1 (masked).

Note : Only interrupt enable/disable can be set by the following control word:



#### 3.6 USING PIO

The following is a programming example to operate the PIO's port in mode 3. This program is followed by the main routine and the interrupt processing program.

- The MPU is used in the mode 2 interrupt.
- The table storing the start address of the interrupt processing routine is 0802H.
- Interrupts occur when both PIO's port input lines A6 and A5 go high.
- The I/O addresses of the PIO are the address listed in Table 3.1.



100489

Figure 3.14 PIO Connection

ORG 100H LD SP, 100H ..... Sets the stack pointer. ..... Sets for MPU mode 2 interrupt. LM 2 LD A,08H ..... Writes data in MPU I register. LD I,A ï LD A,02H ..... Writes the interrupt vector word. OUT (01H),A LD A, OCFH ····· Writes the mode control word. OUT (01H),A LD A,62H ..... Writes the data I/O control word, Sets PIO. OUT (01H),A  $\cdots \cdots$  Writes interrupt control word. LD A,F7H OUT(01H),A LD A,9FH ····· Writes the mask control word. OUT (01H),A ; ······ Set interrupt enable. ΕI

# 4. ELECTRICAL CHARACTERISTICS

# 4.1 ABSOLUTE MAXIMUM RATING

| Symbol          | lter                                  | n            | Rating       | Unit |  |
|-----------------|---------------------------------------|--------------|--------------|------|--|
| V <sub>CC</sub> | Supply Voltage                        |              | - 0.5~ + 7   | V    |  |
| V <sub>IN</sub> | Input Voltage                         |              | -0.5~VCC+0.3 | V    |  |
| PD              | Power Dissipation(6MHz VI<br>(8MHz VI | 250          | mW           |      |  |
| TSOLDER         | Soldering Temperature (10 s           | 260          | °C           |      |  |
| TSTG            | Storage Temperature                   | -65~150      | °C           |      |  |
| TOP             | Operating Temperature                 | 6MHz VERSION | - 40~85      | °C   |  |
| TOPR            |                                       | 8MHz VERSION | - 10~70      | Ľ    |  |

050489

# 4.2 DC ELECTRICAL CHARACTERISTICS

| 6MHz VERSION | : | $T_A = -40^{\circ}C \sim 85^{\circ}C, V_{CC} = 5V \pm 10\%, V_{SS} = 0V$ |
|--------------|---|--------------------------------------------------------------------------|
| 8MHz VERSION | : | $T_A = -10^{\circ}C \sim 70^{\circ}C, V_{CC} = 5V \pm 5\%, V_{SS} = 0V$  |

| SYMBOL                                             | PARAMETER                                  | TEST CON                                                       | MIN.                             | TYP.                  | MAX.         | UNIT                  |    |
|----------------------------------------------------|--------------------------------------------|----------------------------------------------------------------|----------------------------------|-----------------------|--------------|-----------------------|----|
| VILC                                               | Low Clock Input Voltage                    |                                                                |                                  | - 0.3                 | <del>.</del> | 0.6                   | V  |
| VIHC                                               | High Clock Input Voltage                   |                                                                |                                  | V <sub>CC</sub> – 0.6 | <u> </u>     | V <sub>CC</sub> + 0.3 | V  |
| VIL                                                | Low Input Voltage (Except CLK)             |                                                                |                                  | - 0.5                 | _            | 0.8                   | V  |
| VIH                                                | High Input Voltage (Except CLK)            |                                                                |                                  | 2.2                   | -            | Vcc                   | V  |
| VOL                                                | Output Low Voltage                         | IOL = 2.0mA                                                    |                                  | -                     | -            | 0.4                   | V  |
| VOH1                                               | Output High Voltage(I)                     | IOH = - 1.6m                                                   | A                                | 2.4                   | —            | _                     | V  |
| VOH2                                               | Output High Voltage(II)                    | IOH = - 250µ                                                   | A                                | V <sub>CC</sub> – 0.8 | -            | _                     | v  |
| ILI                                                | Input Leakage Current                      | $V_{SS} \leq V_{IN} \leq V_{C}$                                | c                                | _                     | -            | ± 10                  | μA |
| ILO                                                | 3-STATE Output Leakage<br>Current in Float | $V_{SS} + 0.4 \leq V$                                          | <sub>OUT</sub> ≦ V <sub>CC</sub> | -                     | _            | ± 10                  | μА |
| IOHD<br>(2)                                        | Darlington Drive Current                   | VOH = 1.5V<br>REXT = 1.1KΩ                                     | VOH = 1.5V<br>REXT = 1.1KΩ       |                       |              | - 5.0                 | mA |
|                                                    |                                            | $V_{CC} = 5V$<br>$f_{CLK} = (1)$<br>$V_{ILC} = V_{IL}$         | AP-6/<br>AM-6/<br>AT-6           | _                     | 3            | 8                     |    |
| ICC1                                               | Power Supply Current                       | $= 0.2V$ $V_{IHC} = V_{IH}$ $= V_{CC} - 0.2V$                  | AP-8                             | _                     | 4            | 10                    | mA |
| ICC2                                               | Standly Supply Current                     | $V_{ILC} = V_{IL} = 0.2$<br>$V_{IHC} = V_{IH} = V_{CC} - 0.2V$ |                                  | _                     | 0.5          | 10                    | μА |
| Note: (1) fCLK=1/tcC (MIN.) (2) Port B only 050489 |                                            |                                                                |                                  |                       |              |                       |    |

(1/2)

# 4.3 AC ELECTRICAL CHARACTERISTICS

| NO. | SYMBOL           | PARAMETER                                                                                                     | AP-6/AM-6/<br>AT-6<br>(6MHz) |            | AP-8<br>(8MHz) |            | UNIT |
|-----|------------------|---------------------------------------------------------------------------------------------------------------|------------------------------|------------|----------------|------------|------|
|     |                  |                                                                                                               | MIN.                         | MAX.       | MIN.           | MAX.       |      |
| 1   | T <sub>C</sub> C | Clock cycle time                                                                                              | 165                          | DC         | 125            | DC         | ns   |
| 2   | TwCh             | High clock pulse width                                                                                        | 65                           | DC         | 50             | DC         | ns   |
| 3   | TwCl             | Low clock pulse width                                                                                         | 65                           | DC         | 50             | DC         | ns   |
| 4   | TfC              | Clock falling time                                                                                            |                              | 20         | —              | 15         | ns   |
| 5   | TrC              | Clock rising time                                                                                             | -                            | 20         | -              | 15         | ns   |
| 6   | TsCS (RI)        | $\overline{CE}$ , B/ $\overline{A}$ and C/ $\overline{D}$ set-up time for $\overline{RD}$ , $\overline{IORQ}$ | 50                           | -          | 50             | -          | ns   |
| *7  | Th               | Hold time                                                                                                     | 40                           | -          | 40             | -          | ns   |
| 8   | TsRI (C)         | RD, IORQ set-up time for clock rise                                                                           | 70                           | -          | 60             |            | ns   |
| 9   | TdRI (DO)        | Delay from $\overline{\text{RD}}$ , $\overline{\text{IORQ}}$ fall to data output                              |                              | 300        | -              | 200        | ns   |
| 10  | TdRI (DOs)       | Delay from $\overline{\text{RD}}$ , $\overline{\text{IORQ}}$ rise to data float                               | -                            | 70         | -              | 70         | ns   |
| 11  | TsDI (C)         | Data set-up time for clock rise                                                                               |                              | -          | 40             | -          | ns   |
| 12  | TdIO (DOI)       | Delay from IORQ fall of INTA cycle to data output                                                             |                              | 120        | -              | 85         | ns   |
| 13  | TsM1 (Cr)        | $\overline{M1}$ = L set-up time for clock rise                                                                | 70                           | -          | 50             | -          | ns   |
| 14  | TsM1 (Cf)        | $\overline{M1} = H$ set-up time for clock fall ( $\overline{M1}$ sycle)                                       | 0                            | -          | 0              | -          | ns   |
| 15  | TdM1 (IEO)       | Delay from $\overline{M1}$ fall to IEO fall                                                                   | —                            | 100<br>(1) | _              | 100<br>(1) | ns   |
| 16  | TsIEI (IO)       | IEI set-up time for IORQ fall (INTA cycle)                                                                    | 100                          | -          | 80             | -          | ns   |
| 17  | TdIEI (IEOf)     | Delay from IEI fall to IEO rise                                                                               | -                            | 120        | -              | 100        | ns   |
| 18  | TdIEI (IEOr)     | Delay from IEI rise to IEO fall                                                                               | —                            | 150        | -              | 120        | ns   |
| 19  | TclO (C)         | IORQ = H set-up time for clock fall<br>(in case of making READY to active by next<br>cycle)                   | 170                          | _          | 120            |            | ns   |
| 20  | TdC (RDYr)       | Delay from clock fall to READY rise                                                                           | —                            | 170        | -              | 150        | ns   |
| 21  | TdC (RDYf)       | Delay from clock fall to READY fall                                                                           |                              | 120        | -              | 110        | ns   |
| 22  | TwSTB (C)        | STROBE pulse width                                                                                            | 120<br>(2)                   |            | 100<br>(2)     | _          | ns   |
| 23  | TsSTB (C)        | Set-up time of STROBE rise for clock fall<br>(in case of making READY to active by next<br>cycle)             | 150                          | _          | 100            | _          | ns   |

200489

|            |             |                                                                     |      |                              |      |                | (2/2)  |
|------------|-------------|---------------------------------------------------------------------|------|------------------------------|------|----------------|--------|
| NO. SYMBOL |             | PARAMETER                                                           |      | AP-6/AM-6/<br>AT-6<br>(6MHz) |      | AP-8<br>(8MHz) |        |
|            |             |                                                                     | MIN. | MAX.                         | MIN. | MAX.           |        |
| 24         | TdIO (PD)   | Delay from IORQ rise to port data stable (Mode 0)                   | _    | 160                          | -    | 140            | ns     |
| 25         | TsPD (STB)  | Data set-up time for STROBE rise (Mode 1)                           | 190  | —                            | 150  |                | ns     |
| 26         | TdSTB (PD)  | Output data delay time from STROBE fall (Mode 2)                    | . —  | 180                          | -    | 150            | ns     |
| 27         | TdSTB (PDr) | Delay from STROBE rise to data float<br>(Mode 2)                    |      | 160                          | _    | 120            | ns     |
| 28         | TdPD (INT)  | Delay from port data match to $\overline{\text{INT}}$ fall (Mode 3) | _    | 430                          | _    | 350            | ns     |
| 29         | TdSTB (INT) | Delay from STROBE rise to INT fall<br>(Mode 2)                      | _    | 350                          | _    | 250            | ns     |
|            |             |                                                                     |      |                              |      |                | 200489 |

Note :

1 Item with \* mark (No.7) is not compatible with NMOS Z80 PIO.

2 (1) If the daisy chain is at N stage,

2.5 TcC>(N-2)TdIEI(IEOf) + TdM1(IEO) + TsIEI(IO) + TTL buffer delay must be satisfied.

- (2) In Mode 2, TwSTB>TsPD(STB) must be satisfied.
- (3) At test condition : Input : VIH = 2.4V, VIHC = VCC 0.6V, VIL = 0.4V, VILC = 0.6VOutput : VOH = 2.2V, VOL = 0.8V, CL = 100 pF

# 4.4 CAPACITANCE

 $TA = 25^{\circ}C$ 

| SYMBOL | ITEM                    | TEST CONDITION                                  | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|-------------------------------------------------|------|------|------|------|
| CCLOCK | Clock Input Capacitance | f = 1MHz                                        | —    | -    | 10   | рF   |
| CIN    | Input Capacitance       | put Capacitance All terminals except that to be |      |      | 5    | рF   |
| COUT   | Output Capacitance      | measured should be earthed.                     | _    | -    | 10   | pF   |

050489

# 4.5 TIMING DIAGRAM

Numbers shown in the following figures correspond with those in the 4.3 A.C Electrical Characteristics Table.



050489

Figure 4.1 Timing Diagram

# 5. PACKAGE DIMENSION

# 5.1 40-PIN PLASTIC PACKAGE

DIP40-P-600



270289

Note 1: This dimention is measured at the center of bending point of leads.

Note 2: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.40 leads.

5.2 40-PIN SMALL OUTLINE PACKAGE

SSOP40-P-450

Unit : mm



270289

Note : Package Width and length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

# 5.3 44-PIN PLCC PACKAGE

# QFJ44-P-S650





# TMPZ84C30AP-6 / TMPZ84C30AM-6 / TMPZ84C30AT-6 TMPZ84C30AP-8

# TLCS-Z80 CTC : COUNTER TIMER CIRCUIT

# 1. GENERAL DESCRIPTION AND FEATURES

The TMPZ84C30A (hereinafter referred to as CTC) is CMOS version of Z80 CTC and has been designed to provide low power operation.

The TMPZ84C30A is fablicated using Toshiba's CMOS Silicon Gate Technology.

The principal functions and features of the CTC are as follows.

- (1) Compatible with the Zilog Z80 CTC.
- (2) Low power consumption.
  - 4mA Typ. (@5V @6MHz) … TMPZ84C30AP-6/AM-6/AT-6 5mA Typ. (@5V @8MHz) … TMPZ84C30AP-8 10μA Max. (@5V, Stand-by)
- DC to 6MHz operation ··· TMPZ84C30AP-6/AM-6/AT-6
  DC to 8MHz operation ··· TMPZ84C30AP-8
- (4) Single 5V power supply and single-phase clock. 5V  $\pm$  10% (6MHz VERSION) 5V  $\pm$  5% (8MHz VERSION)
- (5) Capable of driving Darlington transistors.
- (6) Four independent counter/timer channels each of which is capable of independently selecting Timer Mode and Counter Mode.
- (7) Each channel is provided with a prescaler to divide system clock into 16 or 256.
- (8) Built-in interrupt control logical operation circuit allows priority processing of interrupt in Daisy-chain structure and automatic loading of 8 bit interrupt vector on the system bus.
- (9) Four channels occupy 4 successive positions in the Daisy-chain structure. Most significant channel is Channel 0 and least significant channel is Channel 3.
- (10) In both modes, at the zero count, the content of the time constant register is automatically loaded on the down counter.
- (11) In either Counter Mode or Timer Mode, the content of the down counter is readable by the microprocessor (hereinafter referred to as MPU).
- (12) Interrupt function available in Z80 MPU Mode 2.

- (13) In Timer Mode, the timer operation is selectable at the rise or fall of the starting trigger. In addition, in Counter Mode the decrement (-1) of the content of the down counter either at the rise or fall of external clock is selectable.
- (14) Programming to generate interrupt by zero count by the down counter in each channel is possible.
- (15) 40 pin DIP package, 40 pin SOP, 44 pin PLCC package.

Note: Z80 is a trademark of Zilog Inc., U.S.A.

# 2. PIN CONNECTIONS AND PIN FUNCTIONS

# 2.1 PIN CONNECTIONS (Top View)

The pin connections of the CTC are as shown in Figure 2.1 and Figure 2.2.



Figure 2.1 DIP, SOP Pin Connections

Figure 2.2 44-Pin PLCC Package

### 2.2 PIN NAMES AND FUNCTIONS

I/O pin names and functions are as shown in Table 2.1.

| Pin Name                  | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                   |
|---------------------------|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0~D7                     | 8                | I/O<br>3-state          | 8-bit bi-directional data bus.                                                                                                                                                                                                                                             |
| RD                        | 1                | Input                   | The read signal.<br>This signal is used in combination with $\overline{\text{IORQ}}$ and $\overline{\text{CE}}$ signals for<br>transfer of data and channel control words between MPU and CTC.                                                                             |
| ZC / TO0<br>~<br>ZC / TO2 | 1                | Output                  | The Zero Count/Timer Out signal. In either the Timer mode, or counter mode, pulses are output from these pins when the down counter has reached zero.                                                                                                                      |
| IORQ                      | 1                | Input                   | I/O request signal.<br>This signal is used in combine with $\overline{\text{RD}}$ and $\overline{\text{CE}}$ signals for transfer of data and channel control words between MPU and CTC.                                                                                   |
| IEO                       | 1                | Output                  | Interruption enable output.<br>Controls interruptions by subordinate peripheral LSI's in the Daisy-<br>chain structure. This terminal becomes H level only when the IEI<br>terminal is at H level and MPU is not providing the interruption<br>service to channels in CTC. |

| Table 2.1 | Pin Names and | Functions | (1/2) |
|-----------|---------------|-----------|-------|
|-----------|---------------|-----------|-------|

100489

| Pin Name                        | Number<br>of Pin | Input/output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------------------------|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| INT                             | 1                | Output                  | Interruption request.<br>This terminal becomes L level if a down-counter for any channel in<br>CTC counts zero when the IEI terminal is at H level and interruption<br>is authorized by a program.                                                                                                                                                                                                                   |
| IEI                             | 1                | Input                   | The interrupt Enable Input signal. This signal is used with the IEO to form a priority daisy chain when there is more than one interrupt-<br>driven peripheral LSI.                                                                                                                                                                                                                                                  |
| M1                              | 1                | Input                   | Machine cycle 1.<br>Informs the machine cycle from MPU. In combination with the $\overline{\text{RD}}$ signal, indiates that MPU fetches commands from the memory, and in combination with the $\overline{\text{IORQ}}$ signal, indicates that MPU is in the interruption acknowledge cycle. This terminal is used, in combination with the $\overline{\text{IORQ}}$ signal, to send the interruption vector to MPU. |
| CLK                             | 1                | Input                   | Single-phase clock input.<br>Single-phase Z80 standard system clock is inputted to this terminal.<br>When this CLK terminal is in the DC state (high or low level), the CTC<br>is placed in the stationary state.                                                                                                                                                                                                    |
| CE                              | 1                | Input                   | Chip enable.<br>Used to write MPU-CTC channel control word, interruption vector,<br>and time constant or to read the content of a downcounter for each<br>channel in combination with the IORQ and RD terminals.                                                                                                                                                                                                     |
| RESET                           | 1                | Input                   | Reset signal .<br>When the reset signal is inputted to this terminal, all channels stop<br>to operate and interruption enable bits in all channel control<br>registers are reset. This RESET terminal must be kept at "L" level for<br>at least 3 system clocks.                                                                                                                                                     |
| CS0~CS1                         | 2                | Input                   | Channel selection.<br>Any one of four channels of the CTC is selected by 2-bit code at time<br>of read/write.                                                                                                                                                                                                                                                                                                        |
| CLK /<br>TRG0~<br>CLK /<br>TRG3 | 4                | Input                   | The external clock/timer trigger. These 4 CLK/TRG pins correspond<br>to 4 channels. In the counter mode, the down counter is<br>decremented by 1 and in the timer mode, the timer is activated at<br>each active edge (a rising of falling edge) of the signal which are<br>input by these pins. It can be selected by program whether the<br>active edge is a rising or falling edge.                               |
| Vcc                             | 1                |                         | The power supply ( + 5V) pin                                                                                                                                                                                                                                                                                                                                                                                         |
| Vss                             | 1                |                         | The ground (0V) pin                                                                                                                                                                                                                                                                                                                                                                                                  |

Table 2.1 Pin Names and Functions (2/2)

100489

# 3. FUNCTIONAL DESCRIPTION

# 3.1 BLOCK DIAGRAM

The block diagram of CTC is shown in Figure 3.1.



Figure 3.1 Block Diagram

# 3.2 SYSTEM CONFIGURATION

The CTC system consists of the following 4 logic circuits.

- (1) MPU bus Input/Output Logic Circuit
- (2) Internal control logic circuit
- (3) Interrupt Control Logic Circuit
- (4) 4 Independent Counter/Timer Channel Logic Circuit

# 3.2.1 MPU bus input/output logic circuit

This circuit transfers data between the MPU and the CTC.

3.2.2 Internal control logic circuit

This circuit controls the CTC operational functions such as the CTC selecting enable, reset, and read/write circuit.

### 3.2.3 Interrupt control logic circuit

This circuit performs the MPU interrupt related processing such as priority determination. The order of priority with other LSIs determined according to the physical location in daisy chain connection.

### 3.2.4 Counter/timer channel logic circuit

This circuit consists of the following 2 registers and 2 counters. Figure 3.2 shows the configuration of this circuit.

- Time-constant register (8 bits)
- Channel control register (8 bits)
- Down-counter (8 bits)
- Prescaler (8 bits)



Figure 3.2 Configuration Counter/Timer Channel Logic Circuit

(1) Time-constant register

This register holds the time constant to be written in the down counter. When the CTC is initialized or the down-counter has reached zero, the time constant is loaded into down-counter. The time constant is set immediately after the MPU has written the channel control word in the channel control register. For a time constant, an integer from 1 to 256 can be used.

#### (2) Channel control register

This register is used to choose the channel mode or condition according to the channel control word sent from the MPU.

# (3) Down-counter

The contents of the time-constant register are loaded into the down counter. In the counter mode, these contents are decremented for each edge of the external clock. In the timer mode, they are decremented for each prescaler clock output. The contents of the time-constant register are loaded at intialization or when the down-counter has reached zero.

The contents of the down-counter can be read any time. Also, the system can be programmed so that an interrupt request is generated each time the down-counter has reached zero.

# (4) Prescaler

The prescaler, used only in the timer mode, divides the system clock by 16 or 256. The dividing number is programmed by channel control word. The output of the prescaler becomes the clock input to the down-counter.

# 3.3 CTC BASIC OPERATIONS

# 3.3.1 Reset

The state of the CTC is unstable after it is powered on. To stabilize the CTC, the low level signal needs to be applied to the  $\overline{\text{RESET}}$  pin. On any channel, the channel control word and time-constant data must be written to be started before it is started in the counter or timer mode. To program the system to enable interrupts, the interrupt vector word must be written in the interrupt controller. When these data have been written in the CTC, it is ready to start.

# 3.3.2 Interrupt

The CTC can cause an interrupt when the MPU is operating on the mode 2. The CTC interrupt can be programmed for each channel. Each time the channel's down-counter has reached zero, the CTC outputs the interrupt request signal (INT). When the MPU accepts the CTC's interrupt request, the CTC outputs the interrupt vector. Based on this interrupt vector, the MPU specifies the start address of the interrupt processing routine and calls it to start interrupt processing.

The MPU specifies the start address of the interrupt processing routine by the interrupt vector output from the CTC, so that the user can change the vector value to call any desired address.

The interrupt processing is terminated when the MPU executes an RETI instruction. The CTC has the circuit which decodes the RETI instruction. By constantly monitoring the data bus the CTC can detect the termination of the interrupt processing.

The order of interrupt priority with the Z80 peripheral LSIs is determined by the daisy chain connection. That is, the peripheral LSIs are connected one after another and the one physically near MPU is given a higher priority.
Inside the CTC, channel 0 is given the highest priority, followed by channels 1, 2 and 3 in this order.

The CTC and other peripheral LSIs have the signal lines IEO and IEI. Connect the IEO of a higher peripheral LSI to the IEI of a lower peripheral LSI. Connect the IEI of the highest peripheral LSI to VCC. Leave the IEO of the peripheral LSI unused. In this connection, the CTC interrupt is caused under the following conditions:

- When both IEI and IEO are high, no interrupt is caused. At this time, the INT signal is high. An interrupt can be requested in this state.
- When the CTC outputs the interrupt request signal (INT), the IEO of the CTC becomes low. When the MPU accepts the interrupt, the INT goes high again.
- When the IEI goes low, the IEO also goes low.
- While the IEI is low, no interrupt can be requested.
- When the IEI goes low while an interrupt is being serviced, the interrupt processiong is aborted.

#### 3.3.3 Operation modes

The CTC oprates in either the counter mode or the timer mode. Mode is selected by writing the channel control word.

#### (1) Counter mode

In the counter mode, the number of edge of the pulse applied to the channel's CLK/TRG pin is counted. When pulses have been input, the contents of the down-counter are decremented synchronizing with the rising edge of the next system clock. The pulse's rising edge or falling esge to be counted can be specified by the channel control word.

When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin. When the interrupt is enabled by the channel control word, the  $\overline{INT}$  pin goes low and an interrupt is requested. When the contents of the down-counter has reached zero, the time constant data written in the time constant register is automatically loaded into the down-counter. To load a new time constant value into the down-counter, write the data to the time constant register, and it is loaded into the down-counter after the current count operation is terminated.

#### (2) Timer mode

In the timer mode, the time intervals which are integral multiples of the system clock period. A timer interval is measured according to the system clock. The system clock is supplied to the prescaler which divides it by a factor of 16 or 256. The output of the prescaler provides the clock to decrement the down-counter by 1. The time constant data is automatically loaded into the down-counter each time it has reached zero as in the counter mode. When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin.

This pulse period is given by the following expression:

tc \* P \* TC Where,tc = System clock period P = Prescaler value (16 or 256) TC = Time constant data (256 for 00H)

The user can select, by means of the channel control word, to start the timer automatically or to start the timer on the edge of the pulse at CLK/TRG pin. In case the user select the CLK/TRG pin, the user can also select the rising edge or falling edge of the pulse.

## TOSHIBA

#### 3.4 CTC STATUS TRANSITION DIAGRAM AND BASIC TIMING

#### 3.4.1 Transition diagram

Figure 3.3 shows the CTC status transition diagram.





MPUZ80-206



100489

Figure 3.3(b) CTC Transition Diagram (b)

### 3.4.2 Write cycle

The write cycle is used to write a channel control word, an interrupt vector, or a time constant. The MPU drives the  $\overline{IORQ}$  pin of the CTC low in the subsequent system clock cycle T2 to start the write cycle.

It is required to make the  $\overline{M1}$  pin of the CTC high to indicate that the write cycle is on.

At the state of the cycle, the channel is specified by CS1 or CS0 of the CTC. Thus, the CTC's internal registers are ready to accept data in system clock T3. Tw is the state to be automatically inserted by the MPU.

### TOSHIBA



Figure 3.4 Write Timing

## 3.4.3 Read cycle

The read cycle is used to read the contents of the down-counter. During clock cycle T2, the MPU initiates a read cycle by driving the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins low. It is required to make the  $\overline{\text{M1}}$  pin high to indicate that the read cycle is on. At the start of the read cycle, the channel is specified by CS1 or CS0 of the CTC.

At the rising edge of system clock TW, the contents of the down-counter at the time of the rising edge of T2 are put on the data bus. TW is the wait state to be automatically inserted by the MPU.



## 3.4.4 Counter mode

In the counter mode, the down-counter is decremented synchronizing with the system clock, at the edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the down-counter is decremented one system clock later. When the down-counter has reached zero, a high level pulse is output from the ZC/TO pin.



Figure 3.6 Couner Mode Timing

### 3.4.5 Timer mode

The timer starts operating at the second rising edge of the system clock from the rising edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be apllied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the timer starts one system clock cycle later.



Figure 3.7 Timer Mode Timing

#### 3.4.6 Interrupt acknowledge cycle

Having received the interrupt request signal  $(\overline{INT})$  from the CTC, the MPU drives the CTC's  $\overline{M1}$  pin and  $\overline{IORQ}$  pin low to provide the acknowledge signal. The  $\overline{IORQ}$  pin goes low 2.5 system clocks later than the  $\overline{M1}$  pin. To stabilize the signal lines (IEI and IEO) in daisy chain connection, the interrupt request cannot be changed on each channel while the  $\overline{M1}$  pin is low. The  $\overline{RD}$  pin is held high to make distinction between the instruction fetch cycle and the interrupt acknowledge cycle. While the  $\overline{RD}$  pin is high, the CTC's interrupt control circuit determines the interrupt-requesting channel of highest priority. When the CTC's IEI is high and the  $\overline{M1}$  pin and  $\overline{IORQ}$  pin go low, the interrupt vector is output from the interrupt requesting channel of highest priority. At this time, 2 system clock cycles are automatically inserted by the MPU as a wait state maintain the stabilization of the daisy chain connection.



Figure 3.8 Interrupt Acknowledge Timing

#### 3.4.7 Return from interrupt processing

Return from the interrupt processing is performed when the MPU executes the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When this instruction is executed by the MPU, the CTC's IEI and IEO return to the active state brfore the interrupt has been serviced.

The RETI instruction is a 2-byte instruction. Its code is EDH 4DH. The CTC decodes this instruction to check if there is the next interrupt request channel.

In the daisy chain structure, the interrupting LSI's IEI and IEO are held high and low respectively at the time the instruction code EDH has been decoded.

The code following EDH is 4DH, only the peripheral LSI which has sent the last interrupt vector (that is, the LSI whose IEI is high and IEO is low) returns from the interrupt processing. This restarts the processing of the suspended interrupt of the peripheral LSI of the next higher priority.



Figure 3.9 Interrupt Return Timing

### 3.5 CTC OPERATIONAL PROCEDURE

To operate the CTC in the counter mode or the timer mode, the channel control word and time-constant data must be written in the CTC. To enable interrupt by the channel control word, the interrupt vector must be written in the CTC.

## (1) Channel control word

To write the channel control word in the CTC, the channel must be specified by the corresponding channel codes. Table 3.1 shows the channel codes.

| Channel | Input Terminal |     |  |  |  |  |
|---------|----------------|-----|--|--|--|--|
| Channel | CS1            | CS0 |  |  |  |  |
| 0       | 0              | 0   |  |  |  |  |
| 1       | 0              | 1   |  |  |  |  |
| 2       | 1              | 0   |  |  |  |  |
| 3       | 1              | 1   |  |  |  |  |
| 27028   |                |     |  |  |  |  |

Table 3.1 Channel codes

The channel control word to be written in the CTC consists of 8 bits. The system data bus D0 through D7 correspond to bit 0 through 7 respectively. Figure 3.10 shows the meaning of each bit. Table 3.2 shows the function of each bit.



Figure 3.10 Channel Control Word

For the channel control words, D0 must always be 1.

| D:4           | Meaning and function                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |  |
|---------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| ы             | 0                                                                                                                                                                                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |  |
| Bit 7<br>(D7) | Disable channel interrupt                                                                                                                                                                                                      | Enables channel interrupt. In either counter or<br>timer mode, the interrupt is requested every<br>time the down-counter has reached zero.<br>When this bit is set to "1", the interrupt vector<br>must be written in the CTC before the down-<br>counter starts. When the channel control word<br>whose D7 bit is "1" is written in an already<br>operating channel, the interrupt occurs only<br>when the down-counter has reached zero for<br>the first time after the writing of the new<br>channel control word.                                                                                                                                                             |  |  |  |  |  |
| Bit 6<br>(D6) | Puts the channel in the timer mode. Puts the system clock into the prescaler and outputs the divided signal to the down-counter.                                                                                               | Puts the channel in the counter mode. The down-counter is decremented for each edge trigger applied to the CLK/TRG pin. In the counter mode, the prescaler is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |  |  |
| Bit 5<br>(D5) | Used only in the timer mode. The prescaler is set to divide the system clock by 16.                                                                                                                                            | Used only in the timer mode. The prescaler is set to divide the system clock by 256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |  |
| Bit 4<br>(D4) | In the timer mode, the timer operation starts<br>on the falling edge of the trigger PULSE<br>(CLK/TRG). In the counter mode, the down-<br>counter is decremented on the falling edge of<br>the external clock pulse (CLK/TRG). | In the timer mode, the timer operation sarts on<br>the rising edge of the trigger pulse (CLK/TRG).<br>In the counter mode, the down-counter is<br>decremented on the rising edge of the trigger<br>pulse (CLK/TRG).                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |  |
| Bit 3<br>(D3) | Used only in the timer mode.<br>The timer operation sarts on the rising edge of<br>the trigger pulse clock after a time constant is<br>loaded onto the down-counter.                                                           | Used only in the timer mode. The timer<br>operation is started at the leading edge of the<br>external triger pulse that inputs 2 system clocks<br>after a time constant is loaded onto the down-<br>counter.<br>When a time lag between the system clock and<br>trigger pulse satisfies a setup time, the<br>prescaler starts to operate from the second<br>leading edge of the trigger pulse. If a time lag<br>between the system clock and trigger pulse<br>does not satisfy the setup time, the prescaler<br>starts to operate at the leading edge of the<br>trigger pulse is input before loading of a time<br>constant, the operation is the same as that<br>when Bit 3 = 0. |  |  |  |  |  |

| Table 3.2 | Meanings and    | Function     | of Channel | Control V | Nords (1/2) |
|-----------|-----------------|--------------|------------|-----------|-------------|
|           | in carnings and | i antection. |            |           |             |

| D:+           | Meaning ar                                                                                                                                                                                                                                                                                                                                                                                         | nd function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| DIL           | 0                                                                                                                                                                                                                                                                                                                                                                                                  | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| Bit 2<br>(D2) | This bit (0) indicates that there is no time<br>constant written after channel control word.<br>However, when the channel is in the reset state<br>and this bit cannot be changed to "0" in the<br>channel control word which is given first after<br>the channel reset. To change other state<br>without changing a time constant, input a<br>channel control word with this bit changed to<br>0. | This bit (1) indicates that there is a time<br>constant written immediately after a channel<br>control word. If a time constant is written<br>while the downcounter is operating a new time<br>constant is set in the time constant register.<br>The counting which is in progress is carried out<br>continuously when the downcounter becomes<br>zero and a new time constant is loaded onto<br>the downcouner.                                                                                                                                             |  |  |
| Bit 1<br>(D1) | Continues the current channel operation.                                                                                                                                                                                                                                                                                                                                                           | Stops the down-counter operation.<br>When this bit is set to "1", the channel<br>operation stops but all the channel control<br>register bits remain unchanged. When bit<br>2 = "1" and bit $1 = "1"$ , the channel operation<br>remains stopped until a new time constant is<br>written. The channel is set up after the new<br>time constant is programmed. The channel is<br>restarted according to the state of bit 3. When<br>bit $2 = "0"$ and bit $1 = "1"$ , the channel<br>operation does not start until a new channel<br>control word is written. |  |  |

| Figure 3.2 | Meanings and | Function of | Channel | Control | Words (2/2) |
|------------|--------------|-------------|---------|---------|-------------|
|            |              |             |         |         |             |

100489

### (2) Time-constant data

In either the time mode or the counter mode, the time-constant data must be loaded into the time constant register. When bit 2 (D2) of the channel control word is "1", the time constant is loaded into the time constant register immediately after the channel control word is written. A time constant value must be an integer in a range of 1 to 256. When the 8 bits of a time constant are all "0"s, such a time constant is assumed to be 256. Figure 3.11 shows the bit configuration of time-constant data.

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| TC7 | TC6 | TC5 | TC4 | TC3 | TC2 | TC1 | TC0 |



## TOSHIBA

### (3) Interrupt Vector

In interrupt in the MPU mode-2, the interrupting channel must give an interrupt vector to the MPU. An interrupt vector is written in the channel-0 interrupt vector register with bit 0 (D0) = "0". The vector is written in the same way as the channel control word is written on channel 0. However, bit 0 (D0) of the vector should always be "0". Bit 7 (D7) thrutgh bit 3 (D3) are user-defined values. Bit 2 (D2) and bit 1 (D1) are automatically given and contain the code of the interrupt-requesting channel having the highest priority. Table 3.3 shows the channel codes. Figure 3.12 shows the interrupt vector bit configuration.



| Table 3.3 Channel Codes | hannel Code | C | 3.3 | le 3 | bl | Та |
|-------------------------|-------------|---|-----|------|----|----|
|-------------------------|-------------|---|-----|------|----|----|

Figure 3.12 Interrupt Vector

#### 3.6 USING CTC

(1) Counter mode

The following describes how to use the CTC by referring to a program using channel 0 with interrupt disabled.

(a) The counter programming procedure is shown in Figure 3.13.



100489

Figure 3.13 Counter Programming Procedure

MPUZ80-214

(b) The block diagram for converting the 100kHz system clock into the 10kHz equivalent is shown in Figure 3.14.



Figure 3.14 Down-Counter Block Diagram

(c) The channel control word configuration is shown in Figure 3.15.



Figure 3.15 Channel Control Word Configuration

- (2) Timer mode
  - (a) The timer programming procedure with interrupt disabled is shown in Figure 3.16



Figure 3.16 Timer Programing Procedure

(b) The block diagram for converting the 4MHz system clock into the 1 kHz equivalent is shown in Figure 3.17.

#### CHANNEL 1



Figure 3.17 Timer Block Diagram

(c) The channel control word is shown in Figure 3.18.



Figure 3.18 Channel Control Word

# 4. ELECTRICAL CHARACTERISTICS

## 4.1 ABSOLUTE MAXIMUM RATINGS

| Symbol  | ltem                                   | Rating             | Unit       |    |
|---------|----------------------------------------|--------------------|------------|----|
| Vcc     | Supply Voltage                         | – 0.5 to + 7       | V          |    |
| VIN     | Input Voltage                          | – 0.5 to Vcc + 0.5 | V          |    |
| PD      | Power Dissipation (6MHz VE<br>(8MHz VE | 250                | mW         |    |
| TSOLDER | Soldering Temperature (10 s            | 260                | °C         |    |
| TSTG    | Storage Temperature                    | – 65 to 150        | °C         |    |
| TOPR    | Operating Temperature                  | 6MHz VERSION       | – 40 to 85 | ŝ  |
|         | operating reinperature                 | 8MHz VERSION       | – 10 to 70 | ·ر |

050489

### 4.2 DC ELECTRICAL CHARACTERISTICS

| SYMBOL | PARAMETER                                  | TEST CONDI                               | TION                   | MIN.      | TYP.      | MAX.  | UNIT |
|--------|--------------------------------------------|------------------------------------------|------------------------|-----------|-----------|-------|------|
| VILC   | Low Clock Input<br>Voltage                 |                                          |                        | - 0.3     | _         | 0.6   | v    |
| VIHC   | High Clock Input<br>Voltage                |                                          | Vcc – 0.6              | —         | Vcc + 0.3 | V     |      |
| VIL    | Low input Voltage<br>(Except CLK)          |                                          | - 0.5                  | _         | 0.8       | V     |      |
| VIH    | High input Voltage<br>(Except CLK)         |                                          | 2.2                    | _         | Vcc       | V     |      |
| VOL    | Output Low Voltage                         | IOL = 2.0mA                              |                        | -         |           | 0.4   | V    |
| VOH1   | Output High Voltage ( I )                  | IOH = - 1.6mA                            |                        | 2.4       | -         | -     | V    |
| VOH2   | Output High Voltage (II )                  | IOH = -250μA                             |                        | Vcc – 0.8 |           | -     | V    |
| ILI    | Input Leak Current                         | Vss≦VIN≦Vcc                              | Vss≦ VIN≦ Vcc          |           |           | ± 10  | μA   |
| ILO    | 3-state Output Leakage<br>Current in Float | Vss + 0.4≦ VOUT                          | ≦Vcc                   | -         | _         | ± 10  | μА   |
| IOHD*  | Darlington Drive<br>Current, (2)           | VOH = 1.5V, REX<br>Applied to ZC / TOO   | T = 1.1KΩ<br>~ZC / TO2 | – 1.5     | -         | - 5.0 | mA   |
| lcc1   | Power Suuply Current                       | Vcc = 5V<br>fCLK = (1)                   | AP-6/<br>AM-6/<br>AT-6 | —         | 4         | 7     | mΔ   |
|        |                                            | = Vcc - 0.2V<br>VIL = VILC = 0.2V        | AP-8                   | -         | 5         | 10    |      |
| lcc2   | Standby Supply Current                     | Vcc = 5V, CLK = V<br>0.2, VIL = VILC = 0 | IH = Vcc<br>.2V        | —         | 0.5       | 10    | μA   |

Note: (1)  $f_{CLK} = 1 / TcC$  (MIN.)

(2) Applied to ZC/TO0, ZC/TO1 and ZC/TO2.

## TOSHIBA

## 4.3 AC ELECTRICAL CHARACTERISTICS

(1/2)

| NO. SYMBOL |                 | PARAMETER                                                                                                     | AP-6/AN<br>(6N | AP-6/AM-6 /AT-6<br>(6MHz)           |      | AP-8<br>(6MHz)                      |          |  |
|------------|-----------------|---------------------------------------------------------------------------------------------------------------|----------------|-------------------------------------|------|-------------------------------------|----------|--|
|            |                 |                                                                                                               | MIN.           | MAX.                                | MIN. | MAX.                                |          |  |
| 1          | TcC             | Clock cycle time                                                                                              | 165            | DC                                  | 125  | DC                                  | ns       |  |
| 2          | TwCh            | High clock pulse width                                                                                        | 65             | DC                                  | 50   | DC                                  | ns       |  |
| 3          | TwC1            | low clock pulse width                                                                                         | 65             | DC                                  | 50   | DC                                  | ns       |  |
| 4          | TfC             | Clock falling time                                                                                            |                | 20                                  | _    | 15                                  | ns       |  |
| 5          | TrC             | Clock rising time                                                                                             | -              | 20                                  | -    | 15                                  | ns       |  |
| 6          | Th              | Hold time                                                                                                     | 0              | -                                   | 0    | -                                   | ns       |  |
| 7          | TsCS (C)        | Set-up time for clock rise                                                                                    | 100            | _                                   | 100  | -                                   | ns       |  |
| 8          | TsCE (C)        | CE Set-up time for clock rise                                                                                 | 100            | -                                   | 80   | -                                   | ns       |  |
| 9          | TsIO (C)        | Set-up time up to IORQ fall for clock rise                                                                    | 70             | _                                   | 65   | -                                   | ns       |  |
| 10         | TsRD (C)        | Set-up time up to RD fall for clock rise                                                                      | 70             |                                     | 55   | -                                   | ns       |  |
| 11         | TdC (DO)        | Delay from clock rise to data output                                                                          |                | 130                                 | -    | 110                                 | ns       |  |
| 12         | TdC (DOZ)       | Delay from IORQ, RD rise to data float                                                                        | _              | 90                                  | _    | 85                                  | ns       |  |
| 13         | TsDI (C)        | Data input set-up time for clock rise                                                                         | 40             | ·                                   | 40   |                                     | ns       |  |
| 14         | TsM1 (C)        | M1 set-up time for clock rise                                                                                 | 70             | -                                   | 55   | _                                   | ns       |  |
| 15         | TdM1<br>(IEO)   | Delay from M1 fall to IEO fall<br>(in case of generating only<br>interruption immediately before M1<br>cycle) | _              | 130                                 |      | 110                                 | ns       |  |
| 16         | TdI0<br>(DOI)   | Delay from IORQ fall to data output<br>(INTA cycle)                                                           | _              | 110                                 | _    | 85                                  | ns       |  |
| 17         | TdIEI<br>(IEOf) | Delay from IEI fall to IEO fall                                                                               | _              | 100                                 |      | 75                                  | ns       |  |
| 18         | TdIEI<br>(IEOr) | Delay from IEI rise to IEO rise<br>(after ED decode)                                                          | -              | 110                                 | _    | 80                                  | ns       |  |
| 19         | TdC (INT)       | Delay from clock rise to INT fall                                                                             |                | (1) + 120                           | _    | (1) + 100                           | ns       |  |
| 20         | TdCLK<br>(INT)  | Delay from CLK/TRG rise to INT fall<br>(Counter mode)<br>tsCTR (C) Satisfied<br>tsCTR (C) not Satisfied       |                | (19) + (26)<br>(1) + (19)<br>+ (26) | _    | (19) + (26)<br>(1) + (19)<br>+ (26) | ns<br>ns |  |

|            |                   |                                                                                                            |                |                          |      |                | (2/2)  |  |
|------------|-------------------|------------------------------------------------------------------------------------------------------------|----------------|--------------------------|------|----------------|--------|--|
| NO. SYMBOL | SYMBOL            | PARAMETER                                                                                                  | AP-6/AN<br>(6N | AP-6/AM-6/AT-6<br>(6MHz) |      | AP-8<br>(8MHz) |        |  |
|            |                   |                                                                                                            | MIN.           | MAX.                     | MIN. | MAX.           |        |  |
| 21         | TcCTR             | CLK / TRG Frequency<br>(COUNT MODE)                                                                        | 2⊤cC           | -                        | 2⊤cC | _              | ns     |  |
| 22         | TrCTR             | CLK / TRG rising time                                                                                      | _              | 40                       | -    | 30             | ns     |  |
| 23         | TfCTR             | CLK / TRG falling time                                                                                     | -              | 40                       | _    | 30             | ns     |  |
| 24         | TwCTRI            | Low CLK/TRG pulse width                                                                                    | 120            | -                        | 90   | -              | ns     |  |
| 25         | TwCTRh            | High CLK/TRG pulse width                                                                                   | 120            | -                        | 90   | —              | ns     |  |
| 26         | TsCTR (Cs)        | Set-up time up to CLK/TRG rise for<br>clock rise requiring immediate count<br>(counter mode)               | 150            | _                        | 110  | _              | ns     |  |
| 27         | TsCTR (Ct)        | Set-up time up to CLK/TRG rise for<br>clock rise requiring immediate start<br>of prescaler<br>(timer mode) | 150            | _                        | 110  | _              | ns     |  |
| 28         | TdC<br>(ZC / TOr) | Delay from clock rise to ZC/TO rise                                                                        | _              | 140                      | -    | 110            | ns     |  |
| 29         | TdC<br>(ZC / TOf) | Delay from clock fall to ZC/TO fall                                                                        | _              | 140                      | _    | 110            | ns     |  |
|            |                   |                                                                                                            |                |                          |      | •              | 050489 |  |

Note 1: AC test condition

 $VIH = 2.4V, VIHC = V_{CC}-0.6V, VIL = 0.4V, VOH = 2.2V, VOL = 0.8V CL = 100 pF$ Note 2 : If the daisy chain is at N stage,

 $2.5 TcC > (N-2) \ TdIEI \ (IEOf) + TdM1 \ (IEO) + TsIEI + TTL \ buffer \ delay \ must \ be \ satisfied.$  Note 3 : (1) : Tcc, (19) : Tdc (INT), (26) : TsCTR (Cs)

### 4.4 CAPACITANCE

 $TA = 25^{\circ}C$ 

| SYMBOL | ITEM                    | TEST CONDITION       | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|----------------------|------|------|------|------|
| CCLOCK | Clock Input Capacitance | f = 1MHz             | -    | -    | 5    | рF   |
| CIN    | Input Capacitance       | All terminals except | -    | _    | 6    | рF   |
| COUT   | Output Capacitance      | should be earthed.   | _    | -    | 10   | pF   |

TMPZ84C30A

### 4.5 AC TIMING CHARTS



Figure 4.1 Timing Diagram

MPUZ80-220

## TOSHIBA

# 5. PACKAGE DIMENSION

## 5.1 DIP PACKAGE

DIP28-P-600



270289

Note 1: This dimension is measured at the center of bending points of leads.

Note 2 : Each lead pitch is 2.54mm, and all the leads are located within  $\pm$  0.25mm from their theoretical positions with respect to No.1 and No.28 leads.

Unit : mm

## 5.2 SOP PACKAGE

SOP28-P-450



270289

Note: Package Width and length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

## 5.3 44-PIN PLCC PACKAGE

QFJ44-P-S650





# TMPZ84C40AP-6 / 41AP-6 / 42AP-6 / 43AF-6 / 44AT-6 TMPZ84C40AM-6 / 41AM-6 / 42AM-6 TMPZ84C40AP-8 / 41AP-8 / 42AP-8 TLCS-Z80 SIO: SERIAL INPUT/OUTPUT CONTROLLER

## 1. GENERAL DESCRIPTION AND FEATURES

The TMPZ84C40A (SIO/0), TMPZ84C41A (SIO/1), TMPZ84C42A (SIO/2), TMPZ84C43A, (hereinafter referred to as SIO) are CMOS version of Z80 SIO and have been designed to provide low power operation.

SIOs are designed for the adaptation to the various serial data communications which are needed to the microcomputer system.

SIOs are able to handle the asynchronous signal, the synchronous byte unit protocol and the synchronous bit unit protocol like HDLC and SDLC.

SIOs are fabricated using Toshiba's CMOS Silicon Gate Technology. The principal functions and features of the SIOs are as follows.

- (1) Compatible with the Zilog Z80 SIO.
- (2) Compatible with the CCITT-X.25.
- (3) Compatible with the HDLC/SDLC.
- (4) Data transfer rate up to 800K bit/Sec.
- (5) 2 independent full-duplex channels can be used.
- (6) Built-in CRC generation and checking function.
- (7) On chip daisy-chain structure interrupt circuit.
- (8) Low power consumption

```
4mA Typ. (@5V @6MHz)… TMPZ84C40/41/42AP-6, TMPZ84C40/41/42AM-6,
TMPZ84C43AF-6, TMPZ84C44AT-6
```

- (9) Single power supply:  $5V \pm 10\%$  (6MHz VERSION),  $5V \pm 5\%$  (8MHz VERSION)
- (10) Extended operating temperature: -40°C to 85°C (6MHz VERSION), -10°C to 70°C (8MHz VERSION)
- (11) 40 pin DIP package, 40 pin SOP package, 44 pin Mini Flat package, 44 pin PLCC package.

Note : Z80 is a trademark of Zilog Inc., U.S.A.

# 2. PIN CONNECTIONS AND PIN FUNCTIONS

The pin connections, pin functions and functions of SIOs are described in this chapter.

## 2.1.1 Pin connections (DIP, SOP)

The pin connections of the SIOs are as shown in Figure 2.1, Figure 2.3, and Figure 2.5.

|             |               |                           |                  | · · · · · · · · · · · · · · · · · · · |                           |
|-------------|---------------|---------------------------|------------------|---------------------------------------|---------------------------|
| D1 🛛 1      | $\bigcirc$    | 40 🖞 D0                   | D1               | d1 💛                                  | 40 þ do                   |
| D3 🛛 2      |               | 39 🛛 D2                   | D3               | d 2                                   | 39 🛛 D2                   |
| D5 🖞 3      |               | 38 🛛 D4                   | D5               | dз                                    | 38 🛛 D4                   |
| D7 🖞 4      |               | 37 🛛 D6                   | D7               | d 4                                   | 37 🖞 D6                   |
| INT [5      |               | 36 🛛 IORQ                 | INT              | c 5                                   | 36 🛛 IORQ                 |
| 1EI 🖞 6     |               | 35 🛛 🔁                    | IEI              | d 6                                   | 35 🛛 CE                   |
| IEO 🛛 7     |               | 34 🛛 B/Ā                  | IEO              | <b>d</b> 7                            | 34 🛛 B/Ā                  |
| M1 [8       |               | 33 🛛 C/D                  | M1               | d 8                                   | 33 🖞 C/D                  |
| Vcc [9      |               | 32 🛛 RD                   | Vcc              | ф 9                                   | 32 🛛 RD                   |
| W/RDYA [ 10 |               | 31 🛛 V <sub>SS</sub> (0V) | W/RDYA           | c 10                                  | 31 🖞 V <sub>SS</sub> (0V) |
| SYNCA [11   | C40A          | 30 W/RDYB                 | SYNCA            | d 11 C41A                             | 30 🛛 W/RDYB               |
| RXDA 🛛 12   |               | 29 🛛 SYNCB                | RXDA             | c 12                                  | 29 SYNCB                  |
| RXCA [ 13   |               | 28 🛛 RXDB                 | RXCA             | [ 13                                  | 28 🛛 RXDB                 |
| TXCA 14     |               | 27 D RXTXCB               | TXCA             | d 14                                  | 27 🛛 RXCB                 |
| TXDA 🖞 15   |               | 26 🛛 TXDB                 | TXDA             | c 15                                  | 26 🛛 TXCB                 |
| DTRA [ 16   |               | 25 DTRB                   | DTRA             | 16                                    | 25 🛛 TXDB                 |
| RTSA [ 17   |               | 24 🛛 RTSB                 | RTSA             | c 17                                  | 24 🛛 RTSB                 |
| CTSA 18     |               | 23 🛛 CTSB                 | CTSA             | C 18                                  | 23 🛛 CTSB                 |
| DCDA [ 19   |               | 22 DCDB                   | DCDA             | [ 19                                  | 22 DCDB                   |
| СLК 🛛 20    |               | 21 RESET                  | CLK              | d 20                                  | 21 D RESET                |
| L           | (a) SIO /     | l                         |                  | (h) SIC                               | ]<br>) / 1                |
|             |               |                           |                  |                                       |                           |
| D1 []1      | $\bigcirc$    | 40 🖞 D0                   |                  |                                       |                           |
| D3 🖞 2      |               | 39 🛛 D2                   |                  |                                       |                           |
| D5 🛛 3      |               | 38 🛛 D4                   |                  |                                       |                           |
| D7 🛛 4      |               | 37 🖞 D6                   |                  |                                       |                           |
| INT d 5     |               | 36 🛛 IORQ                 |                  |                                       |                           |
| 1E1 🛛 6     |               | 35 🛛 CE                   |                  |                                       |                           |
| IEO 🛛 7     |               | 34 🛛 B/Ā                  |                  |                                       |                           |
| M1 [8       |               | 33 🛛 C/D                  |                  |                                       |                           |
| Vcc d 9     |               | 32 🛛 RD                   |                  |                                       |                           |
| W/RDYA 010  | C42A          | 31 🛛 V <sub>SS</sub> (0V) |                  |                                       |                           |
| SYNCA [ 11  |               | 30 W/RDYB                 |                  |                                       |                           |
| RXDA 🛛 12   |               | 29 🛛 RXDB                 |                  |                                       |                           |
| RXCA [ 13   |               | 28 🛛 RXCB                 |                  |                                       |                           |
| TXCA [ 14   |               | 27 ] TXCB                 |                  |                                       |                           |
| TXDA 🛛 15   |               | 26 🛛 ТХОВ                 | Figure 2.1 Pin C | Connection                            | s of                      |
| DTRA [ 16   |               | 25 DTRB                   | TMP              | 784C40A/4                             | 1A/42A (Top View)         |
| RTSA [ 17   |               | 24 🛛 RTSB                 |                  | 201010/01                             |                           |
| CTSA [ 18   |               | 23 🛛 CTSB                 |                  |                                       |                           |
| DCDA [ 19   |               | 22 DCDB                   |                  |                                       | 100489                    |
| CLK [ 20    |               | 21 RESET                  |                  |                                       |                           |
| I           | (a) SIO $(a)$ | l                         |                  |                                       |                           |
|             | () 310 / 2    |                           |                  |                                       |                           |
|             |               |                           |                  |                                       |                           |



However, it is necessary to choose the terminals in accordance with the purposes, because they are limited in number. The differences in SIO/0, SIO/1 and SIO/2 are shown in Figure 2.2 (a) SIOs version diagram.





## 2.1.2 Pin connections (Mini Flat package)



Note 1: NC must be used at open condition.

Note 2: \*ICV must be used at open condition or connected with VCC.

Figure 2.3 Pin Connections of TMPZ84C43A (Top View)

## 2.1.3 How to use TMPZ84C43A as SIO/0 or SIO/1 or SIO/2.

The Figure 2.4 shows six terminals to define TMPZ84C43A as SIO/0 or SIO/1 or SIO/2.





## 2.1.4 Pin connections (PLCC)





Figure 2.5 Pin Connections of TMPZ84C44A (Top View)

MPUZ80-227

#### 2.1.5 How to Use TMPZ84C44A as SIO/0 or SIO/1 or SIO/2.

The Figure 2.6 shows six terminals to define TMPZ84C44A as SIO/0 or SIO/1 or SIO/2.



## 2.2 PIN NAMES AND FUNCTIONS

| Table 2.2 | Pin | Names and | Functions | (1/2) |
|-----------|-----|-----------|-----------|-------|

| Pin Name         | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                                                 |  |
|------------------|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| D0~D7            | 8                | I/O<br>3-state          | 8-bit bidirectional data bus.                                                                                                                                                                                                                                                                                                                                            |  |
| ĪNT              | 1                | Output                  | Interrupt request signal.<br>This is used, in case SIOs request MPU the interrupt. Wired OR<br>connection is possible (because of the open drain).                                                                                                                                                                                                                       |  |
| IEI              | 1                | Input                   | Interrupt enable input signal.                                                                                                                                                                                                                                                                                                                                           |  |
| IEO              | 1                | Output                  | Interrupt enable output signal.<br>IEI and IEO are used for the daisy-chain structure. When IEI terminal<br>is "1" and IEO terminal is "0", the SIO is being serviced by a MPU<br>interrupt service routine.                                                                                                                                                             |  |
| M1               | 1                | Input                   | Machine cycle 1.<br>When the both of $\overline{M1}$ and $\overline{IORQ}$ are "0", it is the interrupt acknowledge eycle by a MPU to the SIO's interrupt reguest.                                                                                                                                                                                                       |  |
| W/RDYA<br>W/RDYB | 2                | Output                  | Wait/ready signal A, wait/ready signal B.<br>These can be used as wait signal or ready signal according to SIOs-<br>programming.<br>SIO becomes active on "0", when pins are programmed as "WAIT"<br>and are not ready to receive the data for MPU.<br>SIO become active on "0", when pins are programmed as "READY"<br>and ready to receive the data character for DMA. |  |
| SYNCA<br>*SYNCB  | *2               | · I/O                   | Synchronous signal.<br>In case of the asynchronous receive mode, These pins become the<br>same input terminals as CTS and DCD.<br>In case of the external synchronous mode, pins become the input<br>terminals and in case of the internal synchronous mode, become the<br>output terminals.                                                                             |  |
| RxDA<br>RxDB     | 2                | Input                   | Serial receive data                                                                                                                                                                                                                                                                                                                                                      |  |
| RxCA<br>*RxCB    | *2               | Input                   | Receive clock signal.<br>In asynchronous mode, pins can choose the receive clocks which are<br>1, 16, 32 and 64 times as large as the data transfer rate according to<br>the program.                                                                                                                                                                                    |  |
| TxDA<br>TxDB     | 2                | Output                  | Serial transmit data                                                                                                                                                                                                                                                                                                                                                     |  |
| DTRA<br>*DTRB    | 2                | Output                  | Data terminal ready signal.<br>These pins output the possibility or impossibility of the serial data<br>receive.                                                                                                                                                                                                                                                         |  |
| RTSA<br>RTSB     | 2                | Output                  | Transmit request signal. (Request to send)<br>In serial data transmit, become "0".                                                                                                                                                                                                                                                                                       |  |

| Pin Name     | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                   |
|--------------|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CTSA<br>CTSB | 2                | Output                  | Transmittable signal. (Clear to send)<br>When terminals are "0", SIOs can receive the serial data transmit of<br>the modem which has sent these signals.                                                                   |
| DCDA<br>DCDB | 2                | Input                   | Data carrier detect signal.<br>When terminals are "0", SIOs can enable the serial data transmit.                                                                                                                           |
| CLK          | 1                | Input                   | Signal-phase clock input.<br>Inputs Z80 standard system clock of single-phase. When CLK<br>terminal is DC state ("1" or "0"), SIOs are in stationary state.                                                                |
| IORQ         | 1                | Input                   | I/O request signal In case both of $\overline{IORQ}$ and $\overline{CE}$ are "0", the data or command are transferred between MPU and SIO by the combination of B/A and C/D.                                               |
| CE           | 1                | Input                   | Chip enable signal.<br>When input becomes "0", SIOs are enabled.                                                                                                                                                           |
| B/Ā          | 1                | Input                   | Channel select signal<br>Selects the channel (A/B)                                                                                                                                                                         |
| C/D          | 1                | Input                   | Command/data select signal.<br>Selects the command and data.                                                                                                                                                               |
| RD           | 1                | Input                   | Read signal.<br>In case both of $\overline{CE}$ and $\overline{IORQ}$ are "0", if $\overline{RD}$ is "0", this pin performs<br>the read operation and if $\overline{RD}$ is "1", this pin performs the write<br>operation. |
| RESET        | 1                | Input                   | Reset signal.<br>If RESET is turned into "0", the receiver and transmitter become<br>disabled and the serial data become the mark state.                                                                                   |
| *RxTxCB      | *1               | Input                   | Bonding terminal of $\overline{TxCB}$ and $\overline{RxCB}$ .                                                                                                                                                              |
| Vcc          | 1                | Power Supply            | + 5V                                                                                                                                                                                                                       |
| Vss          | 1                | Power Supply            | 0V                                                                                                                                                                                                                         |

Table 2.2 Pin Names and Functions (2/2)

100489

Note: The asterisk (\*) mark is difference in accordance with the three versions (SIO/0, SIO/1, SIO/2).

# 3. FUNCTIONAL DESCRIPTION

## 3.1 BLOCK DIAGRAM



Figure 3.1 Block Diagram

## 3.2 SYSTEM CONFIGURATION

## 3.2.1 Architecture

As shown in Figure 3.1, the SIO is composed of MPU bus interface, the internal control circuit, the interrupt control circuit and two full-duplex channels which operate independently. Each channel has the read register, the write register and the external control circuit which is connected to the peripheral LSI or the external device.

Table 3.1 shows the registers in the SIO and their functions. Each channel has eight write registers and three read registers. Refer to 3.4 SIO programming for details.

## (1) Communication data path

Figure 3.2 shows the communication path of the transmit/receive data of each channel.

## 1 Receiving

The receiver has an 8-bit receive shift register and a 3-stage 8-bit buffer register in FIFO configuration. This saves time in high-speed data block transfers. The receivers also have the receive error FIFO which holds the status information such as parity and framing errors.

The receive data follow different paths according to the operation mode and character length as shown in Figure 3.2.

## MPUZ80-231

| Register         |       | Function                                                         |
|------------------|-------|------------------------------------------------------------------|
| Write register 0 | (WR0) | Resets CRC. Sets pointers of registers, and commands.            |
| Write register 1 | (WR1) | Sets the interrupt mode.                                         |
| Write register 2 | (WR2) | Sets the vector to be transmitted at interrupt. (Channel B only) |
| Write register 3 | (WR3) | Provides the parameters to control the receiver.                 |
| Write register 4 | (WR4) | Provides the parameters to control the receiver and transmitter. |
| Write register 5 | (WR5) | Controls the transmitter.                                        |
| Write register 6 | (WR6) | Sets the sync character or the SDLC address field.               |
| Write register 7 | (WR7) | Sets the sync character or the SDLC flag.                        |

100489

Table 3.1 (b) Read Registers

| Register        |       | Function                                                       |
|-----------------|-------|----------------------------------------------------------------|
| Read register 0 | (RR0) | Indicates the receive/transmit buffer state and the pin state. |
| Read register 1 | (RR1) | Indicates the error status and the end-of-frame code.          |
| Read register 2 | (RR2) | Indicates the interrupt vector contents. (Channel B only)      |



Figure 3.2 Transfer Data path (Channel A)

• Asynchronous mode

In the asynchronous mode, the receive data enters the 3-bit buffer if the character length is 7 or 8 bits or the 8-bit receive shift register if the character length is 5 or 6 bits.

• Synchronous mode

In the synchronous mode, the data path depends on the receive processing phase at the time.

The receiver operation starts from the hunt phase. In this mode, the receiver searches the receiver data for the bit pattern which matches the specified sync character. If the SIO is set in the monosync mode, the receiver searches for the bit pattern which matches the sync character set in WR7; if the SIO is set in the bisync mode, the receiver searches for the bit pattern which matches two consecutive sync characters set in WR6 and WR7. When synchronization has been established, the subsequent data enter the 3-bit buffer by bypassing the sync register.

SDLC mode

In the SDLC mode, the sync register constantly monitors the receive data performing zero deletion as required. When the sync register detects 5 "1" s consecutively in the receive data, the following bit is deleted if it is "0". If it is "1", the bit that follows is checked. If it is "0", it is assumed as a flag, if it is "1", it is assumed an abort sequence (7 consecutive "1"s).

The reformatted data are put in the receive shift register via the 3-bit buffer. When synchronization has been established, the subsequent data follow the same path regardless of the character length.

2 Transmission

The transmitter has an 8-bit transmit data register and a 20-bit transmit shift register. The 20-bit transmit shift register holds the data from the WR6, WR7, and transmit data register.

Asynchronous mode

In the asynchronous mode, the data in the 20-bit transmit shift register are added with the start and stop bits to be sent to the transmit multiplexer.

• Synchronous mode

In the synchronous mode, the WR6 and WR7 hold the sync character. The contents of these registers are sent to the 20-bit transmit register as the sync character at the transmission of data blocks or as the idle sync character if a transmitter underrun occurs in data block transmission.

• SDLC mode

In the SDLC mode, the WR6 holds the station address and the WR7 holds the flag. The flag (WR7) is sent to the 20-bit transmit register at the start and end of each frame. For each of the other data fields, one "0" follows five consecutive "1"s.

### (2) I/O functions

To transfer data from/to the MPU, the SIO must be set in the polling, interrupt, or block transfer mode.

• Polling

To operate the SIO in the polling mode, all interrupts mode must be disabled. In the polling mode, the MPU reads the status bit D0 and D2 in each channel's RR0 to check for reception or transmission.

• Interrupts

There are 3 types of SIO interrupt: transmit interrupt, receive interrupt, and external/status interrupt. These interrupts can be enabled by program. The receive interrupt is further divided into the following three:

- Interrupt on the first received character
- Interrupt on all received characters
- Interrupt on special receive conditions

Higher priority is given to channel A than channel B. On the same channel, higher priority is given to reception, transmission, and external/status in this order.

The SIO provides the daisy-chained interrupt priority control feature and the interrupt vector generating feature. Further, it provides the "status affected vector" feature. This feature outputs 4 interrupts depending on the interrupt source.

Block transfer

The SIO has the block transfer mode to adapt to the MPU's block transfer and the DMA controller. For block transfer, the  $\overline{W/RDY}$  line is used. For the MPU's block transfer, this line is used as the wait line; for the DMA block transfer, it is used as the ready line. The SIO's ready output indicates to the DMA controller that the data is ready to transfer. The SIO's wait output indicates to the MPU that the SIO is not ready for data transfer and therefore requesting the extension of the output cycle.

### 3.2.2 SIO basic operations

(1) Asynchronous mode

For data transfer in the asynchronous mode, the character length, clock rate, and interrupt mode must be set. These parameters are written in the write registers. Note that WR4 must be set before the other registers are set.

Data transfer does not start until the transmit eneble bit is set. When the auto enable bit is set, the SIO starts transmission upon the  $\overline{\text{CTS}}$  pin's going "0", allowing the programmer to send a message to the SIO without waiting for the  $\overline{\text{CTS}}$  signal. Figure 3.3 shows the data format of the asynchronous mode.



100489

Figure 3.3 Data Format of Asynchronous Mode

## ① Transmission

Serial data are output from the TxD pin. Its transfer clock rate can be set to one of 1, 1/16, 1/32, and 1/64 times the clock rate to be supplied to the transmit clock input ( $\overline{\text{TxC}}$ ). The serial data are output on the falling edge of  $\overline{\text{TxC}}$ .

#### ② Reception

The receive operation in the asynchronous mode starts when the receive enable bit (D0 of WR3) is set. When the receive data input RxD is set to "0" for the duration of at least 1/2 bit time, the SIO interprets it as the start bit, sampling the input data at the middle of the bit time. The sampling is performed on the rising edge of the  $\overline{RxC}$  signal.

When the receiver receives the data whose character length is not 8 bits, it converts the data into the one composed of the necessary bits, the parity bit and the unused bit set to "1".

"

Example : a 6-bit character

## 1 P D5 D4 D3 D2 D1 D0 '

When the external/status interrupt is enabled and a break state is detected in the receive data, the interrupt is generated and the break/abort status bit (D7 of RR0) is set and the SIO monitors the transmit data until the break state is cleared. The interrupt is also generated when the  $\overline{\text{DCD}}$  signal is in the inactive state for more than the specified pulse width. The DCD status bit is set to "1".

In the polling mode, the MPU must refer the receive character valid bit (D0 of RR0) to read the data. This bit is automatically reset when the receive buffer is read. In the polling mode, the transmit buffer status must be checked before writing data in the transmitter to avoid overwwrite.

#### (2) Synchronous mode

There are 3 kinds of character synchronization: monosync, bisync, and external sync. In each of these synchronous modes, the times 1 clock rate is used for both transmission and reception. The receive data is sampled on the rising edge of the receive clock input  $(\overline{RxC})$ .

The transmit data changes on the falling edge of the transmit clock input.

|                          | Synchronous<br>character | Data field |       | CRC<br>1     | CRC<br>2  |
|--------------------------|--------------------------|------------|-------|--------------|-----------|
|                          |                          | ······››   | Mo    | onosynchroi  | nous mode |
| Synchronous<br>character | Synchronous<br>character | Data field |       | CRC<br>1     | CRC<br>2  |
|                          |                          | ))<br>((   |       | Bisynchror   | nous mode |
|                          |                          | Data field |       | CRC<br>1     | CRC<br>2  |
|                          | Message                  | direction  | Exter | nal synchroi | nous mode |

Figure 3.4 Data Format of Synchronous Mode

1 Monosync

In this mode, synchronization is established when a match with the sync character (8 bits) set to WR7 is found, enabling data transfer.

② Bisync

In this mode, synchronization is established when a match with 2 consecutive sync characters set to WR6 and WR7 is found, enabling data transfer. In this mode as well as the monosync mode <u>SYNC</u> is active during the receive clock period in which the sync character is being detected.

③ External sync

In this mode, synchronization is performed externally. When synchronization is established, it is indicated by the  $\overline{SYNC}$  pin. The  $\overline{SYNC}$  input must be kept to "0" until the character synchronization is lost. Character assembly starts from the rising edge of the  $\overline{RxC}$  after the falling of the  $\overline{SYNC}$ .

After reset, the SIO enters the hunt phase to search for the sync character. If synchronization is lost, the SIO sets the enter-hunt-phase-bit (D4 of WR3) to reenter the hunt phase.

• Transmission

a. Data transfer using interrupt

When the transmit interrupt is enabled, the interrupt is caused upon the transmit buffer's being emptied. For the interrupt processing, other data are written in the transmitter. If these data are not ready for some reason, the transmit underrun condition occurs.

#### b. Bisync mode

In the bisync mode, if the transmitter runs out of data during transmission, supply characters are inserted. This is done in two methods. In one method, sync characters are inserted. In the other, characters generated so far are transmitted followed by sync characters. Either of these methods can be selected by the reset transmit underrun/EOM command in WR0.

c. End of transmission

Break can be performed by setting bit D4 of WR5. When break is performed, the data in the transmit buffer and the shift register are lost. When the external/status interrupt is enabled, the SIO generates the interrupt depending on the transmitter state and outputs the vector. This mode can be used for block transfer.

#### Reception

a. Interrupt on the first received character

This mode is used for ordinary block transfer. In this mode, the SIO generates the interrupt only for the first character; subsequently, it does not generate the interrupt unless special receive conditions are satisfied.

To initialize these settings, command 4 of WR0 (to be enabled by the next receive interrupt) must be set in advance.

b. Interrupt on all received characters

In this mode, the SIO generates the interrupt for all characters coming into the receive buffer. When the status affect vector has been set, a special vector is generated on a special receive condition.

c. Special receive condition interrupt

This interrupt occurs when any of the above interrupts is selected. The special receive conditions include parity error, receive overrun error, framing error, and end-of-frame (SDLC). These error status bits are latched, so that they must be reset after they are read.

They can be reset by command 6 of WR6 (error reset).

#### (3) SDLC mode

The SIO supports both the SDLC and HDLC protocols. They resemble each other, so that only the SDLC mode is explained here.

Figure 3.5 shows the data format in the SDLC mode. In the SDLC mode, one data block is called a frame and the message in it is put between the open flag and the close flag. The address field in the frame contains the address of a secondary station. Checking this address, the SIO receives or ignores the frame.



100489



- Transmission
  - a. Data transfer using interrupt

When the transmit interrupt has been set, the interrupt occurs each time the transmit buffer becomes empty. In the SDLC mode, data are sent to the SIO by this interrupt.

b. Data transfer using wait/ready

The wait function in the wait/ready capability is used to make the MPU extend the output cycle when the SIO's transmit buffer is not empty. The ready function indicates to the DMA that the SIO's transmit buffer is empty and therefore ready to receive data. If no data has been written in the transmit shift register before transmission, the SIO goes in the underrun state. This capability permits data transfer to the SIO.

c. Transmit underrun/EOM

The SIO automatically ends the SDLC frame if there is no data to be transmitted to the transmit data buffer. To implement this, the SIO sends a 2byte CRC when there is no data to send, then the SIO transmits one or more flags. After reset, the transmit underrun/ EOM status bit is set to prevent the CRC character from being inserted when there is no data to be sent. Using this function, the SIO starts frame transmission. Here, the transmit underrun/EOM reset command must be set in advance between the transmission of the first data and the data end. Thus, the SIO goes in the reset state at the end of each message with the CRC character being sent automatically.

d. CRC generation

For CRC calculation, the CRC generator must be reset before transmission (bits D6 and D7 of WR0). CRC calculation starts when the address field is written in the SIO (WR6).

The transmit CRC enable bit (D0 of WR5) must be set before the address field is written.
e. End of transmission

When the transmitter is disabled during transmission, the data currently transmitted is all transmitted to its end. The subsequent data is put in the marking state: When the transmitter is disabled, characters remain in the buffer. However, the abort sequence is made active when the abort command is written in the command register, deleting all data.

Reception

As in the transmit mode, several parameters must be preset in the receive mode. The address field is written in WR7 and the flag character in WR7. Receiving the open flag, the receiver compares the contents of the following address field with the address set in WR6 or the global address ("1111 1111"). If the contents of the address field in frame matches either of these address, the SIO starts reception.

#### a. Interrupt on the first received character

This mode is generally used for the block transfer using the wait/ready capability. In this mode, the SIO generates the interrupt only on the first character. The stauts flag of this interrupt is latched, so that command 4 (to be enabled by the next received character) of WR0 must be preset for reinitialization. When the external/status interrupt is set, an interrupt occurs every time the  $\overline{\text{DCD}}$  changes. This interrupt also occurs when the special receive condition is satisfied.

#### b. Interrupt on all received characters

In this mode, the SIO generates an interrupt on all received characters. When the status affect vector has been set, the SIO generates a special vector on the special receive condition interrupt.

c. Special receive condition interrupt

Using the special receive condition, the interrupt on the first received character or the interrupt on all received characters must be selected in advance. The receive overrun status of the special receive condition interrupt is latched. The status bit can be reset by the error reset command (WR0 command).

#### d. CRC check

The receive CRC check is reset when the open flag at the head of a frame is received. CRC calculation is performed on the subsequent characters up to the close flag. In the SDLC mode, the transmit CRC is inverted, so that a special check sequence is used. The check must end with "0001 1101 0000 1111". Since SIO handles the CRC character as a data, the MPU must discard it after reading it.

e. End of transmission

When the SIO receives the close flag, the end-of-frame-bit is set to indicate that the close flag has been received. When the status affect vector has been set, the special receive condition interrupt occurs and the interrupt vector is output. Any frame can be aborted by abort transmission. When the external/status interrupt has been set, the interrupt occurs and the break/abort bit in RR0 is set.

## TOSHIBA

## 3.3 SIO STATUS TRANSITION DIAGRAM AND BASIC TIMING

#### 3.3.1 Status transition diagram

Figure 3.6 shows the SIO status transition diagram.





MPUZ80-242



Figure 3.6 (c) State Transition Diagram



Figure 3.6 (d) SIO Status Transition Diagram



Figure 3.6 (e) State Transition Diagram

#### 3.3.2 Basic timing

Figure 3.7 shows the timing in which data or a command is written from the MPU to the SIO. Figure 3.8 shows the timing in which data is read from the SIO to the MPU. Figure 3.9 shows the interrupt acknowledge timing in which the MPU gives an interrupt response to the SIO's interrupt request to set the  $\overline{IORQ}$  pin to "0" several clocks after setting the  $\overline{MI}$  pin to "0" as the acknowledge signal. To maintain the interrupt serviced state in daisy chain structure, the interrupt request state cannot be changed while  $\overline{MI}$  is active.

Figure 3.10 shows the timing in which the return from interrupt is performed.

Figure 3.11 shows how the daisy chain structure works. First, suppose that the SIO is servicing interrupt. When the PIO issues an interrupt request immediately before the first byte "EDH" of the RETI instruction is decoded with  $\overline{\text{M1}}$  being active, "IEO" of the PIO goes "0". However, when "EDH" is decoded, the PIO's interrupt request is not acknowledged.

Therefore, the PIO's "IEO" returns to "1". When the second byte "4DH" is decoded, the SIO's "IEO" returns to "1". Therefore, the "IEI" and "IEO" of each peripheral LSI at this point of time all go "1", or out of the interrupt serviced state. The PIO keeps the INT pin at "0" until this state is set. Then, the interrupt is serviced starting with the peripheral device of the higher priority.



Figure 3.7 Write Timing





#### TOSHIBA





① The SIO has made an interrupt request.



O The SIO is servicing the interrupt.



③ The PIO has made an interrupt request immediately before "EDH" is decoded by the SIO. By the PIO's interrupt request, PIO's IEO is set to "0".



④ Because "EDH" has been decoded, the PIO's interrupt request is not acknowledged. Therefore, PIO's IEO returns to "1".





(5) Because "4DH" has been decoded, the SIO's IEO is set to "1".



(6) The PIO's interrupt request is acknowledged and the PIO's IEO is set to "0".



100489



#### 3.4 SIO OPERATIONAL PROCEDURE

The following mainly describes the meaning of each bit of the write and read registers. Special attention should be directed to the fact that the parameters of the write register (WR4) should be set before the others.

#### (1) Write registers

WR0; Write register 0

| Table 3.2 | Configuration | of Write Register 0 |
|-----------|---------------|---------------------|
|           |               |                     |

| D7             | D6 | D5                  | D4 | D3                   | D2 | D1 | D0     |
|----------------|----|---------------------|----|----------------------|----|----|--------|
| CRC reset code |    | Primary command bit |    | Register pointer bit |    |    |        |
|                |    |                     | [  | [                    |    |    | 1      |
|                |    |                     |    |                      |    |    | 100489 |

### Bits D0 through D2: Register pointer bits

These bits specify the register on which read/write is performed by the next byte. When read/write is completed, the register pointer points to WR0.

### Bits D3 through D5: Basic command bits

• Command 0 (=000) : No operation

This command only sets the register pointer without making the SIO operate. It is used to invalidate the command in the command chain for the SIO or hold the location at which a command is inserted in the command chain if required.

• Command 1 (=001): Abort sequence generation

This command is used to generate the abort sequence (7 or more consecutive "1"s). Note that command 1 is used only in the SDLC.

• Command 2 (=010): External/status interrupt reset

Once an external interrupt or a status interrupt has occurred, the status bit of RR0 is latched. This command is issued to enable the RR0's status bit in order to enable the interrupt again.

• Command 3 (=011) : Channel reset

This command performs generally the same operation as when the **RESET** pin is set. The difference is that reset is performed only on a single channel. The command for channel A resets the interrupt priority circuit as well.

• Command 4 (=100): Enable the interrupt at the next character reception.

This command is used to enable an interrupt when the end of data block has been detected followed by the reception of the next block.

• Command 5 (=101): Reset transmit interrupt pending

If the transmit buffer becomes empty in the transmit interrupt enable mode, an interrupt occurs. This command is used to disable the transmit interrupt when there is no data in the transmit buffer.

• Command 6 (=110) : Error reset

The error (parity or overrun error) caused in block transfer is latched in bits D4 and D5 of RR1. This commands is used to clear these bits.

• Command 7 (=111): Return from interrupt

This command performs the same operation as the operation required to execute the RETI instruction on the SIO's data bus. Therefore, non-Z80 CPUs (that is, systems using no RETI instruction) can use the daisy chain in the SIO. This command is available only on channel A.

#### Bits D6 and D7: CRC reset code

These 2 bits allow the programmer to select between the receive CRC checker reset, the transmit CRC generator reset, and the transmit underrun/EOM reset.

| Reset command                    | D7    | D6     |
|----------------------------------|-------|--------|
| No operation                     | 0     | 0      |
| Reset the receive CRC checker    | 0     | 1      |
| Reset the transmit CRC generator | 1     | 0      |
| Reset the transmit underrun/EOM  | <br>1 | 1      |
|                                  |       | 100489 |

Table 3.3 List of Reset Command Codes

## WR1; Write register 1

|        |                      |                      | 5                   |                      | 5                           |                                     |                                           |
|--------|----------------------|----------------------|---------------------|----------------------|-----------------------------|-------------------------------------|-------------------------------------------|
| D7     | D6                   | D5                   | D4                  | D3                   | D2                          | D1                                  | D0                                        |
| Enable | Wait/ready<br>Select | Select<br>receiving/ | Rece<br>inter<br>mc | iving<br>rupt<br>ode | Status<br>-affect<br>vector | Enable<br>transmission<br>interrupt | Enble<br>external/<br>status<br>interrupt |
|        | Turrectorr           | transmission         |                     | l                    |                             |                                     | L                                         |

| able 3.4 | Configuration | of Write | Register 1 |
|----------|---------------|----------|------------|
| able 5.4 | configuration | or write | Negister i |

100489

## Bit D0: External/status interrupt enable

When this bit is set, an interrupt is generated at the start of sync character transmission even if the execution is terminated upon detection of break/abort, the  $\overline{\text{DCD}}$ ,  $\overline{\text{CTS}}$  or  $\overline{\text{SYNC}}$  signal has changed, or the transmit underrun/EOM latch is set.

## Bit D1: Transmit interrupt enable

When this bit is set, a transmit interrupt is generated upon the transmit buffer becoming empty.

## Bit D2: Status affect vector

When this bit is set, bits D1 through D3 (V1 through V3) of WR2 is changed. When this bit is not set, the same interrupt vector as the contents of WR2 issued. Note that this bit is available only on channel B.

## Bits D3 and D4: Receive interrupt mode

These bits are used to select a receive interrupt mode.

## Bits D5 through D7: Selection wait/ready functions

These 3 bits are used to select a  $\overline{W/RDY}$  pin function. The wait or the ready function is selected by program and they are not used simultaneously. The meaning of these bits are:

- When D5 is set to "1", it indicates that the W/RDY pin responds to the receive buffer; when D5 is reset to "0", it indicates that the pin responds to the transmit buffer.
- When D6 is set to "1", the W/RDY pin functions as the READY pin; when D6 is reset to "0", the pin functions as the WAIT pin.
- When D7 is set to "1", the wait/ready function is enabled; when D7 is reset to "0", the function is disabled.

For example, when D7, D6, and D5 are "1", "1", and "0" respectively, and the transmit buffer is full, the <u>READY</u> pin goes "1"; when the transmit buffer is empty, the pin goes "0".

# TOSHIBA

Table 3.5 shows the summary of the above description of bits D3 and D4 and D5 through D7.

| Receive interrupt mode                                                                  | D4 | D3     |
|-----------------------------------------------------------------------------------------|----|--------|
| Receive interrupt disable                                                               | 0  | 0      |
| Interrupt on first received character or special receive conditon*                      | 0  | 1      |
| Interrupt on received character or special receive condition*                           | 1  | 0      |
| Interrupt on received character or special receive condition* (except for parity error) | 1  | 1      |
|                                                                                         |    | 100489 |

## Table 3.5 List of Receive Interrupt Mode Codes

\* Special receive conditions: • End of frame (in SDLC mode only)

- Receive overrun error
- Parity error
- Framing error

| Din (Eunction) Din output |                                                                         |            | Buffer state                                                   | D7 | D6 | D5 |
|---------------------------|-------------------------------------------------------------------------|------------|----------------------------------------------------------------|----|----|----|
| Pin (Fur                  | iction)                                                                 | Pin output |                                                                |    |    |    |
| DISABLE                   | WAIT                                                                    | Floating   |                                                                | 0  | 0  |    |
|                           | READY                                                                   | High       | -                                                              | U  | 1  |    |
| ENABLE                    | WAIT                                                                    | Low        | The transmit buffer is full and the SIO data port is selected. |    | 0  |    |
|                           |                                                                         | Floating   | The transmit buffer is empty.                                  |    |    | 0  |
|                           | High The transmit buffer is full.                                       |            |                                                                |    | Ū  |    |
| READY                     |                                                                         | Low        | The transmit buffer is empty.                                  |    |    |    |
|                           |                                                                         | Floating   | The receive buffer is full.                                    | 1  |    |    |
|                           | WAIT Low The receive buffer is empty and the SIO data port is selected. |            | The receive buffer is empty and the SIO data port is selected. |    | 0  | 1  |
|                           | Low The receive buffer is full.                                         |            |                                                                | 1  | '  |    |
|                           | READY                                                                   | High       | The receive buffer is empty.                                   |    | 1  |    |

## Table 3.6 Wait/Ready Select Function (D5 through D7)

WR2: Write register 2

#### Table 3.7 Configuration of Write Register 2 D0 D7 D6 D5 D4 D3 D2 D1 V5 V7 V6 V4 V3 V2 V1 V0 Subject to change under different interrupt conditions if the statusaffect vector bit is set. 100489

This write register is the interrupt vector register. When bit D2 of WR1 is not set, the interrupt vector is issued. When bit D2 of WR1 is set, bits D1 through D3 (V1 through V3) are changed depending on the interrupt generation condition. This time, the contents of WR2 remain unchanged. Because WR2 is available only on channel B, WR2 must be programmed even if only channel A of the SIO is used.

Table 3.8 shows the WR2 bit states in the interrupt condition with the status affect vector being set.

| Channel | Interrupt condition          | V3 | V2 | V1     |
|---------|------------------------------|----|----|--------|
| В       | Transmit buffer empty        | 0  | 0  | 0      |
|         | Change of external/status    | 0  | 0  | 1      |
|         | Received character available | 0  | 1  | 0      |
|         | Special receive condition *  | 0  | 1  | 1      |
|         | Transmit buffer empty        | 1  | 0  | 0      |
|         | Change of external/status    | 1  | 0  | 1      |
| А       | Received character available | 1  | 1  | 0      |
|         | Special receive condition *  | 1  | 1  | 1      |
|         |                              |    |    | 100489 |

Table 3.8 Channel Interrupt Condition Codes

\* Special receive conditions :

• End of frame (in SDLC mode only)

- Receive overrun error
- Parity error
- Framing error

#### WR3; Write resgister 3

| Table 3.9 | Configuration | of Write Register 3 |
|-----------|---------------|---------------------|
|-----------|---------------|---------------------|

|   | D7                | D6               | D5             | D4                     | D3                         | D2                        | D1 :                                         | D0                  |
|---|-------------------|------------------|----------------|------------------------|----------------------------|---------------------------|----------------------------------------------|---------------------|
| 1 | Receivi<br>/chara | ing bit<br>acter | Auto<br>enable | Enter<br>hunt<br>phase | Enable<br>receiving<br>CRC | Address<br>search<br>mode | Prohibit<br>synchronous<br>character<br>load | Enable<br>receiving |
|   |                   |                  |                |                        |                            |                           |                                              | 100489              |

#### Bit D0: Receive enable

When this bit is set, the receive operation starts. Because this bit is used to start the receive operation, it must be set after the receive-associated programming has been all completed.

#### Bit D1: Sync character load inhibit

When this bit is set in the sync mode, the sync character is not loaded into the receive buffer.

This bit is used to remove the sync character and idle sync from the received characters.

#### Bit D2: Address search mode

When this bit is set in the SDLC mode, any message having a programmed address or an address other than the global address (FFH) is not received by WR6. Thefore, the receive interrupt does not occur unless an address match occurs.

#### Bit D3: Receive CRC enable

When this bit is set, CRC calculation starts at the start of the last data transfer from the receive shift register to the receiver buffer.

#### Bit D4: Enter hunt Phase

When the establishment of synchronization is required, set this bit to enter the SIO into the hunt phase. The hunt phase is automatically cleared upon establishment of synchronization.

#### Bit D5: Auto enable

When this bit is set, the transmitter is enabled at the time the  $\overline{\text{CTS}}$  pin is "0". When the  $\overline{\text{DCD}}$  pin is "0", the receiver is enabled.

#### Bits D6 and D7: Receive character length

These bits are used to specify the number of receive bits which make up one character (character length). Table 3.10 shows the number of bits per character.

| Bits/character | D7 | D6     |
|----------------|----|--------|
| 5              | 0  | 0      |
| 7              | 0  | 1      |
| 6              | 1  | 0      |
| 8              | 1  | 1      |
|                |    | 100489 |

Table 3.10 Receive Character Length Codes

WR4; Write register 4

#### Table 3.11 Configuration of Write Register 4

| D7    | D6   | D5       | D4       | D3       | D2 | D1       | D0     |
|-------|------|----------|----------|----------|----|----------|--------|
| Clock | mode | Synchron | ous mode | Stop bit |    | Parity   |        |
| cioci |      | Synemon  |          |          |    | Even/Odd | Enable |
|       |      |          |          |          |    |          | 100489 |

#### Bit D0: Parity enable

When this bit is set, 1-bit transmit data is added to the number of bits specified by D6 and D7 of WR3 and the data is received in the resulting number of bits. If a character length other than 8 bits is selected, the added parity bit is set to the MSB side to be transferred to the receive data FIFO. When the 8-bit character length is selected, the parity bit is not transferred to the receive data FIFO.

#### Bit D1: Parity even/odd

This bit is used to determine whether to perform transfer and check in even or odd parity. (Even parity = "1", odd parity = "0")

#### Bit D2 and D3: Stop bit length

These bits are used to select the stop bit length in the asynchronous mode. In the synchronous mode, both D2 and D3 must be set to "0".

| Stop bit                | D3 | D2     |
|-------------------------|----|--------|
| Sync mode               | 0  | 0      |
| 1 stop bit/character    | 0  | 1      |
| 1.5 stop bits/character | 1  | 0      |
| 2 stop bits/character   | 1  | 1      |
| · · · · ·               |    | 100489 |

Table 3.12 Stop Bit Length Codes

## Bits D4 and D5: Sync mode

These bits are used to select the sync mode.

| Sync mode                       | D5 | D4     |  |  |  |  |
|---------------------------------|----|--------|--|--|--|--|
| 8-bit sync mode                 | 0  | 0      |  |  |  |  |
| 16-bit sync mode (bisync mode)  | 0  | 1      |  |  |  |  |
| SDLC mode (flag character; 7EH) | 1  | 0      |  |  |  |  |
| External sync mode              | 1  | 1      |  |  |  |  |
|                                 |    | 100489 |  |  |  |  |

Table 3 13 Sync Mode Codes

#### Bits D6 and D7: Clock mode

These bits are used to select the factor between the transmit/receive clock and the data transfer rate. In the synchronous mode, the  $\times 1$  clock mode must be set. In the asynchronous mode, the transmit side and the receive side must have the same factor.

| · · · · · · · · · · · · · · · · · · · |    |        |
|---------------------------------------|----|--------|
| Clock mode (data transfer rate)       | D7 | D6     |
| × 1 data transfer rate                | 0  | 0      |
| × 16 data transfer rate               | 0  | 1      |
| × 32 data transfer rate               | 1  | 0      |
| × 64 data transfer rate               | 1  | 1      |
|                                       |    | 100489 |

Table 3.14 Clock Mode Codes

#### WR5; Write register 5

Table 3.15 Configuration of Write Register 5

| D7  | D6             | D5                | D4                    | D3                     | D2              | D1  | D0                         |
|-----|----------------|-------------------|-----------------------|------------------------|-----------------|-----|----------------------------|
| DTR | Trans<br>/chai | mit bit<br>racter | Break<br>transmission | Enable<br>transmission | CRC-16<br>/SDLC | RTS | Enable CRC<br>transmission |

100489

#### Bit D0: Transmit CRC enable

When this bit is set at the time the transmit data is loaded from the transmit data buffer into the transmit shift register, the CRC calculation is performed on that data. If this bit is not set, the CRC calculation and transmission are not performed in the transmit underrun state in the synchronous or SDLC mode.

### Bit D1: Request to send (RTS)

When this bit is set, the  $\overline{\text{RTS}}$  pin goes "0". When this bit is not set, the  $\overline{\text{RTS}}$  pin goes "1". In the asynchronous mode, the  $\overline{\text{RTS}}$  pin goes "1" when the transmit buffer becomes empty. In the synchronous or SDLC mode, this bit state is followed by the  $\overline{\text{RTS}}$  pin state.

#### Bit D2: CRC-16/SDLC

When this bit is set, the CRC-16 polynomial  $(X^{16} + X^{15} + X^2 + 1)$  is selected. When this bit is reset to "0", the CRC-CCITT polynomial  $(X^{16} + X^{12} + X^5 + 1)$  is selected.

#### Bit D3: Transmit enable

When this bit is set, the transmitter is enabled. Even if this bit is reset to "0" after the start of transmission, the sync character and the data being transmitted are transmitted to the last.

#### Bit D4: Transmit break

When this bit is set, transmitting any data forcibly puts the transmit data line (TxD pin) in the space state. When this bit is reset to "0", the TxD pin is put in the marking state.

#### Bits D5 and D6: Transmit character length

These bits indicate the character length of transmit data.

| Bits/character   | D6 | D5     |
|------------------|----|--------|
| Less than 5 bits | 0  | 0      |
| 7 bits           | 0  | 1      |
| 6 bits           | 1  | 0      |
| 8 bits           | 1  | 1      |
|                  |    | 100400 |

Table 3.16 Transmit Character Length Codes

As shown in Table3.16, for the transmission of less than 5 bits (4 bits or 3 bits) per character, D6 and D5 are "0" and "0", which do not indicate how many bits the transmit data consists of. To solve this problem, the data characters must be processed by the format shown in Table 3.17. Note that D indicates data.

| Transmit bits/character | D7 | D6 | D5 | D4 | D3 | D2 | D1 _ | D0     |
|-------------------------|----|----|----|----|----|----|------|--------|
| 1                       | 1  | 1  | 1  | 1  | 0  | 0  | 0    | D      |
| 2                       | 1  | 1  | 1  | 0  | 0  | 0  | D    | D      |
| 3                       | 1  | 1  | 0  | 0  | 0  | D  | D    | D      |
| 4                       | 1  | 0  | 0  | 0  | D  | D  | D    | D      |
| 5                       | 0  | 0  | 0  | D  | D  | D  | D    | D      |
|                         |    |    |    |    |    |    |      | 100489 |

| Table 3.17 Data Tr | ransfer Format with | Transmit Data | Consisting of | <sup>-</sup> Less than 5 bits |
|--------------------|---------------------|---------------|---------------|-------------------------------|
|--------------------|---------------------|---------------|---------------|-------------------------------|

#### Bit D7: data terminal ready

This bit indicates the  $\overline{\text{DTR}}$  pin state. When this bit is set, the  $\overline{\text{DTR}}$  pin goes "0", when it is reset, the  $\overline{\text{DTR}}$  pin goes "1".

WR6; Write register 6

|      | • • |    | coningarat |      | te negistei | •  |        |  |
|------|-----|----|------------|------|-------------|----|--------|--|
| D7   | D6  | D5 | D4         | D3 - | D2          | D1 | D0     |  |
| SYNC |     |    |            |      |             |    |        |  |
| _    |     |    |            | -    |             |    |        |  |
| 7    | 6   | 5  | 4          | 3    | 2           | 1  | 0      |  |
| L    | L   | L  |            |      | L           |    | 100499 |  |

Table 3.18Configuration of Write Register 6

This register is programmed as follows:

• In the external sync mode : Transmit sync character

- In the monosync mode : Transmit sync character
  - In the bisync mode : First sync character
- In the SDLC mode : Slave station address

WR7; Write register 7

|           |           |           | 5         |           | 5         |          |          |  |  |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|--|--|
| D7        | D6        | D5        | D4        | D3        | D2        | D1       | D0       |  |  |
| SYNC      |           |           |           |           |           |          |          |  |  |
| 15<br>(7) | 14<br>(6) | 13<br>(5) | 12<br>(4) | 11<br>(3) | 10<br>(2) | 9<br>(1) | 8<br>(0) |  |  |

## Table 3.19 Configuration of Write Register 7

This register is programmed as follows:

- In the monosync mode : Receive sync character
- In the bisync mode : Second sync character
- In the SDLC mode : Flag character (7EH)

This register is not used in the external sync mode.

(2) Read registers

RR0; Read register 0

## Table 3.20 Configuration of Read Register 0

| D7              | D6                               | D5  | D4                    | D3  | D2                           | D1                   | D0                                  |
|-----------------|----------------------------------|-----|-----------------------|-----|------------------------------|----------------------|-------------------------------------|
| Break/<br>Abort | Transmission<br>underrun<br>/EOM | CTS | Synchro-<br>nize/Hunt | DCD | Transmission<br>buffer empty | Reserve<br>interrupt | Receiving<br>character<br>effective |
|                 | L                                |     |                       |     |                              |                      |                                     |

Used with the external/status interrupt

100489

#### Bit D0: Receive character available

This bit is set when the receive buffer holds characters of 1 byte or more. This bit is reset when the buffer becomes empty.

### Bit D1: Interrupt pending

This bit is set when an interrupt occurs in the SIO regardless of the interrupt condition type.

This bit is available only on channel A.

### Bit D2: Transmit buffer empty

This bit is set when the transmit data buffer becomes empty or the SIO is reset. However, in the sync and SDLC modes where the CRC character is being transmitted, bit D2 is reset.

### Bit D3: Data carrier detect

This bit indicates the  $\overline{\text{DCD}}$  pin input state. This bit is latched when the external/status interrupt occurs.

#### Bit D4: Sync/hunt

The meaning of this bit depends on the operation mode:

### TOSHIBA

#### (i) Asynchronous mode

Bid D4 indicates the SIO's  $\overline{\text{SYNC}}$  pin state. When the  $\overline{\text{SYNC}}$  pin state changes, the external/status interrupt occurs.

(ii) External sync mode

When synchronization has been established by the detection of external synchronization, the last bit of the sync character must be set to "0" at the second  $\overline{\text{RxC}}$  falling edge from the rising edge of the received  $\overline{\text{RxC}}$ . That is, to set the  $\overline{\text{SYNC}}$  input to "0" by the external circuit after the detection of synchronization, full 2 receive cycle clocks must be awaited.

When the  $\overline{\text{SYNC}}$  input goes "0", the sync hunt bit is set. When synchronization is lost or the end of message is detected, the enter hunt phase bit is set.

#### (iii) Internal sync mode

In the monosync and bisync modes, bit D4 is initialized to "1" by the enter hunt phase command (D4 of WR3). This bit is reset when the SIO detects the sync character.

(iv) SDLC mode

Bit D4 is set when the receiver is disabled or the enter hunt phase command is issued.

Then, when the frame open flag is detected, this bit is reset.

#### Bit D5: Clear to send (CTS)

This bit indicates the opposite of the  $\overline{\text{CTS}}$  pin input state.

#### Bit D6: Transmit underrun/EOM

#### Bit D7: Break/abort

In the asynchronous mode in reception, this bit indicates the break state detection. When the break state is detected, this bit is set, generating the external/status interrupt. This bit is reset by the external/status interrupt reset command.

After break, the external/status interrupt is generated again. In the SDLC mode, bit D7 is set when the abort sequence is detected, generating the external/status interrupt.

## RR1; Reader register 1

| Table 5.21 Configuration of Read Register 1 |                  |                               |                 |    |          |    |                        |  |
|---------------------------------------------|------------------|-------------------------------|-----------------|----|----------|----|------------------------|--|
| D7                                          | D6               | D5                            | D4              | D3 | D2       | D1 | D0                     |  |
| End of<br>frame                             | framing<br>error | Receiving<br>overrun<br>error | Parity<br>error |    | Fraction |    | Feed all<br>characters |  |
|                                             |                  |                               |                 |    |          |    | 100489                 |  |

## Table 3.21 Configuration of Read Register1

## Bit D0: All sent

In the asynchronous mdoe, this bit is set when all characters are sent from the transmitter or there is no transmit data in the SIO. In the synchronous mode, this bit is always set.

## Bits D1 through D3: Fraction codes

Normally, I field is an integral multiple of character length. If it is not, these bits show the number of fraction bits. These codes are effective only for the transmission for which the end of frame bit is set in the SDLC mode.

Example: Figure 3.12 shows examples of fractions in which the number of bits/ character at the end of I field is 8 bits (1) and 4bits (2).



Figure 3.12 Examples of Fraction Bits in I Field

Table 3.22 (a) shows the fraction codes for the receive character whose character length is 8 bits.

| Number of fraction | bits at end of I field | 50     | 50 | D1 |
|--------------------|------------------------|--------|----|----|
| 1 byte before      | 2 bytes before         | 23     |    |    |
| 0                  | 3                      | 1      | 0  | 0  |
| 0                  | 4                      | 0      | 1  | 0  |
| 0                  | 5                      | 1      | 1  | 0  |
| . 0                | 6                      | 0      | 0  | 1  |
| 0                  | 7                      | 1      | 0  | 1  |
| 0                  | 8                      | 0      | 1  | 1  |
| 1                  | 8                      | 1      | 1  | 1  |
| 2                  | 8                      | 0      | 0  | 0  |
|                    |                        | 100489 |    |    |

Table 3.22 (a) Bit Patterns by Fraction Bits at End of I Field

The same table can also be provided for each character length when the receive character length of I field is other than 8 bits.

Table 3.22 (b) Bit Patterns by Number of Bits/Character (No Fractions)

| Bits/character   | D3 | D2 | D1     |
|------------------|----|----|--------|
| 5 bits/Character | 0  | 0  | 1      |
| 6 bits/Character | 0  | 1  | 0      |
| 7 bits/Character | 0  | 0  | 0      |
| 8 bits/Character | 0  | 1  | 1      |
|                  |    |    | 100489 |

#### Bit D4: Parity error

This bit is latched when the parity select bit (D0 of WR4) is set and a parity error is detected in the receive data. Latch can be cleared by the error reset command (WR0 bits D5, D4, D3 = "1", "1", "0").

#### Bit D5: Receive overrun error

The receive data FIFO holds up to 3 characters. When more characters are received without read out by the MPU, the excess character is set to the receive FIFO. When this character is read by the MPU, this receive overrun error is set. Once set, bit D5 latches that state. When the error reset command (command 6 of WR0 bits D3 through D5) is written, this bit is also reset.

#### Bit D6: CRC/framing error

In the asynchronous mode, this bit is set when a framing error is detected in the received character. Because this bit is not latched, it is always updated.

In the synchronous and SDLC modes, this bit indicates the transmitted CRC check result. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written.

#### Bit 7: End of frame

This bit is set when the end flag is detected in the receive data. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written. This bit is used only in the SDLC mode and is updated when the first character of the next frame is received.

#### RR2; Read register 2



Table 3.23 Configuration of Read Register 2

When the status affect vector bit (D2 of WR1) is set, bits V3 through V1 are changed depending on the interrupt condition at the time. The vector to be read is determined by the interrupt condition having the highest priority at the time of read. When the status affect vector bit is reset, the contents of this register are the same as those of WR2.

#### 3.5.6 Using SIO

The following describes some system examples using the SIO. Figure 3.13 shows an inter-processor communication system. In this example, the MPU on the left side controls the data transfer with the modules on the right side. Both diagrams shown in Figure 3.13 (a) and (b) are communication systems. As shown, the SIO is used to interface with external devices in data communication. The greatest advantage of the SIO is the smaller number of data lines than parallel communication.



Figure 3.13 (a) Example of Data Communication between Processors



Figure 3.13 (b) Example of Data Communication between Processors

## 4. ELECTRICAL CHARACTERISTICS

## 4.1 ABSOLUTE MAXIMUM RATINGS

| Symbol          | ltem                                | Rating             | Unit       |    |
|-----------------|-------------------------------------|--------------------|------------|----|
| V <sub>CC</sub> | Supply Voltage                      | 0.5 to +7.0        | V          |    |
| V <sub>IN</sub> | Input Voltage                       | – 0.5 to VCC + 0.5 | V          |    |
| PD              | Power Dissipation(6MHz V<br>(8MHz V | 250                | mW         |    |
| TSOLDER         | Soldering Temperature (10 s         | 260                | °C         |    |
| TSTG            | Storage Temperature                 | – 65 to 150        | °C         |    |
| TOPR            | Operating Temperature               | 6MHz VERSION       | – 40 to 85 | ٥٢ |
|                 | Operating remperature               | 8MHz VERSION       | – 10 to 70 | L  |

050489

## 4.2 DC ELECTRICAL CHARACTERISTICS

| SYMBOL  | ITEM                                                | TEST CONDITION                                           |     | MIN.      | TYP. | MAX.      | UNIT |
|---------|-----------------------------------------------------|----------------------------------------------------------|-----|-----------|------|-----------|------|
| VILC    | Low Clock Input Voltage                             |                                                          |     | - 0.3     | -    | 0.6       | V    |
| VIHC    | High Clock Input Voltage                            |                                                          |     | Vcc – 0.6 | -    | VCC + 0.3 | V    |
| VIL     | Input Low Voltage                                   |                                                          |     | - 0.5     | -    | 0.8       | V    |
|         | (Except CLK)                                        |                                                          |     |           |      |           |      |
| VIH     | Input High Voltage                                  |                                                          |     | 2.2       | -    | VCC       | v    |
|         | (Except CLK)                                        |                                                          |     |           |      |           |      |
| VOL     | Output Low Voltage                                  | IOL = 2.0mA                                              |     | _         | -    | 0.4       | V    |
| VOH1    | Output High Voltage (I)                             | IOH = - 1.6mA                                            | 2.4 | -         | _    | V         |      |
| VOH2    | Output High Voltage (II)                            | IOH = - 250µA                                            |     | Vcc – 0.8 | -    |           |      |
| ILI     | Input Leakage Current                               | $VSS \leq VIN \leq VCC$                                  |     | -         | -    | ± 10      | μA   |
| ILO     | Output Leakage Current                              | $VSS + 0.4 \leq VOUT \leq VCC$                           |     | -         | -    | ± 10      | μA   |
| IL (SY) | SYNC Pin Leakage Current                            | $VSS + 0.4 \leq VIN \leq VCC$                            |     | - 40      | -    | 10        | μA   |
| ICC1    | Power Supply Current VCC = 5V<br>fCLOK = (1)        |                                                          | (2) | -         | 4    | 10        | mA   |
|         |                                                     | VIHC = VIH $= VCC - 0.2V$ $VILC = VIL = 0.2V$            | (3) | _         | 5    | 12        |      |
| ICC2    | Standby Supply Current<br>Except SYNC at "L" output | VCC = 5V<br>VIH = VIHC = VCC - 0.2V<br>VIL = VILC = 0.2V |     | -         | _    | 10        | μА   |

Note: (1) fCLK = 1/TcC (MIN.), (2) AP-6/AM-6/AF-6/AT-6, (3) AP-8

## TOSHIBA

## 4.3 AC ELECTRICAL CHARACTERISTICS (1/2)

(1/2)

|     | SYMBOL PARAN  |                                                                                                                                                       | (1) (6MHZ)                                                       |      | (2) (8MHZ) |      |      |
|-----|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|------|------------|------|------|
| NO. |               | PARAMETER                                                                                                                                             | MIN.                                                             | MAX. | MIN.       | MAX. | UNIT |
| 1   | TcC           | Clock cycle time                                                                                                                                      | 165                                                              | DC   | 125        | DC   | ns   |
| 2   | TwCH          | Clock pulse width (High)                                                                                                                              | 70                                                               | DC   | 50         | DC   | ns   |
| 3   | TfC           | Clock fall time                                                                                                                                       | -                                                                | 15   |            | 15   | ns   |
| 4   | TrC           | Clock rise time                                                                                                                                       |                                                                  | 15   | -          | 15   | ns   |
| 5   | TwCl          | Clock pulse width (Low)                                                                                                                               | 70                                                               | DC   | 50         | DC   | ns   |
| 6   | TsCS (C)      | Control signal to clock setup time $(\overline{CE}, C/\overline{D}, B/\overline{A})$                                                                  | 60                                                               | _    | 60         |      | ns   |
| 7   | TsRD (C)      | $\overline{IORQ} \downarrow$ , $\overline{RD} \downarrow$ to clock $\uparrow$ setup60-55-time60-55-                                                   |                                                                  | ns   |            |      |      |
| 8   | TdC (DO)      | Clock↑ to data out delay                                                                                                                              | —                                                                | 150  |            | 100  | ns   |
| 9   | TsDI (C)      | Data in to clock↑ setup<br>(Write or M1 cycle)                                                                                                        | 30                                                               | _    | 30         | -    | ns   |
| 10  | TdRD (DOz)    | $\overline{RD} \uparrow$ to data out float delay                                                                                                      | $\overline{\text{RD}}$ $\uparrow$ to data out float delay - 90 - |      | -          | 70   | ns   |
| 11  | TdIO (DOI)    | IORQ↓ to data out delay<br>(INTACK cycle)                                                                                                             | -                                                                | 120  | _          | 85   | ns   |
| 12  | TsM1 (C)      | M1 to clock↑ setup time                                                                                                                               | 75                                                               | -    | 50         | _    | ns   |
| 13  | TsIEI (IO)    | IEI↓ to IORQ↓ setup time<br>(INTACK cycle)                                                                                                            | 120                                                              | _    | 80         |      | ns   |
| 14  | TdM1 (IEO)    | $\overline{M1} \downarrow$ to IEO $\downarrow$ delay<br>(interrupt before $\overline{M1}$ )                                                           | -                                                                | 160  | _          | 120  | ns   |
| 15  | TdIEI (IEOr)  | IEI↑ to IEO↑ delay<br>(after ED decode)                                                                                                               | _                                                                | 110  |            | 110  | ns   |
| 16  | TdIEI (IEOf)  | IEI↓ to IEO↓ delay                                                                                                                                    | -                                                                | 70   | -          | 70   | ns   |
| 17  | TdC (INT)     | Clock↑ to INT↓ delay                                                                                                                                  | _                                                                | 150  |            | 100  | ns   |
| 18  | TdIO (W/RWf)  | $\overline{\text{IORQ}} \downarrow \text{or } \overline{\text{CE}} \downarrow \text{to } \overline{\text{W/RDY}} \downarrow \text{delay}$ (Wait mode) | _                                                                | 175  |            | 130  | ns   |
| 19  | TdC (W / RRf) | Clock ↑ to W/RDY↓ delay — 100 — 80<br>(Ready mode)                                                                                                    |                                                                  | 80   | ns         |      |      |
| 20  | TdC (W / RWZ) | Clock $\downarrow$ to $\overline{W/RDY}$ float delay<br>(Wait mode)                                                                                   | _                                                                | 110  | _          | 90   | ns   |
| 21  | Th, Th (CS)   | Any unspecified hold when setup is specified                                                                                                          | 0                                                                | _    | 0          | _    | ns   |
| 22  | TwPh          | Pulse width (High)                                                                                                                                    | 200                                                              | -    | 200        | -    | ns   |

## AC ELECTRICAL CHARACTERISTICS (2/2)

|            | SYMPOL        |                                                                                  | (1) (6MHZ) |                                         | (2) (8MHZ) |                                         |                 |
|------------|---------------|----------------------------------------------------------------------------------|------------|-----------------------------------------|------------|-----------------------------------------|-----------------|
| NO. STWBOL |               | PARAMETER                                                                        | MIN.       | MAX.                                    | MIN.       | MAX.                                    | UNIT            |
| 23         | TwPI          | Pulse width (Low)                                                                |            | -                                       | 200        | -                                       | ns              |
| 24         | TcTxC         | TxC cycle time                                                                   | 330        | œ                                       | 250        | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ns              |
| 25         | TwTxCl        | TxC width (Low)                                                                  | 100        | œ                                       | 80         | ∞                                       | ns              |
| 26         | TwTxCh        | TxC width (High)                                                                 | 100        | ∞                                       | 80         | ∞                                       | ns              |
| 27         | TdTxC (TxD)   | TxC↓ to TxD delay (x1 mode)                                                      |            | 220                                     | -          | 180                                     | ns              |
| 28         | TdTxC (W/RRf) | $\overline{TxC} \downarrow to \overline{W/RDY} \downarrow delay$<br>(Ready mode) | 5          | 9                                       | 5          | 9                                       | CLK<br>Periods* |
| 29         | TdTxC (INT)   | TxC↓ to INT↓ delay                                                               | 5          | 9                                       | 5          | 9                                       | CLK<br>Periods* |
| 30         | TcRxC         | RxC cycle time                                                                   | 330        | œ                                       | 250        | ∞                                       | ns              |
| 31         | TwRxCl        | RxC width (Low)                                                                  | 100        | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | 80         | ∞                                       | ns              |
| 32         | TwRxCh        | RxC width (High)                                                                 | 100        | œ                                       | 80         | ∞                                       | ns              |
| 33         | TsRxD (RxC)   | RxD to RxC ↑ setup time<br>(x1 mode)                                             | 0          | _                                       | 0          | _                                       | ns              |
| 34         | ThRxD (RxC)   | $\overline{RxC} \uparrow$ to RxD hold time (x1 mode)                             | 100        | -                                       | 80         | -                                       | ns              |
| 35         | TdRxC (W/RRf) | RxC↑ to W/RDY↓ delay<br>(Ready mode)                                             | 10         | 13                                      | 10         | 13                                      | CLK<br>Periods* |
| 36         | TdRxC (INT)   | RxC↑ to INT↓ delay                                                               | 10         | 13                                      | 10         | 13                                      | CLK<br>Periods* |
| 37         | TdRxC (SYNC)  | RxC↑ to SYNC↓ delay<br>(Output modes)                                            |            | 7                                       | 4          | 7                                       | CLK<br>Periods* |
| 38         | TsSYNC (RxC)  | SYNC↓ to RxC↑ setup<br>(External sync modes)                                     | - 100      | _                                       | - 100      | -                                       | ns              |

Note: (1) AP-6/AM-6/AF-6/AT-6, (2) AP-8

AC test condition VIH=2.4V, VIHC=VCC-0.6V, VIL=0.4V, VILC=0.6V VOH=2.2V, VOL=0.8V CL=100pF

\* System Clock In all modes, the System Clock rate must be at least five times the maximum data rate.

#### 4.4 CAPACITANCE

 $\mathrm{TA}\,{=}\,25^{\circ}\mathrm{C}$ 

| SYMBOL | ITEM                    | TEST CONDITION                  | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|---------------------------------|------|------|------|------|
| CCLOCK | Clock Input Capacitance | f = 1MHz                        | -    | -    | 7    | рF   |
| CIN    | Input Capacitance       | All terminals except that to be |      | 1    | 5    | рF   |
| COUT   | Output Capacitance      | measured should be earthed.     | —    | —    | 10   | рF   |

050489

050489

#### MPUZ80-267

#### 4.5 TIMING DIAGRAM

Numbers shown in the following figures correspond with those in the 4.3 A.C. Electrical Characteristics Table.







Figure 4.1 (b) Timing Diagram

## 5. PACKAGE DESCRIPTION

5.1 40-PIN DIP

DIP40-P-600

Unit : mm



270289

Note 1 : This dimension is measured at the center of bending point of leads.

Note 2: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.40 leads.

## 5.2 44-PIN MINI-FLAT PACKAGE

## QFP44-P-1414F



Note: Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

## MPUZ80-271

5.3 SOP PACKAGE

SSOP40-P-450

Unit : mm



270289

Note : Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

## 5.4 44-PIN PLCC PACKAGE

QFJ44-P-S650



# 6. PRECAUTIONS

In the programming using the SIO, it can be used only for single channel according to registers and bits.

## TMPZ84C61AP-6

## TLCS-Z80 CGC : Z80 CLOCK GENERATOR/CONTROLLER

## 1. GENERAL DESCRIPTION AND FEATURES

The TMPZ84C61A is a clock generator/controller (CGC) for the TLCS-Z80 Family (Microprocessor (MPU) and its peripheral LSIs) fabricated with Toshiba's CMOS Silicon Gate Technology. The TMPZ84C61A is provided with two input terminals which are capable of selecting one of the following 3 modes when the TLCS-Z80 MPU executes the HALT instruction.

#### (1) RUN Mode

The clock (CLK) output operation of the TMPZ84C61A is continued. The TLCS-Z80 MPU is in the HALT state at this time and continues to execute the NOP instruction.

(2) IDLE Mode

The clock (CLK) output by the TMPZ84C61A is stopped. However, only the internal oscillator continues to run.

(3) STOP Mode

The operation of the TMZ84C61A is completely stopped.

In the STOP mode, the operation of the microcomputer system is completely stopped. Therefore, it becomes possible to keep the system at low power consumption.

When "0" is inputted to the  $\overline{\text{DIV}}$  terminal, the signal obtained by dividing input frequency from the external oscillator is transmitted from the CLK terminal, and when "1" is inputted, the signal of the same frequency, as that of the external oscillator is transmitted from the CLK terminal.

The TMPZ84C61A is enclosed in 16 pin standard DIP.

The principal functions and features of the TMPZ84C61A are as follows.

- (1) Upper compatible with TMPZ84C60P
- (2) Low power consumption

 3mA Typ.
 (@5V, 6MHz operation)

 500μA Typ.
 (@5V 6MHz)
 (IDLE Mode)

 10μA MAX.
 (@5V stationary)
 (STOP Mode)

- (3) Single 5V power supply  $(5V \pm 10\%)$
- (4) Extended operating temperature  $(-40^{\circ}C \text{ to } 85^{\circ}C)$

- (5) The following 3 modes are selectable :
  - RUN Mode
  - IDLE Mode
  - STOP Mode
- (6) Clock output frequency division
- (7) With the RESOUT terminal signal, stable reset pulse can be provided to the MPU and its peripheral LSIs.

Compatibility with TMPZ84C60

TMPZ84C61A is used in the same mode as TMPZ84C60 under the following conditions.

- (1) Leave the  $\overline{\text{RESOUT}}$  terminal open, and connect the  $\overline{\text{RESET}}$  terminal of the MPU with that of TMPZ84C61A.
- (2) Input "1" to the  $\overline{\text{DIV}}$  terminal.
100489

# 2. PIN CONNECTIONS AND PIN FUNCTIONS

The pin connections and I/O pin names and brief functions of the TMPZ84C61A are shown below.

#### 2.1 PIN CONNECTIONS

The pin connections of the TMPZ84C61A are as shown in Figure 2.1.





# 2.2 PIN NAMES AND FUNCTIONS

I/O pin names and functions of the TMPZ84C61A are as shown in Table 2.1.

| Pin Name                                                     | Number<br>of Pin | Input/Out<br>put 3-state | Function                                                                                                                                     |
|--------------------------------------------------------------|------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| RSTI1                                                        | 1                | Input                    | Restart signal from clock (CLK) stop state<br>(Level trigger input)                                                                          |
| HALT                                                         | 1                | Input                    | Halt signal (HALT) input                                                                                                                     |
| M1                                                           | 1                | Input                    | Machine cycle 1 (M1) signal input                                                                                                            |
| RSTO2                                                        | 1                | Output                   | Restart signal RSTI2 output                                                                                                                  |
| RST12                                                        | 1                | Input                    | Restart signal from clock (CLK) stop state<br>(Edge trigger input)                                                                           |
| CLK                                                          | 1                | Output                   | Single-phase clock output.<br>When the HALT instruction in STOP or IDLE Mode is executed, The<br>TMPZ84C61A holds clock output at "0" level. |
| DS                                                           | 1                | Input                    | Counter output stage selecting input.<br>Input to set up a warming-up time at time of restart ftom the clock<br>stop state in stop mode.     |
| RESET                                                        | 1                | Input                    | Reset signal input.<br>Restart signal from clock (CLK) stop state (Level trigger input)                                                      |
| RESOUT                                                       | 1                | Output                   | Reset signal output.<br>Restart signal output to MPU and peripherals.                                                                        |
| DIV                                                          | 1                | Input                    | Determinds division or non-division of oscillation frequency.<br>Division mode is selected by the input of "0".                              |
| MS1, MS2                                                     | 2                | Input                    | Mode selection input.<br>One of 3 modes (RUN, IDLE,STOP) is selected according to the state<br>of these 2 pins                               |
| XTAL1<br>(X <sub>IN</sub> ),<br>XTAL2<br>(X <sub>OUT</sub> ) | 2                | Input<br>Output          | Crystal oscillator connecting terminal                                                                                                       |
| vcc                                                          | 1                | Power<br>supply          | + 5V                                                                                                                                         |
| VSS                                                          | 1                | Power<br>supply          | 0V                                                                                                                                           |

|  | Table 2.1 | Pin Names and Functions |
|--|-----------|-------------------------|
|--|-----------|-------------------------|

## 3. DESCRIPTION OF OPERATION

The system configuration, functions and basic operation of the TMPZ84C61A Clock Generator are described here.

#### 3.1 BLOCK DIAGRAM

The block diagram of the internal configuration is shown in Figure 3.1.



Figure 3.1 Block Diagram

#### 3.2 SYSTEM CONFIGURATION

The internal configuration of TMPZ84C61A is as shown in Figure 3.1.

The waveform that is inputted by the external oscillator is converted into the squarewave for clock by the internal oscillator, Clock is controlled by the control circuit and the counter, and outputted to the outside.

In this section, the following principal components and functions which must be known in using the TMPZ84C61A will be described.

- (1) Generation of clock
- (2) Operation mode
- (3) Warming-up time at restart

#### 3.2.1 Generation of clock

TMPZ84C61A internally supports an oscillation circuit to facilitate the clock output. A desired clock is generated from the CLK terminal by simply connecting the oscillator with the external terminals (XTAL1 and XTAL2). The input of "1" to the DIV terminal allows the output of the same frequency as that of the oscillator. By entering "0" to the DIV terminal, TMPZ84C61A generates the clock signal with a 1/2 the input frequency. The DIV terminal must be kept "Low" for a frequency level of more than 6MHz.

Figure 3.2 shows a typical connection of the oscillator.

 A quartz crystal should conform to the following characteristics or MR12000-C20 of TokyoDempa (oscillation frequency : 12MHz):

Output clock frequency (f) : 6MHz

MR12000-C20 quarts crystal oscillator

 $C_S < 4pF$   $R_S < 25\Omega$ Cin = Cout = 33pF



Figure 3.2 Examples of Oscillator Connection

#### 3.2.2 Operation modes

There are 3 kinds of operations modes ; RUN mode, IDLE mode,and STOP mode available for the TMPZ84C61A. One of these modes can be selected by the mode select input (MS1, MS2). These operation modes are effective when the TLCS-Z80 MPU is executing the HALT instruction. When fetching the HALT instruction, MPU outputs "0" to the HALT terminal to indicate that MPU enters into the HALT state. After executing the HALT instruction, the TMPZ84C61A performs the operation in one of these mode by this signal.

The operations of these modes in the HALT state are shown in Table 3.1.

100489

| MS1 | MS2        | Operation<br>Mode | Content of Operation at Halt State                                                                                               |
|-----|------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------|
| 1   | 1          | RUN Mode          | Continues to supply clock to the outside.                                                                                        |
| 0   | *<br>Note) | IDLE Mode         | The internal oscillator only operates and supply of clock to the outside is stopped.<br>Clock output (CLK) is held at "0" level. |
| 1   | 0          | STOP Mode         | The internal operations are all stopped.<br>Clock output (CLK) is held at "0" level.                                             |

Table 3.1 TMPZ84C61A Operation Modes

Note: MS2 can be used for any modes.

Clock is continuously supplied in any mode except the HALT state. MPU is restarted from the clock stop state in IDLE mode and STOP mode by inputting one of  $\overline{\text{RSTI1}}$ ,  $\overline{\text{RST12}}$  or  $\overline{\text{RESET}}$  signal.

MPU is released from the HALT state by the input of **RESET** signal or acceptance of maskable (INT signal) or non-maskable (NMI signal) interrupt request. Therefore, these signals are normally connected to MPU as follows:

- Connect the **RESET** signal of the system with TMPZ84C61A.
- Connect the **RESET** signals of the MPU and peripherals with the **RESOUT** signal.
- INT signal (maskable interrupt input) and RSTI1 signal (restart input) are commonly used.
- RETO2 signal (output of restart input signal RSTI2) is connected to NMI signal (non-maskable interrupt input).

#### 3.2.3 Warming-up time at restart (STOP mode)

When released from the HALT state by acceptance of interrupt request, MPU will execute the interrupt routine. Therefore, to restart the clock by  $\overline{\text{RSTI1}}$  or  $\overline{\text{RSTI2}}$  restart signal in STOP mode it is necessary to supply clock to the outside after the oscillation is sufficiently stabilized. The TMPZ84C61A provides a sufficient warming-up time enough to reach stabilized frequency by operating the internal counter. The warming-up is completed and clock output is started at the rising edge of the internal counter output which is divided oscillation frequency. There is the DS input terminal provided for setting this warming-up time, and a time of  $2^{17}$  (DS=0) or  $2^{14}$  (DS=1) division of the externally connected oscillator is provided.

The block diagram of the internal counter unit is shown in Figure 3.3 and the relationship between the logic of the DS terminal and warming-up time is shown in Table 3.2.

Further, in case of the restart by **RESET** signal, the internal counter does not operate for a quick operation at time of power ON.





| DS | Counter Output | fc = 6MHz | Unit |
|----|----------------|-----------|------|
| 0  | 218            | 21.9      |      |
| 1  | 215            | 2.7       | 1115 |

Table 3.2 Warming-up Time

#### 3.3 STATUS CHANGE FLOWCHART AND BASIC TIMING

In this section, the status change and basic timing when the TMPZ84C61A is operating are explained.

#### 3.3.1 Status change flowchart





#### 3.3.2 Basic timing

(1) Operation when HALT instruction is executed

The basic timing of each mode when the TLCS-Z80 MPU executes the HALT intruction is explained. Synchronously with the fall of T4 state of the HALT instruction opcode fetch cycle (M1), MPU makes the  $\overline{\text{HALT}}$  signal to "0" level. By this signal,the TMPZ84C61A detects that MPU is going to enter into the HALT state.

(a) RUN mode (MS = 1, MS2 = 1)

The basic timing of RUN mode is shown in Figure 3.5.

In the RUN mode, clock is continuously supplied to the outside even when MPU is in the HALT state. This mode is used on a system requiring the memory address refresh.



Figure 3.5 RUN Mode Timing

(b) IDLE mode (MS1 = 0) and STOP mode (MS1 = 1, MS2 = 0)

The basic timing in the IDLE and STOP modes is shown in Figure 3.6. In these modes, clock output is stopped at the "0" level during T4 state by the  $\overline{\text{HALT}}$  signal and  $\overline{\text{MI}}$  signal following the HALT instruction.

However, in case of the STOP mode the internal oscillator of the TMPZ84C61A is also stopped.





#### (2) Restart from clock stop

The clock is restarted from the stopped state in the IDLE or STOP mode when "0" is inputted to any one of the following signals :

- RSTI1 (level trigger input)
- RSTI2 (edge trigger input)
- **RESET** (level trigger input)
- (a) Restart in IDLE mode

The restart sequence from the clock output stop state in the IDLE mode is shown in Figure 3.7. In the restart in the IDLE mode, the clock output is restarted in a relatively short delay time as the internal oscillator is in operation even when the clock output is kept stopped.



Figure 3.7 Restart Sequence Timing from Clock Stop State (IDLE mode)

(b) Restart in STOP mode

The restart sequence from the clock output stopped state in the STOP mode is shown in Figure 3.8. In restarting the clock output by inputting "0" into  $\overline{\text{RSTI1}}$  or  $\overline{\text{RST12}}$  signal, a warming-up time is automatically provided by the internal counter.





### 3.4 METHOD OF USE

Connection of the TMPZ84C61A with MPU when executing the HALT instruction is explained here.

### 3.4.1 $\overline{ ext{RESET}}$ Signal

Figure 3.9 shows the examples of restart timing in the STOP mode when the TLCS-Z80 MPU and TMPZ84C61A use  $\overline{\text{RESET}}$  signal commonly.

To reset the TLCS-Z80 MPU,  $\overline{\text{RESET}}$  signal must be kept at "0" level for at least 3 clocks. Further, when  $\overline{\text{RESET}}$  signal becomes "1" level, MPU is released from the HALT state after the dummy cycle for at least 2T states and executes an instruction starting from address 0000H.

In restarting the clock output in the STOP mode by  $\overline{\text{RESET}}$  signal, the internal counter for determining the warming-up time does not operate.

Note that MPU may not be restarted properly due to unstable clock output immediately after the internal oscillator is restarted. Therefore,  $\overline{\text{RESET}}$  signal should be kept at "0" level for a sufficient period of time enough to firmly reset MPU by taking stability of crystal oscillation at time of power ON.



Figure 3.9 Example of Clock Restart Timing by  $\overline{\text{RESET}}$  Signal

## 3.4.2 HALT release by interrupt signal

When the TMPZ84C61A is in the IDLE or STOP mode, the clock output is restarted by  $\overline{\text{RSTI1}}$  or  $\overline{\text{RST12}}$  signal input and MPU starts to run according to that clock input. However, after the clock output, MPU is still in the HALT state and executes the NOP instruction. To release MPU from the HALT state, it is necessary to input the interrupt signal ( $\overline{\text{INT}}$  or  $\overline{\text{NMI}}$ ). MPU samples the interrupt signal at the falling edge of the last clock of each instruction (NOP instruction for the HALT state).

(1) When non-maskable interrupt ( $\overline{NMI}$ ) is used:

The non-maskable interrupt is the edge trigger input, and there is flip-flop (F/F) in MPU. The state of this internal NMI F/F is sampled at the falling edge of the last clock of an instruction. Therefore, if a short low active ("0") pulse has been input before the interrupt signal sampling timing, this interrupt request is accepted.

 $\overline{\text{RST12}}$  input of the TMPZ84C61A is output to  $\overline{\text{RST02}}$  through the internal circuit. It is therefore recommended that the restart signal is generated to the  $\overline{\text{RST12}}$  input terminal and  $\overline{\text{RST02}}$  signal is output into the  $\overline{\text{NMI}}$  terminal of MPU.

(2) When maskable interrupt (INT) is used :

For maskable interrupt, the interrupt enable flip-flop (IFF) must be set to "1" before "0" of  $\overline{INT}$  input signal is recognized. In the connection of MPU and TMPZ84C61A, this interrupt signal  $\overline{INT}$  is jointly used with the restart signal  $\overline{RST11}$  of the TMPZ84C61A. Shown in Figure 3.10 are examples of the timing when  $\overline{RST02}$  output signal of the TMPZ84C61A is input to  $\overline{NM1}$  of MPU and  $\overline{RST11}$  signal of the TMPZ84C61A is jointly used with  $\overline{INT}$  signal of MPU.



Figure 3.10 Example of Clock Restart Timing by  $\overline{\mathrm{RSTI1}}$  or  $\overline{\mathrm{RST12}}$  Signals

#### 3.4.3 Example of connection

A connecting example of the TMPZ84C61A and MPU is shown in Figure 3.11.1. This figure shows an example when  $\overline{\text{RSTO2}}$  output signal of the TMPZ84C61A is input into  $\overline{\text{NMI}}$  of MPU by jointly using  $\overline{\text{RESET}}$  signal with MPU and  $\overline{\text{RSTI1}}$  signal of the TMPZ84C61A and  $\overline{\text{INT}}$  signal of MPU are jointly used.

Also refer to Figure 3.11.2 for the example of connecting the  $\overline{\text{RESOUT}}$  signal of TMPZ84C61A with the  $\overline{\text{RESET}}$  signal of the MPU.



Figure 3.11.1 Connecting Example of the TMPZ84C61A and TLCS-Z80 MPU without using RESOUT



Figure 3.11.2 Conncting Example of the TMPZ84C61A and TLCS-Z80 MPU using RESOUT

# 4. ELECTRICAL CHARACTERISTICS

# 4.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL              | ITEM                          | RATING             | UNIT   |
|---------------------|-------------------------------|--------------------|--------|
| V <sub>CC</sub>     | Supply Voltage                | - 0.5 to + 7       | V      |
| VIN                 | Input Voltage                 | – 0.5 to Vcc + 0.5 | V      |
| PD                  | Power Dissipation (TA = 85°C) | 250                | mW     |
| T <sub>SOLDER</sub> | Soldering Temperature (10sec) | 260                | °C     |
| T <sub>stg</sub>    | Storage Temperature           | – 65 to 150        | °C     |
| T <sub>opr</sub>    | Operating Temperature         | – 40 to 85         | °C     |
|                     |                               |                    | 100489 |

## 4.2 DC ELECTRICAL CHARACTERISTICS

 $TOPR = -40^{\circ}C$  to 85°C,  $VCC = 5V \pm 10\%$ , VSS = 0V

| SYMBOL           | ITEM                                    | TEST CONDITIOIN                  | MIN.                  | TYP.         | MAX.            | UNIT |
|------------------|-----------------------------------------|----------------------------------|-----------------------|--------------|-----------------|------|
| V <sub>IL</sub>  | Input Low Voltage<br>(Except XTAL 1,2)  |                                  | - 0.5                 | <sup>:</sup> | 0.8             | v    |
| V <sub>IH</sub>  | Input High Voltage<br>(Except XTAL 1,2) |                                  | 2.2                   |              | V <sub>CC</sub> | v    |
| V <sub>OLC</sub> | Output Low Vlotage<br>(CLK)             | I <sub>OL</sub> = 2.0mA          | _                     | —            | 0.4             | V    |
| V <sub>OL</sub>  | Output Low Vlotage<br>(Except CLK)      | I <sub>OL</sub> = 2.0mA          | _                     | —            | 0.4             | v    |
| V <sub>OHC</sub> | Output High Vlotage<br>(CLK)            | l <sub>OH</sub> = -250µА         | V <sub>CC</sub> – 0.6 | _            | -               | v    |
| V <sub>OH1</sub> | Output High Vlotage<br>(Except CLK)     | I <sub>OH</sub> = – 1.6mA        | 2.4                   | _            | _               | v    |
| V <sub>OH2</sub> | Output High Vlotage<br>(Except CLK)     | l <sub>OH</sub> = -250µА         | V <sub>CC</sub> – 0.8 | _            | _               | v    |
| IIL              | Input Leak Current                      | $V_{SS} \leq V_{IN} \leq V_{CC}$ | _                     | _            | ±1              | μA   |

| SYMBOL | ITEM                                        | TEST CONDITION                                                                                      | MIN. | TYP. | MAX. | UNIT   |
|--------|---------------------------------------------|-----------------------------------------------------------------------------------------------------|------|------|------|--------|
| ICC1   | Supply Current<br>(Operation)<br>(RUN Mode) | $V_{CC} = 5V,$<br>fXTAL = 12MHz<br>$V_{IHC} = V_{IH} = V_{CC} - 0.2V,$<br>$V_{ILC} = V_{IL} = 0.2V$ | _    | 3    | 5    | mA     |
| ICC2   | Supply Current<br>(STOP Mode)               | $V_{CC} = 5V,$<br>$V_{IHC} = V_{IH} = V_{CC} - 0.2V,$<br>$V_{ILC} = V_{IL} = 0.2V$                  |      | 0.3  | 10   | μΑ     |
| ICC3   | Supply Current<br>(IDLE Mode)               | $V_{CC} = 5V,$<br>fXTAL = 12MHz<br>$V_{IHC} = V_{IH} = V_{CC} - 0.2V,$<br>$V_{ILC} = V_{IL} = 0.2V$ | _    | 0.5  | 1    | mA     |
|        |                                             |                                                                                                     |      |      |      | 100489 |

# DIV="0" (6MHz) (Oscillation frequency: 12MHz)

#### 4.3 AC ELECTRICAL CHARACTERISTICS

| NO. | SYMBOL              | ITEM            |        | TEST<br>CONDI-<br>TION | MIN. | түр.                  | MAX. | UNIT |
|-----|---------------------|-----------------|--------|------------------------|------|-----------------------|------|------|
| 1   | TcC                 | CLK Frequency   |        |                        | 165  | -                     | -    | ns   |
| 2   | TwCh                | High CLK widt   | h      |                        | 70   | -                     | -    | ns   |
| 3   | TwCl                | Low Clk width   |        |                        | 70   | -                     | -    | ns   |
| 4   | TrC                 | CLK rising time | 9      |                        | -    | -                     | 12   | ns   |
| 5   | TfC                 | CLK falling tim | e      |                        | -    | -                     | 12   | ns   |
| 6   | TsHALT<br>(M1r)     | HALT set-up ti  | me     |                        | 10   | -                     | -    | ns   |
| 7   | TwRSTI1             | Low RSTI1 wid   | th     |                        | 70   | -                     | -    | ns   |
| 8   | TwRSTI2             | Low RSTI2 wid   | th     |                        | 160  | -                     | -    | ns   |
| 9   | TdRSTO2<br>(RSTI2f) | RSTO2 delay ti  | me     |                        | -    | -                     | 60   | ns   |
| 10  | TwRSTO2             | Low RSTO2 wi    | dth    |                        | 70   | -                     | -    | ns   |
| 11  | TWRESET             | Low RESET wid   | lth    |                        | 70   | -                     | -    | ns   |
| 12  | TRST1S              |                 |        | 100pF                  | -    | (2 <sup>17</sup> +    | -    | ns   |
|     |                     | CLK restart     | DS = 0 |                        |      | 2.5) T <sub>C</sub> C |      |      |
|     |                     | time by RSTI1   |        |                        | -    | (214 +                | -    | ns   |
|     |                     | (STOP Mode)     | DS = 0 |                        |      | 2.5) T <sub>C</sub> C |      |      |
| 13  | TRST2S              |                 |        |                        | -    | (217 +                | -    | ns   |
|     |                     | CLK restart     | DS = 0 |                        |      | 2.5) T <sub>C</sub> C |      |      |
|     |                     | time by RSTI2   |        |                        | -    | (2 <sup>14</sup> +    | -    | ns   |
|     |                     | (STOP Mode)     | DS = 0 |                        |      | 2.5) T <sub>C</sub> C |      |      |
| 14  | TRST11              | CLK restart t   | ime by |                        |      | 2.5                   | •    | ns   |
|     |                     | RSTI1 (IDLE mo  | de)    |                        |      | TcC                   |      |      |
| 15  | TRST2I              | CLK restart t   | ime by |                        |      | 2.5                   |      | ns   |
|     |                     | RSTI2 (IDLE mo  | de)    |                        |      | TcC                   |      |      |
| 16  | TRESETI             | CLK restart t   | ime by |                        |      | 1                     |      | ns   |
|     |                     | RESET (IDLE mo  | ode)   |                        |      | TcC                   |      |      |

 $TOPR = -40^{\circ}C$  to  $85^{\circ}C$ ,  $VCC = 5V \pm 10\%$ , VSS = 0V,  $\overline{DIV} = "1"$ ,  $\overline{DIV} = "0"$ 

100489

Note :Test conditions

- 1) Input high voltage VIH = 2.4V, Input low voltage VIL = 0.4V
- 2) Testing point
  - a VOH=2.2V, VOL=0.8V (except CLK output)
  - b CLK Output: VOH = VCC 0.6V, VOL = 0.4V

# 4.4 CAPACITANCE

## $TA = 25^{\circ}C$

| SYMBOL             | ITEM                               | TEST CONDITION                              | MIN. | TYP. | MAX. | UNIT   |
|--------------------|------------------------------------|---------------------------------------------|------|------|------|--------|
| С <sub>СLОСК</sub> | Clock Input Capacitance<br>(XTAL2) | f = 1MHz                                    | -    | -    | 15   | pF     |
| C <sub>IN</sub>    | Input Capacitance                  | All terminals except<br>that to be measured | -    | -    | 5    | pF     |
| C <sub>OUT</sub>   | Output Capacitance                 | should be earthed.                          | -    | -    | 6    | рF     |
|                    |                                    |                                             |      |      |      | 100489 |

#### 4.5 TIMING DIAGRAM

Figure 4.1 to 4.4 show the basic timings of respective operation. Numbers shown in the figures correspond with those in the AC Electrical Characteristics Table in 4.3.











# 5. OUTLINE DRAWING

DIP16-P-300A



270289

#### Note :

- 1. This dimension is measured at the center of bending point of leads.
- 2. Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.16 leads.

## 6. PRECAUTIONS

When the TMPZ84C61A is used, care should be taken to the following points.

- In using RESET signal commonly with MPU, hold RESET signal at "0" for a sufficient period of time enough to positively reset MPU. Especially, in case of the restart in the STOP mode using RESET signal, be careful as output of the internal oscillator is not stable.
- (2) MPU is not released from the HALT state simply when the clock input is resumed. To release MPU, it is necessary to reset MPU or accept an interrupt request.
- (3) Since RSTI2 signal of the TMPZ84C61A and NMI signal of MPU are both trailing edge trigger inputs. if both signals are jointly used, RSTI2 signal only may be detected and NMI signal may not be detected in some cares. This trouble can be solved by using RSTO2 signal, which is the output signal of RSTI2 input signal, as the input signal to NMI in order to a sufficient pulse for the detection.

# PART 1 8-BIT MICROPROCESSOR CHAPTER 2 TLCS-Z80 ASSP FAMILY

TOSHIBA CORPORATION

# CONTENTS

# TMPZ84C011A

| 1. OVER | VIEW AND FEATURES                              | MPUZ80 - 297 |
|---------|------------------------------------------------|--------------|
|         |                                                | MDU200 200   |
| Z. PINA |                                                | MPU280 - 298 |
| 2.1 PI  | ASSIGNMENTS (TOP VIEW)                         | WPU280 - 298 |
| 3. OPER | ATIONAL DESCRIPTIONS                           | MPUZ80 - 302 |
| 3.1 EN  | TIRE BLOCK DIAGRAM AND OPERATION OF EACH BLOCK | MPUZ80 - 302 |
| 3.1.1   | Entire Block Diagram                           | MPUZ80 - 302 |
| 3.1.2   | Operation of Each Block                        | MPUZ80 - 303 |
| 3.2 MF  | PU OPERATIONS                                  | MPUZ80 - 304 |
| 3.2.1   | Block Diagram                                  | MPUZ80 - 304 |
| 3.2.2   | MPU System Configuration                       | MPUZ80 - 305 |
| 3.2.3   | MPU Status Transition Diagram and Basic Timing | MPUZ80 - 319 |
| 3.2.4   | TMPZ84C011A Instruction Set                    | MPUZ80 - 334 |
| 3.3 CG  | C Operations                                   | MPUZ80- 352  |
| 3.3.1   | Block Diagram                                  | MPUZ80- 352  |
| 3.3.2   | CGC System Configuration                       | MPUZ80 - 352 |
| 3.3.3   | CGC Status Transition Diagram and Basic Timing | MPUZ80 - 356 |
| 3.3.4   | Relationship with MPU                          | MPUZ80 - 359 |
| 3.4 CT  | C Operational Description                      | MPUZ80 - 362 |
| 3.4.1   | CTC Block Diagram                              | MPUZ80 - 362 |
| 3.4.2   | CTC System Configuration                       | MPUZ80 - 363 |
| 3.4.3   | CTC Basic Operations                           | MPUZ80 - 365 |
| 3.4.4   | CTC Status Transition Diagram and Basic Timing | MPUZ80 - 366 |
| 3.4.5   | CTC Operational Procedure                      | MPUZ80 - 373 |
| 3.4.6   | Using CTC                                      | MPUZ80 - 376 |
| 3.5 Des | cription of I/O Operation                      | MPUZ80 - 379 |
| 3.5.1   | I/O Block Diagram                              | MPUZ80 - 379 |

i

|   | 3.5.2 | I/O System Configuration                             | MPUZ80 - 380 |
|---|-------|------------------------------------------------------|--------------|
|   | 3.5.3 | I/O Port Basic Operations                            | MPUZ80 - 381 |
|   | 3.5.4 | I/O System Basic Timing                              | MPUZ80 - 383 |
|   |       |                                                      |              |
| 4 | ELEC  | TRICAL CHARACTERISTICS                               | MPUZ80 - 384 |
|   | 4.1 N | AXIMUM RATINGS                                       | MPUZ80 - 384 |
|   | 4.2 D | C ELECTRICAL CHARACTERISTICS                         | MPUZ80 - 384 |
|   | 4.3 A | C ELECTRICAL CHARACTERISTICS (1) (IN ACTIVE STATE)   | MPUZ80 - 385 |
|   | 4.3.1 | AC Characteristics of MPU (in Active State)          | MPUZ80 - 385 |
|   | 4.3.2 | AC Characteristics of CGC (in Active State)          | MPUZ80 - 387 |
|   | 4.3.3 | AC Characteristics of CTC (in Active State)          | MPUZ80 - 387 |
|   | 4.3.4 | AC Characteristics of I/O (in Active State)          | MPUZ80 - 388 |
|   | 4.4 C | APACITANCE                                           | MPUZ80 - 388 |
|   | 4.5 A | C TIMING CHARTS (1) (IN ACTIVE STATE)                | MPUZ80 - 389 |
|   | 4.5.1 | AC Timing Charts of MPU (in Active State)            | MPUZ80 - 389 |
|   | 4.5.2 | AC Timing Cfarts of CGC (in Active State)            | MPUZ80 - 394 |
|   | 4.5.3 | AC Timing Charts of CTC (in Active State)            | MPUZ80 - 395 |
|   | 4.5.4 | AC Timing Charts of I/O (in Active State)            | MPUZ80 - 396 |
|   | 4.6 A | C ELECTRICAL CHARACTERISTICS (2) (IN INACTIVE STATE) | MPUZ80 - 397 |
|   | 4.6.1 | AC Characteristics of CGC (in Inactive State)        | MPUZ80 - 397 |
|   | 4.6.2 | AC Characteristics of CTC (in Inactive State)        | MPUZ80 - 398 |
|   | 4.6.3 | AC Characteristics of I/O (in Inactive State)        | MPUZ80 - 399 |
|   | 4.7 A | C TIMING CHARTS (2) (IN INACTIVE STATE)              | MPUZ80 - 400 |
|   | 4.7.1 | AC Timing Charts of CGC (in Inactive State)          | MPUZ80 - 400 |
|   | 4.7.2 | AC Timing Charts of CTC (in Inactive State)          | MPUZ80 - 401 |
|   | 4.7.3 | AC Timing Charts of I/O (in Inactive State)          | MPUZ80 - 402 |
|   | 4.8 O | UT LINE DRAWING                                      | MPUZ80 - 403 |

ii

# TMPZ84C013A

| 1. OUTLINE AND FEATURES                              | MPUZ80 - 404 |
|------------------------------------------------------|--------------|
| 2. PIN ASSIGNMENT AND FUNCTIONS                      | MPUZ80 - 406 |
| 2.1 PIN ASSIGNMENTS (TOP VIEW)                       | MPUZ80 - 406 |
| 2.2 (A) PIN FUNCTIONS                                | MPUZ80 - 407 |
| 2.2 (B) TMPZ84C013A INTERNAL I/O ADDRESS MAP         | MPUZ80 - 411 |
|                                                      |              |
| 3. OPERATIONAL DESCRIPTION                           | MPUZ80 - 412 |
| 3.1 BLOCK DIAGRAM AND OPERATIONAL OUTLINE            | MPUZ80 - 412 |
| 3.1.1 Block Diagram                                  | MPUZ80 - 412 |
| 3.1.2 Operational Outline                            | MPUZ80 - 413 |
| 3.2 MPU OPERATIONS                                   | MPUZ80 - 415 |
| 3.2.1 Block Diagram                                  | MPUZ80 - 415 |
| 3.2.2 MPU System Configuration                       | MPUZ80 - 416 |
| 3.2.3 MPU Status Transition Diagram and Basic Timing | MPUZ80 - 430 |
| 3.2.4 TMPZ84C013A Instruction Set                    | MPUZ80 - 445 |
| 3.3 CGC OPERATIONS                                   | MPUZ80 - 463 |
| 3.3.1 Block Diagram                                  | MPUZ80 - 463 |
| 3.3.2 CGC System Configuration                       | MPUZ80 - 463 |
| 3.3.3 CGC Status Transition Diagram and Basic Timing | MPUZ80 - 467 |
| 3.3.4 Relationship with MPU                          | MPUZ80 - 471 |
| 3.4 CTC OPERATIONAL DESCRIPTION                      | MPUZ80 - 474 |
| 3.4.1 CTC Block Diagram                              | MPUZ80 - 474 |
| 3.4.2 CTC System Configuration                       | MPUZ80 - 474 |
| 3.4.3 CTC Basic Operations                           | MPUZ80 - 476 |
| 3.4.4 CTC Status Transition Diagram and Basic Timing | MPUZ80 - 479 |
| 3.4.5 CTC Operational Procedure                      | MPUZ80 - 484 |
| 3.4.6 Using CTC                                      | MPUZ80 - 488 |
| 3.5 SIO OPERATIONAL DESCRIPTION                      | MPUZ80 - 491 |
| 3.5.1 SIO Block Diagram                              | MPUZ80 - 491 |
| 3.5.2 SIO System Configuration                       | MPUZ80 - 491 |
|                                                      |              |

iii

|     | 3.5.3 | SIO Basic Operations                               | MPUZ80 - 497 |
|-----|-------|----------------------------------------------------|--------------|
|     | 3.5.4 | SIO Status Transition Diagram and Basic Timing     | MPUZ80 - 503 |
|     | 3.5.5 | SIO Operational Procedure                          | MPUZ80 - 510 |
|     | 3.5.6 | Using SIO                                          | MPUZ80 - 525 |
| 3.  | 6 STA | ANDBY CAPABILITY                                   | MPUZ80 - 527 |
|     | 3.6.1 | Setting Halt Mode                                  | MPUZ80 - 527 |
|     | 3.6.2 | Halt Mode Setting Procedure                        | MPUZ80 - 529 |
| 3.  | 7 WA  | TCHDOG TIMER                                       | MPUZ80 - 530 |
|     | 3.7.1 | Block Diagram of Watchdog Timer                    | MPUZ80 - 530 |
|     | 3.7.2 | Setting Watchdog Timer                             | MPUZ80 - 531 |
|     | 3.7.3 | Watchdog Timer Output                              | MPUZ80 - 532 |
| 3.  | 8 INT | ERRUPT PRIORITY                                    | MPUZ80 - 533 |
|     | 3.8.1 | Setting Interrupt Priority                         | MPUZ80 - 533 |
|     |       |                                                    |              |
| 4.  | ELECT | RICAL CHARACTERISTICS                              | MPUZ80 - 534 |
| 4.  | 1 MA  | XIMUM RATINGS                                      | MPUZ80 - 534 |
| 4.  | 2 DC  | ELECTRICAL CHARACTERISTICS                         | MPUZ80 - 534 |
| 4.  | 3 AC  | ELECTRICAL CHARACTERISTICS (1) (IN ACTIVE STATE)   | MPUZ80 - 536 |
|     | 4.3.1 | AC Characteristics of CPU (in Active State)        | MPUZ80 - 536 |
|     | 4.3.2 | AC Characteristics of CGC (in Active State)        | MPUZ80 - 538 |
|     | 4.3.3 | AC Characteristics of CTC (in Active State)        | MPUZ80 - 539 |
|     | 4.3.4 | AC Caracteristics of SIO (in Active State)         | MPUZ80 - 540 |
|     | 4.3.5 | AC Chracteristics of WDT (in Active State)         | MPUZ80 - 541 |
| 4.4 | 4 AC  | TIMING CHARTS (1) (IN ACTIVE STATE)                | MPUZ80 - 542 |
|     | 4.4.1 | AC Timing Charts of CPU (in Active State)          | MPUZ80 - 542 |
|     | 4.4.2 | AC Timing Charts of CGC (in Active State)          | MPUZ80 - 546 |
|     | 4.4.3 | AC Timing Charts of CTC (in Active State)          | MPUZ80 - 548 |
|     | 4.4.4 | AC Timing Charts of SIO (in Active State)          | MPUZ80 - 549 |
|     | 4.4.5 | AC Timing Charts of WDT (in Active State)          | MPUZ80 - 551 |
| 4.! | 5 AC  | ELECTRICAL CHARACTERISTICS (2) (IN INACTIVE STATE) | MPUZ80 - 552 |
|     | 4.5.1 | AC Characteristics of CGC (in Inactive State)      | MPUZ80 - 552 |
|     | 4.5.2 | AC Characteristics of CTC (in Inactive State)      | MPUZ80 - 552 |
|     | 4.5.3 | AC Characteristics of SIO (in Inactive State)      | MPUZ80 - 554 |
|     | 4.5.4 | AC Characteristics of WDT (in Inactive State)      | MPUZ80 - 555 |

| 4.6 AC TIMING CHARTS (2) (IN IN | IACTIVE STATE) M        | PUZ80 - 556 |
|---------------------------------|-------------------------|-------------|
| 4.6.1 AC Timing Charts of CGC   | C (in Inactive State) M | PUZ80 - 556 |
| 4.6.2 AC Timing Charts of CTC   | (in Inactive State) M   | PUZ80 - 558 |
| 4.6.3 AC Timing Charts of SIO ( | (in Inactive State) M   | PUZ80 - 559 |
| 4.6.4 AC Timing Charts of WD    | T (in Inactive State) M | PUZ80 - 561 |
| 4.7 PIN CAPACITANCE             | M                       | PUZ80 - 562 |
|                                 |                         |             |
| 5. EXTERNAL DIMENSIONS          | ΜΜ                      | PUZ80 - 563 |

v

# TMPZ84C015A

| 1. OUTLINE AND FEATURES                              | MPUZ80 - 564 |
|------------------------------------------------------|--------------|
| 2 PIN ASSIGNMENTS AND FUNCTIONS                      | MPU780 - 566 |
| 2.1 PIN ASSIGNMENTS (TOP VIEW)                       | MPUZ80 - 566 |
| 2.1 (A) PIN FUNCTIONS                                | MPUZ80 - 567 |
| 2.2 (R) TMP784C015A Internal I/O Address Man         | MPU780 - 572 |
|                                                      | WI 0200 372  |
| 3. OPERATIONAL DESCRIPTION                           | MPUZ80 - 573 |
| 3.1 BLOCK DIAGRAM AND OPERATIONAL OUTLINE            | MPUZ80 - 573 |
| 3.1.1 Block Diagram                                  | MPUZ80 - 573 |
| 3.1.2 Operational Outline                            | MPUZ80 - 574 |
| 3.2 MPU OPERATIONS                                   | MPUZ80 - 576 |
| 3.2.1 Block Diagram                                  | MPUZ80 - 576 |
| 3.2.2 MPU System Configuration                       | MPUZ80 - 577 |
| 3.2.3 MPU Status Transition Diagram and Basic Timing | MPUZ80 - 591 |
| 3.2.4 TMPZ84C015A Instruction Set                    | MPUZ80 - 605 |
| 3.3 CGC OPERATIONS                                   | MPUZ80 - 623 |
| 3.3.1 Block Diagram                                  | MPUZ80 - 623 |
| 3.3.2 CGC System Configuration                       | MPUZ80 - 623 |
| 3.3.3 CGC Status Transition Diagram and Basic Timing | MPUZ80 - 627 |
| 3.3.4 Relationship with MPU                          | MPUZ80 - 631 |
| 3.4 CTC OPERATIONAL DESCRIPTION                      | MPUZ80 - 634 |
| 3.4.1 CTC Block Diagram                              | MPUZ80 - 634 |
| 3.4.2 CTC System Configuration                       | MPUZ80 - 634 |
| 3.4.3 CTC Basic Operations                           | MPUZ80 - 636 |
| 3.4.4 CTC Status Transition Diagram and Basic Timing | MPUZ80 - 639 |
| 3.4.5 CTC Operational Procedure                      | MPUZ80 - 644 |
| 3.4.6 Using CTC                                      | MPUZ80 - 647 |
| 3.5 PIO OPERATIONAL DESCRIPTION                      | MPUZ80 - 650 |
| 3.5.1 PIO Block Diagram                              | MPUZ80 - 650 |

vi

| 3.5.2 PIO System Configuration                          | MPUZ80 - 650 |
|---------------------------------------------------------|--------------|
| 3.5.3 PIO Basic Operations                              | MPUZ80 - 652 |
| 3.5.4 PIO Transition and Basic Timing                   | MPUZ80 - 658 |
| 3.5.5 PIO Operational Procedure                         | MPUZ80 - 666 |
| 3.5.6 Using PIO                                         | MPUZ80 - 669 |
| 3.6 SIO OPERATIONAL DESCRIPTION                         | MPUZ80 - 670 |
| 3.6.1 SIO Block Diagram                                 | MPUZ80 - 670 |
| 3.6.2 SIO System Configuration                          | MPUZ80 - 671 |
| 3.6.3 SIO Basic Operations                              | MPUZ80 - 676 |
| 3.6.4 SIO Status Transition Diagram and Basic Timing    | MPUZ80 - 682 |
| 3.6.5 SIO Operational Procedure                         | MPUZ80 - 690 |
| 3.6.6 Using SIO                                         | MPUZ80 - 705 |
| 3.7 STANDBY CAPABILITY                                  | MPUZ80 - 706 |
| 3.7.1 Setting Halt Mode                                 | MPUZ80 - 706 |
| 3.7.2 Halt Mode Setting Procedure                       | MPUZ80 - 708 |
| 3.8 WATCHDOG TIMER                                      | MPUZ80 - 709 |
| 3.8.1 Block Diagram of Watchdog Timer                   | MPUZ80 - 709 |
| 3.8.2 Setting Watchdog Timer                            | MPUZ80 - 710 |
| 3.8.3 Watchdog Timer Output                             | MPUZ80 - 711 |
| 3.9 INTERRUPT PRIORITY                                  | MPUZ80 - 712 |
| 3.9.1 Setting Interrupt Priority                        | MPUZ80 - 712 |
|                                                         |              |
| 4. ELECTRICAL CHARACTERISTICS                           | MPUZ80 - 713 |
| 4.1 MAXIMUM RATINGS                                     | MPUZ80 - 713 |
| 4.2 DC ELECTRICAL CHARACTERISTICS                       | MPUZ80 - 713 |
| 4.3 AC ELECTRICAL CHARACTERISTICS (1) (in Active State) | MPUZ80 - 715 |
| 4.3.1 AC Characteristics of MPU (in Active State)       | MPUZ80 - 715 |
| 4.3.2 AC Characteristics of CGC (in Active State)       | MPUZ80 - 717 |
| 4.3.3 AC Characteristics of CTC (in Active State)       | MPUZ80 - 718 |
| 4.3.4 AC Characteristics of PIO (in Active State)       | MPUZ80 - 719 |
| 4.3.5 AC Characteristics of SIO (in Active State)       | MPUZ80 - 720 |
| 4.3.6 AC Characteristic of WDT (in Active State)        | MPUZ80 - 721 |
| 4.4 AC TIMING CHARTS (1) (in Active State)              | MPUZ80 - 722 |
| 4.4.1 AC Timing Charts of MPU (in Active State)         | MPUZ80 - 722 |

vii

| 4.4.2 AC Timing Charts of CGC (in Active State)           | . MPUZ80 - 7 <b>26</b> |
|-----------------------------------------------------------|------------------------|
| 4.4.3 AC Timing Charts of CTC (in Active State)           | . MPUZ80 - 728         |
| 4.4.4 AC Timing Charts of PIO (in Active State)           | . MPUZ80 - 729         |
| 4.4.5 AC Timing Charts of SIO (in Active State)           | . MPUZ80 - 730         |
| 4.4.6 AC Timing Charts of WDT (in Active State)           | . MPUZ80 - 732         |
| 4.5 AC ELECTRICAL CHARACTERISTICS (2) (In Inactive State) | . MPUZ80 - 733         |
| 4.5.1 AC Characteristics of CGC (in Inactive State)       | . MPUZ80 - 733         |
| 4.5.2 AC Characteristics of CTC (in Inactive State)       | . MPUZ80 - 733         |
| 4.5.3 AC Characteristics of PIO (in Inactive State)       | . MPUZ80 - 735         |
| 4.5.4 AC Characteristics of SIO (in Inactive State)       | . MPUZ80 - 736         |
| 4.5.5 AC Characteristics of WDT (in Inactive State)       | . MPUZ80 - 738         |
| 4.6 AC TIMING CHARTS (2) (In Inactive State)              | MPUZ80 - 739           |
| 4.6.1 AC Timing Charts of CGC (in Inactive State)         | . MPUZ80 - 739         |
| 4.6.2 AC Timing Charts of CTC (in Inactive State)         | . MPUZ80 - 741         |
| 4.6.3 AC Timing Charts of PIO (in Inactive State)         | . MPUZ80 - 742         |
| 4.6.4 AC Timing Charts of SIO (in Inactive State)         | . MPUZ80 - 743         |
| 4.6.5 AC Timing Charts of WDT (in Inactive State)         | . MPUZ80 - 745         |
| 4.7 PIN CAPACITANCE                                       | MPUZ80 - 746           |
|                                                           |                        |
| 5. EXETERNAL DIMENSIONS                                   | MPUZ80 - 747           |

# The Guide Of TOSHIBA TLCS-Z80 ASSP Development Tools And Development Methods

| 1. | GENERAL                                         | MPUZ80 - 748 |
|----|-------------------------------------------------|--------------|
| 2. | EVALUATION MODE OF ASSP                         | MPUZ80 - 749 |
| 3. | EMULATOR CONNECTION AND ADAPTER BOARDS          | MPUZ80 - 750 |
| 3  | 3.1 LEVEL 1 (Evaluation boards : BM8024/25)     | MPUZ80 - 750 |
| 3  | 2.2 LEVEL 2 (Adapter boards : BM8026/27)        | MPUZ80 - 750 |
| 4. | DEVELOPMENT METHOD                              | MPUZ80 - 751 |
| 4  | I.1 LEVEL 1                                     | MPUZ80 - 751 |
| 4  | I.2 LEVEL 2                                     | MPUZ80 - 751 |
| 4  | 3 CONNECTION OF RM8026/RM8027 AND TARGET SYSTEM | MPU780 - 752 |

ix

# TMPZ84C011AF-6 TLCS-Z80 MICROPROCESSOR

## 1. OVERVIEW AND FEATURES

The TMPZ84C011A is a high-performance CMOS 8-bit microprocessor that contains the functional peripherals such as counter timer circuit (CTC) parallel I/O port, and clock generator/controller (CGC) around the TLCS-Z80 MPU. This microprocessor directly inherits the basic architecture of the TLCS-Z80 MPU, making available the software resources and development tools accumulated so far.

The TMPZ84C011A is based on the new CMOS process and housed in a standard 100pin mini-flat package, greatly contributing to system minituarization and power saving.

The TMPZ84C011A has many I/O ports, making it available for a wide range of system applications such as the controller, the measuring instrument, and the word processor.

Features:

- Built-in MPU, CTC, and CGC functions of the TLCS-Z80 family.
- High speed operation (6 MHz operation)
- Built-in clock generator (CGC. Clock Generator/Controller)
- Built-in standby capability (with the controller built in)
- Low power consumption

| operation | 15 mA typ. (4 MHz) 22mA typ. (6MHz)          |
|-----------|----------------------------------------------|
| idle      | $1.0\ mA$ typ. (4 MHz) $1.5\ mA$ typ. (6MHz) |
| standby   | 500 nA typ.                                  |

- Wide operational power voltage range  $(5V \pm 10\%, 3 \text{ to } 6V \text{ operation supported})$
- Wide operational temperature range (-40°C to +85°C)
- Many general-purpose ports (5 ports, 40 bits) which support I/O operation on a bit basis.
- Four channels of timer/counter (the same capability as the TLCS-Z80 CTC).
- Built-in dynamic RAM refresh controller
- Daisy-chain interrupt control pin

- Housed in a compact 100-pin mini-flat package
- Emulation by Z80 ICE (ex. Toshiba Real Time Emulator RTE80) is available.
- The Toshiba evaluator board (BM8024) and adapter board (BM8026) are available.

note: Z80 is a trade mark of Zilog Inc.

## 2. PIN ASSIGNMENTS AND FUNCTIONS

#### 2.1 PIN ASSIGNMENTS (TOP VIEW)





(1/3)

| Pin     | Number                  | Туре              | Function                                                                                                                                                                                                                                                                                                                                                        |
|---------|-------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D7   | 8<br>(6-13)             | l/O<br>3-state    | The 8-bit bi-directional data bus.                                                                                                                                                                                                                                                                                                                              |
| A0-A15  | 16<br>(29-44)           | Output<br>3-state | The 16-bit address bus.<br>These pins specify memory and I/O port addresses. During a<br>refresh cycle, the refresh address is output to the low-order 7 bits.                                                                                                                                                                                                  |
| ΡΑΟ-ΡΑ7 | 8<br>(61-68)            | l/O<br>3-state    | The general-purpose I/O port (port A) which can be set by program<br>for input or output on a bit basis. When it is set for output, it<br>provides latch output.                                                                                                                                                                                                |
| PB0-PB7 | 8<br>(69-76)            | I/O<br>3-state    | The general-purpose I/O port (port B) which can be set by program for input or output on a bit basis. When it is set for output, it provides latch output.                                                                                                                                                                                                      |
| PC0-PC7 | 8<br>(53-60)            | I/O<br>3-state    | The general-purpose I/O port (port C) which can be set by program for input or output on a bit basis. When it is set for output, it provides latch output.                                                                                                                                                                                                      |
| PD0-PD7 | 8<br>(88-89)<br>(91-96) | I/O<br>3-state    | The general-purpose I/O port (port D) which can be set by program for input or output on a bit basis. When it is set for output, it provides latch output.                                                                                                                                                                                                      |
| PEO-PE7 | 8<br>(78-85)            | I/O<br>3-state    | The general-purpose I/O port (port E) which can be set by program for input or output on a bit basis. When it is set for output, it provides latch output.                                                                                                                                                                                                      |
| M1      | 1<br>(25)               | Output<br>3-state | Machine cycle 1 signal pin. In an Op code fetch cycle, this pin goes<br>"0" with the MREQ signal. At the execution of a 2-byte Op code,<br>this pin goes "0" for each operation fetch. In a maskable<br>interrupt acknowledge cycle, this pin goes "0" with the IORQ<br>signal. When the EV signal is applied, this pin is put in the high-<br>impedance state. |
| RD      | 1<br>(19)               | Output<br>3-state | The read signal pin. This signal indicates that the MPU is ready for<br>accepting data from memory or an I/O device. The data from the<br>addressed memory or I/O device is gated by this signal onto the<br>MPU data bus.<br>When the BUSREQ signal is applied, this pin is put in the high<br>impedance state.                                                |
| WR      | 1<br>(20)               | Output<br>3-state | The write signal pin. This signal active when the data to be stored<br>in the addressed memory or I/O device is on the data bus. When<br>the BUSREQ signal is applied, this pin is put in the high-impedance<br>state.                                                                                                                                          |
| MREQ    | 1<br>(17)               | Output<br>3-state | The memory request signal pin. When the execution address for memory access is on the address bus, this pin goes "0". During a memory refresh cycle, this pin also goes "0" with the RFSH signal.                                                                                                                                                               |

(2/3)

| Pin                        | Number       | Туре              | Function                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|--------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ĪORQ                       | 1<br>(18)    | Output<br>3-state | The input/output request signal pin. This pin goes "0" when the address for an I/O operation is on the low-order 8 bits (A0 through A7) for the address bus. The IORQ signal is also output with the M1 signal at interrupt acknowledge to tell an I/O device that it can put the interrupt response vector onto the data bus.                                               |
| WAIT                       | 1<br>(22)    | Input             | The wait request signal pin. This signal indicates to MPU that the addressed memory or I/O device is not ready for data transfer. As long as this signal is "0", the MPU continues to be in the wait state.                                                                                                                                                                  |
| BUSREQ                     | 1<br>(23)    | Input             | The bus request signal pin. The $\overline{\text{BUSREQ}}$ signal forces the MPU address bus, data bus, and control signals $\overline{\text{MREQ}}$ , $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ , and $\overline{\text{WR}}$ to get in the high-impedance state. This signal is normally wire-ORed and required an external pullup resistor for these applications. |
| BUSACK                     | 1<br>(21)    | Output            | The bus acknowledge signal pin. In response to the BUSREQ signal, the BUSACK signal indicates to the requesting peripheral LSI that the MPU address bus, data bus, and control signals MREQ, IORQ, RD, and WR have been put in the high-impedance state.                                                                                                                     |
| HALT                       | 1<br>(16)    | Output<br>3-state | The halt signal pin. This pin goes "0" when the MPU has executed<br>a HALT instruction and is in the halt state. It is put in the high-<br>impedance state when the EV signals is applied.                                                                                                                                                                                   |
| RFSH                       | 1<br>(26)    | Output            | The refresh signal pin. When the dynamic memory refresh address is on the low-order 7 bits of the address bus, this signal goes "0". At the same time, the $\overline{\text{MREQ}}$ signal also goes active ("0").                                                                                                                                                           |
| EV                         | 1<br>(15)    | Input             | The evaluator signal pin. When "1" is applied to this pin, the $\overline{M1}$ and $\overline{HALT}$ pins are put in the high-impedance state. In using the TMPZ84C011A for an evaluator chip, giving the signal with BUSREQ electrically disconnects the MPU section and the chip operates following the instructions from other MPUs (such as the MPU of the ICE).         |
| TEST                       | 1<br>(86)    | Input             | The test signal pin. Normally, this pin should be "0".                                                                                                                                                                                                                                                                                                                       |
| CLK/TRG0<br>\$<br>CLK/TRG3 | 4<br>(2-5)   | Input             | The external clock/timer trigger input pins. These 4 CLK/TRG pins correspond to 4 channels. In the counter mode, the down-counter is decremented by 1 and, in the timer mode, the timer is activated by each active edge (a rising of falling edge) which are input at these pins. Whether the active edge is a rising or falling edge can be selected by program.           |
| ZCT/O0<br>۶<br>ZCT/02      | 3<br>(97-99) | Output            | The zero count/time out signal output pin. In either the timer<br>mode or counter mode, pulses are output from these pins when<br>the counter value has reached zero.                                                                                                                                                                                                        |

|                |                           |                 | (3/3)                                                                                                                                                                                                                                                                                                                                                                     |
|----------------|---------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin            | Number                    | Туре            | Function                                                                                                                                                                                                                                                                                                                                                                  |
| IEI            | 1<br>(1)                  | Input           | The CTC interrupt enable input signal pin. This signal indicates whether there is an interrupt by an upper peripheral LSIs in daisy-chaining.                                                                                                                                                                                                                             |
| IEO            | 1<br>(87)                 | Output          | The CTC interrupt enable output signal pin. This signal controls<br>the interrupts by lower peripheral LSIs in daisy chaining. This<br>signal goes high only when the IEI pin is high and the MPU is not<br>servicing the interrupt from the channel in the CTC.                                                                                                          |
| XTAL1<br>XTAL2 | 2<br>(49)<br>(48)         | Input<br>Output | The crystal oscillator connection pins.<br>Connect a resonator whose oscillation frequency is double the<br>system clock (CLK output) frequency.                                                                                                                                                                                                                          |
| MS1<br>MS2     | 2<br>(47)<br>(46)         | Input           | The mode select input pins. The states of these 2 pins determine one of the 3 modes (Run, Idle, and Stop).                                                                                                                                                                                                                                                                |
| CLK            | 1<br>(52)                 | Output          | The single-phase clock output pin. When the HALT instruction is executed in the Stop or Idle mode, the MPU and the CTC stop operating with the clock (CLK) output held at "0". This output is used for the clock to other peripheral LSIs                                                                                                                                 |
| RESET          | 1<br>(24)                 | Input           | The reset signal input pin. This signal is commonly given to the MPU, CTC, I/O and CGC. It is also used for the restart signal from the halt state.                                                                                                                                                                                                                       |
| INT            | 1<br>(14)                 | Input           | The maskable interrupt request signal pin. The interrupt is caused<br>by the CTC or peripheral LSIs. The interrupt is accepted when the<br>interrupt enable flip-flop (IFF) is set to "1" by software. The INT<br>pin is normally wire-ORed, requiring to attach a pullup resistor<br>externally. This signal is also used for the restart signal from the<br>halt state. |
| NMI            | 1<br>(45)                 | Input           | The non-maskable interrupt request signal pin. This interrupt request has a higher priority than a maskable interrupt and independent of the interrupt enable flip-flop (IFF) state.                                                                                                                                                                                      |
| vcc            | 3<br>(27, 51, 90)         |                 | The power supply pin ( + 5 V).                                                                                                                                                                                                                                                                                                                                            |
| VSS            | 4<br>(28, 50, 77,<br>100) |                 | The ground pin (0 V).                                                                                                                                                                                                                                                                                                                                                     |
### TOSHIBA

110489

# 3. OPERATIONAL DESCRIPTIONS

## 3.1 ENTIRE BLOCK DIAGRAM AND OPERATION OF EACH BLOCK

#### 3.1.1 Entire Block Diagram





#### MPUZ80-302

### 3.1.2 Operation of Each Block

The TMPZ84C011A largely consists of a processor (MPU), a counter/timer circuit (CTC), an input/output port section (I/O), and a clock generator/controller (CGC).

- The MPU has all pins of the Toshiba TLCS-Z80 MPU, and its function is fully compatible with TLCS-Z80 microprocessor.
- The CTC provides the capabilities of the Toshiba TLCS-Z80 CTC (TMPZ84C30A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The four independent timer channels are I/O-addressed internally. It also has the IEI and IEO pins required for the daisy-chain interrupt to provide daisy-chaining with other peripheral LSIs.
- The I/O consists of 5 general-purpose I/O ports, each made up of 8 bits. Each port can be specified by program for input or output on a bit basis. The 5 ports are assigned with I/O addresses, which are specified by program to make the ports perform I/O operations. When these ports are used for output ports, the output is latched, so that the data once output is held as it is until changed.
- The CGC provided the 3 kinds of operation modes to control the entire TMPZ84C011A chip; the Run, Idle, and Stop modes. The CGC provides the same function as the Toshiba TLCS-Z80 CGC (TMPZ84C60) and has the pin to select the Run, Idle, or Stop mode.
  - In the Run mode, the clock generated by the CGC is supplied to the TMPZ84C011A and peripheral LSIs to perform the normal programmed microcomputer operations.
  - In the Idle mode, clock oscillation is going on but the clock is not supplied to the TMPZ84C011A and peripheral LSIs, thereby saving the system power consumption. This mode shortens the time required for system restart.
  - In the Stop mode, clock oscillation is not performed and the system operation can be stopped completely. In this mode, the system can be restarted with the internal data retained with an extremely low power consumption level unique to the CMOS technology.Note that these modes can be set only when the MPU has executed a HALT instruction.
- Additionally, the TMPZ84C011A has also the EV pin which is used to put the MPU in the high-impedance state for electrical disconnection, thus providing an evaluator chip. That is, the MPU in the TMPZ84C011A is electrically disconnected by the EV pin and the BUSREQ pin to implement the emulation by the signal from the in-circuit emulator (ICE).

#### 3.2 MPU OPERATIONS

This subsection describes the system configuration, functions and the basic operations of the MPU of the TMPZ84C011A.

### 3.2.1 Block Diagram

Figure 3.2.1 shows the block diagram of the MPU.



Figure 3.2.1 MPU Block Diagram

### 3.2.2 MPU System Configuration

The MPU has the configuration shown in Fig. 3.2.1. The address signal is put on the address bus via the address buffer. The data bus is controlled for input or output by the data bus interface. Both the address and data buses are put in the high-impedance state by the BUSREQ signal input to make them available for other peripheral LSIs. The Opcode read from memory via the data bus is written to the instruction register. This Opcode is decoded by the instruction decoder. According to the result of the decoding, control signals are sent to the relevant devices. Receiving these control signals, the ALU performs various arithmetic operations. The register array temporarily holds the information required to perform a given operation.

The following describes the MPU's internal registers and functions:

[1] Internal Register Groups

The configuration of the internal register groups is as follows:

(1) Main registers

A, F, B, C, D, E, H, L

(2) Alternate registers

A', F', B', C', D', E', H', L'

(3) Special registers

I, R, IX, IY, SP, PC

Figure 3.2.3 shows the configuration of the internal register groups. The register groups, each being of a static RAM, consists of eighteen 8 bit registers and four 16-bit registers. The following describes the function of each register:

- (1) Main registers (A, F, B, C, D, E, H, L)
  - (a) Accumulator (A)

The accumulator is an 8-bit register used for arithmetic and data transfer operations.

(b) Flag register (F) (see Figure 3.2.2)

The flag register is an 8-bit register to hold the result of each arithmetic operation. Actually, the 6 of the 8 bits are set ("1")/reset ("0") according to the condition specified by an instruction.

| TOSHIBA | 4                           |       |        |            |         |           |                                       |       | TMPZ84C011A     |
|---------|-----------------------------|-------|--------|------------|---------|-----------|---------------------------------------|-------|-----------------|
|         |                             |       |        |            |         |           |                                       |       |                 |
|         | MSB                         |       |        |            |         |           |                                       | LSB   |                 |
|         | 7                           | c     | F      | 4          | 2       | 2         | 1                                     | 0     | ``              |
|         | S                           | Z     | *      | 4<br>H     | *       | 2<br>P/V  | <br>N                                 | C     | (* = Undefined) |
|         | L                           |       |        | <b>.</b>   | I       |           |                                       | L     |                 |
|         |                             |       | Figure | 3.2.2 Fl   | lag Reg | ister Cor | nfigrati                              | on    | 270405          |
|         |                             |       | 5      |            | 5 5     |           | 5                                     |       |                 |
|         |                             |       |        |            |         |           |                                       |       |                 |
|         |                             |       | MSB    |            | LSB MS  | SB        | LSB                                   |       |                 |
|         |                             |       |        | cumulate   | 0/      | Elag rog  | ictor                                 | )<br> |                 |
|         |                             |       |        | A          |         | Flag leg  | ister                                 |       |                 |
|         | General-purpose<br>register |       | - [    |            |         |           |                                       |       | in register     |
| G       |                             |       |        | <u>B</u>   |         | C         |                                       | 4     |                 |
| re      |                             |       |        | D          |         | E         |                                       |       |                 |
|         |                             | l     | _ L    | н          |         | L         | ·····                                 |       |                 |
|         |                             |       | Ac     | cumulato   | or      | Flag reg  | ister                                 | ] ]   |                 |
|         |                             |       |        | Α'         |         | F′        |                                       |       |                 |
|         |                             |       | [      |            |         |           |                                       |       |                 |
|         |                             |       |        | B          |         | C         |                                       |       | ernate register |
|         |                             |       |        |            |         | E         |                                       | 4     |                 |
|         |                             |       |        | H          |         | Ľ.        | A                                     |       |                 |
|         |                             |       | Inte   | rrupt vec  | tor     | Memory re | efresh                                | 1 7   |                 |
|         |                             |       |        | 1          |         | R         |                                       |       |                 |
|         |                             |       | MSB    |            |         |           |                                       | LSB   |                 |
|         |                             |       | Inc    | dex regist | er      | D         | <                                     | Spi   | ecial register  |
| Ge      | eneral-pu                   | rpose | Inc    | dex regist | er      | <br> `    | · · · · · · · · · · · · · · · · · · · |       |                 |
| re      | gister                      |       | Sta    | ack point  | er      | S         | P                                     | 1     |                 |
|         |                             |       | Pro    | ogram co   | unter   | Р         | с                                     |       |                 |
|         |                             | 1     | L L    |            |         |           |                                       | L     |                 |



The following 4 bits are directly available to the programmer for setting the jump, call and return instruction conditions:

Sign flag (S)

When the result of an operation is negative, the S flag is set to "1". Actually, the content of bit 7 of accumulator is stored in this flag.

Zero flag (Z)

When all bits turn out to be "0" after operation, the Z flag is set to "1". Otherwise, it is set to "0". With a block search instruction (CPI, CPIR, CPD or CPDR), the Z flag is set to "1" if the source data and the accumulator data match. With a block I/O instruction (INI, IND, OUTI or OUTD), the Z flag is set to "1" if the content of the B register used as the byte counter is "0" at the end of comparison.

#### Parity overflow flag (P/V)

This flag has two functions. One is the parity flag (P) that indicates the result of a logic operation (AND A,B etc.). The P flag is set to "1" if the parity is even as a result of the operation on signed values by two's complement. It is set to "0" is the parity is odd. With a block search instruction (CPI, CPIR, CPD or CPDR) and a block transfer instruction (LDI or LDD), the P flag indicates the state of the byte counter (register pair BC). It is set to "1" if the byte counter is not "0" and to "0" when the byte counter becomes "0" (at the end of comparison or data transfer). The content of the interrupt enable flip-flop (IFF) is saved to the P flag when the contents of the R register or I register are transferred to the accumulator.

The other use of the P/V flag is the overflow flag (V) that indicates whether an overflow has occurred or not as a result of an arithmetic operation. The V flag is set to "1" when the value in the accumulator gets out of a range of the maximum value +127 and the minimum value -128 and therefore cannot be correctly represented as a two's complement notation.

Whether the P/V flag operates as the P flag or V flag is determined by the type of the instruction executed.

Carry flag (C)

The C flag is set to "1" if a carry occurs from bit 7 of the accumulator or a borrow occurs as a result of an operation.

The following two flags are not available to the programmer for the test and set ("1")/reset ("0") purposes. They are internally used by the MPU for BCD arithmetic operations.

### Half carry flag (H)

The H flag is used for holding the carry or borrow from the low-order 4 bits of a BCD operation result. When a DAA instruction (decimal adjust) is executed, the MPU automatically uses the H flag to adjust the result of a decimal addition or subtraction.

### Add/subtract flag (N)

In BCD operation, algorithm is different between addition and subtraction. The N flag indicates whether the executed operation is addition or subtraction. For how the flags change depending on the instruction, see 3.2.4 "TMPZ84C011A

Instruction Set".

### (c) General-purpose registers (B, C, D, E, H, L)

General-purpose registers consist of 8 bits each. They are used as 16-bit register pairs (BC, DE, HL) as well as separate 8-bit registers to supplement the accumulator. The B register and the register pair BC are used as a counter when a block I/O, block transfer, or search instruction is executed. The register pair HL has various memory addressing features as compared with the register pairs BC and DE.

### (2) Alternate registers (A', F', B', C', D', E', H', L')

The configuration of the alternate registers is exactly the same as that of the main registers. There is no instruction that handles the alternate registers directly. The data in the alternate registers are processed by moving them into the main registers by means of exchange instructions as shown below:

 $\begin{array}{ll} EX AF, AF' & (A \leftrightarrow A', F \leftrightarrow F') \\ EXX & (B \leftrightarrow B', C \leftrightarrow C', D \leftrightarrow D', E \leftrightarrow E', H \leftrightarrow H', L \leftrightarrow L') \end{array}$ 

When a high-speed interrupt response has been requested within the system, these instructions can be used to quickly move the data from the accumulator, flag registers, and general-purpose registers on the main or alternate side into the corresponding registers. This eliminates the need for transferring the register contents to/from the external stack during execution of the interrupt handling routine, thereby shortening the interrupt servicing time greatly.

# TOSHIBA

- (3) Special registers (I, R, IX, IY, SP, PC)
  - (a) Interrupt page address register (I)

The TMPZ84C011A provides two kinds of interrupts: maskable interrupt ( $\overline{INT}$ ) and non-maskable interrupt ( $\overline{INI}$ ). The maskable interrupt provides three modes (0, 1, and 2) in which the interrupt is handled. These modes can be selected by instructions IM0, IM1, and IM2 respectively. In mode 2, any memory location can be called indirectly depending on the interrupt. For this purpose, the I register stores the high- order 8 bits of the indirect address. The low-order 8 bits are supplied from the interrupting peripheral LSI. This scheme permits calling the interrupt handling routine from any memory location in an extremely short access time. For the details of interrupts, see (IV) "Interrupt Capability".

(b) Memory refresh register (R)

The R register is used as the memory refresh counter when the dynamic RAM is used for memory. This perimits using of the dynamic memory in the same manner as the static memory. This 8- bit register is automatically incremented for each instruction fetch. While the MPU decoder executes the fetched instruction, the contents of the R register are synchronized with the refresh signal to place the loworder 7 bits on the address bus. This operation is all performed by the MPU and, therefore, need not perform a special processing by program. The MPU operation is not delayed by this operation. During refresh, the contents of the I register are placed on the high-order 8 bits of the address bus.

(c) Index registers (IX, IY)

The two independent index registers IX and IY holds the 16-bit base address when used in the index addressing mode. In this addressing mode, the memory address obtained by adding the contents of an index register to the displacement value (for example, LD IX + 40H) is specified. This mode is convenient for using data tables. Also these registers can be used separately for memory addressing and data retaining registers.

#### (d) Stack pointer (SP)

The stack pointer is a 16-bit register to provide the start address information in the stack area in the external RAM. The content of the stack pointer is decremented at the execution of a call instruction or PUSH instruction or interrupt handling and is incremented at the execution of a return instruction or POP instruction. At the execution of a call instruction or interrupt handling, the current content of the program counter is saved into the stack. At the execution of a return instruction, the content is restored from the stack to the program counter. These operations are all pereformed by the MPU automatically. However, the other registers are not saved or restored automatically. For the storing of these registers, alternate register exchange instruction (EX and EXX) or a PUSH and a POP instructions must be used. When a PUSH instruction is executed, the contents of the specified register are saved into the stack. When a POP instruction is executed, the contents of the stack are moved to the specified register.

These data are restored on a last-in, first-out basis. Use of the stack permits processing of multiple-level interrupts, very deep subroutine nestings, and various data manipulation very easily. The stack pointer is not initialized in the hardware approach. Therefore, it is required to specify initialization (to the highest address in the stack) in the initialization program by allocating the stack area in RAM in during programming.

| MEMO | DRY AI<br>(HEX) | DDRES<br>) | s<br>I         | M E M O R Y<br>ADDRESS<br>(HEX) |                   |       | SP Va<br>befo<br>Execu | alue<br>ore<br>tion |      |
|------|-----------------|------------|----------------|---------------------------------|-------------------|-------|------------------------|---------------------|------|
| Low  |                 |            | Save direction | 1230                            | CALL              | 1500H | FFF1                   |                     |      |
| ∳ F  | FEB             | CO         | 1              |                                 |                   |       |                        |                     |      |
| F F  | FED             | 23         |                | 1500                            | PUSH              | AF    | FFEF                   | A=05                | F=23 |
| ı F  | FEE             | 05         |                | 1501                            | PUSH              | ы     | FFED                   | D-DZ                | L-CU |
| F    | FEF             | 33         |                |                                 |                   |       |                        |                     |      |
| ¥ 1  | ·FF0            | 12         | Destant        | 1600                            |                   | PC    | CCCD                   |                     |      |
| High |                 |            | direction      | 1601<br>1602                    | POP<br>POP<br>RET | AF    | FFED                   |                     |      |
|      | 1               |            | 1              |                                 |                   |       |                        |                     |      |

The above example shows the stack pointer and stack operations in which the instructions starting with the CALL at address 1230H and ending at with the RET at address 1602H have been executed. However, it is assumed that there is no instruction or interrupt other than shown above that uses the above stack during the execution. When the value of the stack pointer before executing the CALL instruction at address 1230H indicates address FFF1H, address 1233H is stored at addresses FFF0H and FFEFH because the CALL instruction consists of 3 bytes, then the stack pointer is decremented. Similarly, the data are saved or restored sequentially according to the instructions. These stack and stack pointer operations are all performed automatically.

(e) Program counter (PC)

The program counter holds, in 16 bits, the memory address of the instruction to be executed next. The MPU fetches the instruction from the memory location indicated by the program counter. When the content of the program counter is put on the address bus, the program counter is incremented automatically. However, it is not incremented with a jump instruction, a call instruction, or interrupt processing. Instead, the specified new address set on it. With a return instruction, the content restored from the stack is set on the program counter. These operations are all performed automatically and therefore, transparent to the programmer.

### [2] Halt capability

When a HALT instruction has been executed, the MPU is put in the halt state. The halt capability can be used to halt the MPU against the external interrupts, thereby reducing the power dissipation. In the halt state the states of MPU's internal registers are all retained. The halt state is cleared by reset or when an interrupt is accepted. For the details of halt operation, see [3] "Basic Timing".

#### (1) Halt operation

When a HALT instruction has been executed, the MPU sets the  $\overline{\text{HALT}}$  signal to "0" to tell the outside that the MPU is going to get in the halt state. Actually, the MPU in the halt state continues executing NOPs if there is the system clock input. However, the program counter is not incremented. This keeps the refresh signal generated when the dynamic memory is used. During halt, the MPU's internal states are retained. The TMPZ84C011A contains the clock generator/controller, easily implementing the clock input control for these halt operations.

(2) Clearing the halt state

The halt state is cleared by accepting an interrupt (the  $\overline{INT}$  or  $\overline{NMI}$  signal input) or by reset (the  $\overline{RESET}$  signal input). When an interrupt is accepted, the halt state is cleared and the interrupt handling routine is executed. However, a maskable interrupt (INT) cannot be accepted unless the interrupt enable flip-flop (IFF) is set.

Note that when the halt state is cleared by the  $\overline{\text{RESET}}$  signal, the MPU is reset and the program counter is set to "0".

[3] RESET Signal

Holding the  $\overline{\text{RESET}}$  pin at the low level ("0") under the following conditions, the MPU's internal states are reset:

- (1) The power voltage level is within the operational voltage range.
- (2) System clock stabilization.
- Holding the RESET signal at the low level ("0") for at least 3 full clock cycles.
  When the RESET signal goes high ("1"), the MPU starts executing instructions from address 0000H after at least 2T state dummy cycles.
  When reset, the MPU performs the following processing:
- Program counter

0000H is set.

Interrupt

The interrupt enable flip-flop (IFF) is reset to "0" to disable the maskable interrupt. For the maskable interrupt processing, mode 0 is specified.

Control output

All control outputs are made inactive ("1"). Therefore, the halt state is also cleared.

Interrupt page address register (I register)

The content of the I register becomes 00H.

• Refresh register (R register)

The content of the R register becomes 00H.

The registers other than above and the external memory do not change. Therefore, they must be initialized as required.

#### [4] Interrupt Capability

The interrupt capability is used to pause the execution of the currently executed program upon request from a peripheral LSI, executing the requested processing before. Normally, this interrupt processing routine contains the data exchange and transfer of status and control information between the MPU and the peripheral LSI. When this routine has been completed, the MPU returns to the state before the interrupt was accepted.

The TMPZ84C011A provides the non-maskable interrupt (NMI) and maskable interrupt (INT) capabilities which are detected by the  $\overline{\rm NMI}$  and  $\overline{\rm INT}$  interrupt request signals, respectively. A non- maskable interrupt, when caused by a peripheral LSI, is accepted unconditionally. This interrupt is used to support critical functions such as the protection of the system from unpredictable happening including power outages. A maskable interrupt can be enabled or disabled by program. For example, if the timer is used and, therefore, an interrupt is not desired, the system can be programmed to disable the interrupt. Table 3.2.1 lists the processing by interrupt cause.

(1) Interrupt enable/disable

A non-maskable interrupt cannot be disabled by program, while a maskable interrupt can be enabled or disabled by program. The MPU has the interrupt enable flip-flop (IFF). A maskable interrupt can be enabled or disabled by setting this flip-flop to "1" (set) or "0" (reset) through an EI instruction (enable) or a DI instruction (disable) in program. Actually, the IFF consists of two flip-flops IFF1 and IFF2. IFF1 is used to select between the enable and disable of a maskable interrupt. IFF2 holds the state of IFF1 effective before a nonmaskable interrupt has been accepted. Both IFF1 and IFF2 are reset to "0" when any of the following conditions occurs, disabling an interrupt:

Actually, the waiting maskable interrupt request is accepted after the execution of the instruction that follows the EI instruction. This delay by one instruction is caused by accepting an interrupt after completion of the execution of a return instruction if the instruction following the EI instruction is a return instruction. In the following operations, the contents of IFF1 and IFF2 are the same.

- MPU reset
- Execution of DI instruction
- Acceptance of maskable interrupt

Both IFF1 and IFF2 are set to "1" when the following condition occurs, enabling an interrupt:

• Execution of EI instruction

110489

| Interrupt Source                               | Priority | Programmed condition |        | Vector address            | Interrupt<br>return<br>instruction |
|------------------------------------------------|----------|----------------------|--------|---------------------------|------------------------------------|
| Non-maskable interrupt                         | 1        | No                   | one    | Address 66H               | RETN                               |
| (the falling edge of $\overline{\text{NMI}}$ ) |          |                      |        |                           |                                    |
|                                                |          |                      |        | Instruction from          |                                    |
| Maskable interrupt                             | 2        | IFF = 1              | Mode 0 | peripheral LSI.           | (Note)                             |
| (INT becomes "0" at                            |          |                      |        | Normally, CALL or RST     | RETI                               |
| instruction's last clock)                      |          |                      |        | instruction.              |                                    |
|                                                |          |                      | Mode 1 | Address 38H.              |                                    |
|                                                |          |                      |        | The address indicated by  |                                    |
|                                                |          |                      |        | the data table (memory)   |                                    |
|                                                |          |                      | Mode 2 | at the address specified  |                                    |
|                                                |          |                      |        | by I register (high-order |                                    |
|                                                |          |                      |        | 8 bits) and data from     |                                    |
|                                                |          |                      |        | peripheral LSI (low-      |                                    |
|                                                |          |                      |        | order 8 bits, LSB = "0"). |                                    |

Table 3.2.1 Processing by Interrupt Cause

Note: Mode 0 applies when the instruction from peripheral LSI is CALL or RST instruction.





MPUZ80-314

When a non-maskable interrupt has been accepted, IFF1 is reset to "0" (interrupt disable) until an EI or RETI instruction is executed to prevent a next interrupt accepting. For this purpose, the state (interrupt enable/disable) of IFF1 immediately before non-maskable interrupt acceptance must be stored. This state is copied into IFF2 upon acceptance of a non-maskable interrupt. The content of IFF2 is copied into the parity flag at the execution of the following instructions, so that the copied data can be tested or stored:

- The load instruction (LD A, I) to load from the I register to the accumulator.
- The load instruction (LD A, R) to load from the R register to the accumulator.

When the return instruction from the non-maskable interrupt (RETN) is executed, the content of IFF2 is copied back to IFF1. If an operation which changes the contents of IFF2 (due to the execution of EI or DI instruction, for example) has not been performed during interrupt handling. IFF1 automatically returns to the state which was effective immediately before the interrupt acceptance. Table 3.2.1 lists the states of IFF1 and IFF2 after the execution of interrupt- related instructions.

| Operation sequence   | IFF1 | IFF2 | Remarks          |  |  |  |  |  |  |  |
|----------------------|------|------|------------------|--|--|--|--|--|--|--|
| MPU reset            | 0    | 0    |                  |  |  |  |  |  |  |  |
| El                   | 1    | 1    |                  |  |  |  |  |  |  |  |
| NMI acceptance       | 0    | 1    |                  |  |  |  |  |  |  |  |
| LD A, I              | *    | *    | Parity flag←IFF2 |  |  |  |  |  |  |  |
| RETN                 | 1    | 1    | IFF1←IFF2        |  |  |  |  |  |  |  |
| LD A, R              | *    | *    | Parity flag←IFF2 |  |  |  |  |  |  |  |
| INT acceptance       | 0    | 0    |                  |  |  |  |  |  |  |  |
| RETI                 | *    | *    |                  |  |  |  |  |  |  |  |
| EI                   | 1    | 1    |                  |  |  |  |  |  |  |  |
| NMI acceptance       | 0    | 1    |                  |  |  |  |  |  |  |  |
| DI                   | 0    | 0    |                  |  |  |  |  |  |  |  |
| RETN                 | *    | *    |                  |  |  |  |  |  |  |  |
| Note · * = no change |      |      |                  |  |  |  |  |  |  |  |

Table 3.2.1 State of IFF1 and IFF2

Note : \* = no change.

#### (2) Interrupt processing

With a non-maskable interrupt, the internal NMI flip-flop is set to "1" at the falling edge of the interrupt signal, <u>NMI</u>. The state of this flip-flop is sampled at the rising edge of the last clock of each instruction to accept an interrupt. A maskable interrupt is accepted if the interrupt signal INT is low ("0") at the rising edge of the last clock of each instruction and the interrupt enabled state (IFF = 1 and  $\overline{\text{BUSREQ}}$  signal = inactive ("1")) is on. Described below is the processing to be performed after a non-maskable interrupt and a maskable interrupt are accepted:

(a) Non-maskable interrupt (NMI)

When a non-maskable interrupt has been accepted, the MPU performs the following processing:

- ① The internal NMI flip-flop is reset "0".
- ② IFF1 is reset to "0", disabling the maskable interrupt. The contents of the IFF1 immediately before the interrupt acceptance are copied into the IFF2.
- ③ The current contents of the program counter are saved into the stack.
- (1) The instructions starting from non-maskable interrupt vector address 66H are executed.

The non-maskable interrupt processing program terminates by executing the RETN instruction. This return instruction performs the followings:

- ① The contents of the current IFF2 are copied into IFF1.
- 2 The contents of the program counter are restored from the stack.



Figure 3.2.5 Non-Maskable Interrupt Processing

(b) Maskable interrupt (INT)

When a maskable interrupt has been accepted, the MPU performs the following processings:

- ① Both IFF1 and IFF2 are reset to "0", disabling the maskable interrupts.
- 2 The current contents of the program counter are saved into the stack.
- ③ A maskable interrupt is serviced in one of the three modes 0, 1 and 2. A mode is selected by executing the instruction IM0, IM1 or IM2 before the interrupt is serviced. The instructions are executed starting from the vector address corresponding to the selected mode.

## • Mode 0

In mode 0, the interrupting peripheral LSI puts a restart instruction (RST) or a call instruction (CALL) on the data bus and the MPU executes the interrupt service routine according to that instruction.





### • Mode 1

When an interrupt is accepted in mode 1, restart is performed from address 0038H. Therefore, the service routine for this interrupt is programmed from the address 0038H.





#### Mode 2

The interrupt processing in mode 2 requires a 16-bit pointer consisting of the highorder 8 bits of the I register and the low-order 8 bits (with the LSB = "0") of the data captured from the interrupting CTC or TLCS-Z80 family peripheral LSI. Therefore, the necessary value must be loaded in the I register beforehand. This pointer is used to specify the memory address in the table. The contents of the specified addresses and the next address provide the start address of the service routine. Therefore, use of this mode requires to present table of the service routine's start address (16 bits) by program at convenient location. This location can be anywhere in memory. The LSB of the table pointer is set to "0" because a 2-byte data is needed to specify the service routine start address just in 16 bits and start that address from an even-number address. In the table, the start address begins with the low- order byte followed by the high-order byte as shown in Figure 3.2.8



Figure 3.2.8 Interrupt Processing in Mode 2

Mode 2 is used in the daisy chain interrupt processing using the CTC and/or TLCS-Z80 family LSI. The CTC and TLCS-Z80 family perpheral LSIs all contain the interrupt priority controller of daisy chain structure. In this interrupt structure, the interrupt request signals are put in the series order and given priorities for processing when two or more maskable interrupt requests occur at a time. Only the interrupt vector from the peripheral LSI having the highest priority is put on the data bus. By receiving the vector interrupt in mode 2, the processing for that peripheral LSI can be performed. When an interrupt comes from a peripheral LSI having a priority higher than that of the current peripheral LSI during the execution of its interrupt processing routine, the new interrupt can be enabled by the EI instruction to form an interrupt nesting.

The maskable interrupt processing program terminates by executing an RETI instruction. This return instruction performs the following processing:

- Restores the content of the program counter from the stack.
- Notifies the requesting peripheral LSI of the termination of interrupt processing.

### 3.2.3 MPU Status Transition Diagram and Basic Timing

The following describes the MPU status transition and the basic timing of each MPU operation.

[1] Instruction Cycle

Each TMPZ84C011A instruction is executed by combining the basic operations of memory read/write, input/output, bus request/acknowledge, and interrupt. These basic operations are performed in synchronization with the system clock (the CLK signal).

One clock period is called a state (T). The smallest unit of each basic operation is called a machine cycle (M). Each instruction consists of 1 to 6 machine cycles and each machine cycle, 3 to 6 clock states basically. However, the number of clock states in a machine cycle can be increased by the  $\overline{\text{WAIT}}$  signal described later on. Figure 3.2.9 shows an example of the basic timing of a 3-machine-cycle instruction.

The first machine cycle (M1) of each instruction is the cycle in which the Opcode of the instruction to be executed next is read (this is called the Opcode fetch cycle). The Opcode fetch cycle basically consists of 4 to 6 clock states. In the machine cycle that follows the Opcode fetch cycle, data is transferred between the MPU and the memory or peripheral LSIs. This operation basically consists of 3 to 5 clock states.





# TOSHIBA

### [2] Status Transition Diagram



Figure 3.2.10 Status Transition Diagram

#### [3] Basic Timings

(1) Opcode fetch cycle (M1)

In the Opcode fetch cycle, MPU reads an Opcode from among the machinelanguage codes in memory. This is also called the M1 cycle for it is the first machine cycle to execute each instruction.

Figure 3.2.11 shows the basic timing of a basic Opcode fetch cycle. In clock state T1, the content of the program counter is put on the address bus. The  $\overline{\text{M1}}$  signal goes "0", telling the outside the MPU that this is the Opcode fetch cycle. At the same time,  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals go "0". When the  $\overline{\text{MREQ}}$  signal goes "0", the address signal has already been stabilized. Therefore, this signal can be used for the memory chip enable signal. The  $\overline{\text{RD}}$  signal indicates that the MPU is ready to accept the data from memory. By these signals, the MPU accesses memory to put the Opcode in the instruction register. The MPU samples the  $\overline{\text{WAIT}}$  signal at the falling edge of clock state T2. If the  $\overline{\text{WAIT}}$  signal is "0" at the falling edges of clock state T2 and the following wait state (T<sub>W</sub>), the next state becomes clock state T<sub>W</sub>. Figure 3.2.12 shows the delay state of the Opcode fetch cycle caused by the  $\overline{\text{WAIT}}$  signal.

The data (Opcode) on the data bus is fetched at the rising edge of clock state T3 then, at the rising edges of the same state, the  $\overline{\text{MREQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{M1}}$  signals go "1". In clock state T3, a memory refresh address is put on the low-order 7 bits of the address bus and the  $\overline{\text{RFSH}}$  signal goes "0" and the  $\overline{\text{MREQ}}$  signal goes "0" again. This signal indicates that the memory refresh cycle is on. At this time, the contents of the I register are on the high-order 8 bits of the address bus and the 7 bits of the R register contents are on the low-order 7 bits of the address bus. By using the RFSH and  $\overline{\text{MREQ}}$  signals, memory refresh is performed in clock states T3 and T4. However, the  $\overline{\text{RD}}$  signal remains "1" because the contents of the memory refresh address are not put on the data bus.

In clock state T4, the  $\overline{\text{MREQ}}$  signal returns to "1". The refresh address is kept output until the rising edge of the clock state T1 of the next machine cycle, during which the  $\overline{\text{RFSH}}$  signal is also "0". The cycle delay state caused by setting the  $\overline{\text{WAIT}}$  signal to "0" is the same with the memory read/write, input/output, and maskable interrupt acknowledge cycles. The following description the diagram of the cycle delay state caused by the  $\overline{\text{WAIT}}$  signal's going "0" is omitted.





MPUZ80-322

### (2) Memory read/write operations

Figure 3.2.13 shows the basic timing of memory read/write operations (except for the Opcode fetch cycle) in the same diagram for convenience.

In each case, the memory address signal to read/write data on the address bus is output in clock state T1. The operation in which the  $\overline{WAIT}$  signal is sampled in clock state T2 and the following  $T_W$  state is the same as the Opcode fetch cycle.

In memory read, memory data is put on the data bus by the address,  $\overline{\text{MREQ}}$ , and  $\overline{\text{RD}}$  signals. The MPU reads this data.

In memory write, the memory address signals is put on the address bus then the  $\overline{\text{MREQ}}$  signal is set to "0" to put the write data onto the data bus. When the data bus has been stabilized, the  $\overline{\text{WR}}$  signal is output in clock state T2. The  $\overline{\text{WR}}$  signal can be used for the memory write signal.



Figure 3.2.13 Memory Read / Write Cycle Timing

#### (3) Input/output operations

Figure 3.2.14 shows the basic timing of input/output operations. The feature of the I/O operation timing is that, regardless of the state of the WAIT signal in clock state T2, the I/O cycle automatically gets in the wait state  $(T_W^*)$  after clock T2. The WAIT signal is sampled at the falling edge of  $T_W^*$ . If the WAIT signal is "0" at the falling edges of  $T_W^*$  and the following clock state, the I/O cycle moves into clock state  $T_W$ . Clock state  $T_W^*$  is inserted because the  $\overline{IORQ}$  signal goes "0" in clock state T2, so that it is too late to sample the WAIT signal after decoding the I/O port address. In each of input and output operations, the I/O port address is put on the low-order 8 bits of the address bus in clock state T1. On the high-order 8 bits, the contents of the accumulator or B register are output. In clock state T2, the  $\overline{IORQ}$  signal goes "0" instead of the MREQ signal. The  $\overline{IORQ}$  signal can be used as the chip enable signal for a peripheral LSI.

In an input operation, the contents of the input port are read onto the data bus by the address,  $\overline{\text{IORQ}}$ , and  $\overline{\text{RD}}$  signals. The MPU reads this data.

In an output operation, the output port address and the output data are respectively put on the address bus and data bus in clock state T1; the  $\overline{IORQ}$  and  $\overline{WR}$  signals goes "0" in clock state T2. The  $\overline{WR}$  signal can be used as the output port write signal.



Figure 3.2.14 I/O OPperation Timing

(4) Bus request and bus acknowledge operations

Figure 3.2.15 shows the basic timings of bus request and bus acknowledge operations.

The 3-state address bus (A0 through A15), data bus (D0 through D7),  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{WR}}$  signals controlled by the MPU can be put in the highimpedance state (floating) to electrically disconnect them from the MPU. This operation, by sampling the  $\overline{\text{BUSREQ}}$  signal at the rising edge of the last clock of each machine cycle, starts with the rising edge of the next clock if this signal is found "0". Subsequently, these buses are controlled by peripheral LSIs. For example, data can be directly transferred between memory and these peripheral LSIs. This state is cleared if the  $\overline{\text{BUSREQ}}$  signal is found "1" by sampling it at the rising edge of each subsequent clock state ( $T_X$ ), executing the next machine cycle. During the floating state, the  $\overline{\text{BUSACK}}$  signal is "0" to tell the peripheral LSIs of it.

In this state, however, no memory refresh is performed and, therefore, the  $\overline{\text{RFSH}}$  signal is set to "1". Hence, to maintain this state for a long time with a system using dynamic memory, memory refresh must be performed by the external controller.

Note that, in the floating state, neither maskable (INT) nor non-maskable (NMI) interrupts can be accepted.



Figure 3.2.15 Bus Request and Bus Acknowledge Timing

(5) Maskable interrupt acknowledge operation

Figure 3.2.16 shows the basic timing of the maskable interrupt acknowledge.

The MPU samples the maskable interrupt request signal  $(\overline{INT})$  at the rising edge of the last clock of each instruction execution. If the  $\overline{INT}$  signal is found "0", a maskable interrupt is accepted except in the following cases:

- The interrupt enable flip-flop is reset to "0".
- The BUSREQ signal is "0".

When a maskable interrupt has been accepted, a special Opcode fetch cycle is generated. In this cycle, 2 clock states of wait state  $(T_W^*)$  is automatically inserted after the clock state T2. The WAIT signal is sampled at the falling edge of the second clock state  $T_W^*$  and the following clock state  $T_W$  and, if the WAIT signal is found "0", the instruction cycle gets in the next clock state  $T_W$ . In this Opcode fetch cycle, the IORQ signal goes "0" in the first  $T_W^*$  state instead of the MREQ signal while in a normal Opcode fetch cycle the MREQ signal goes "0" in clock state T1. This tells the maskable interrupt requesting LSI that it can put the 8-bit interrupt vector on the data bus, then reads this data to perform interrupt processing. Therefore, the contents of the program counter put on the address bus are not used. Unlike an ordinary I/O operation, the RD signal does not go "0".

In the clock state T3, the memory refresh address signal is put on the address bus for memory refresh like normal Opcode fetch cycle and the  $\overline{\text{RFSH}}$  signal goes "0". In the subsequent machine cycles (M2 and M3), the current contents of the program counter are saved into the stack. In the machine cycles M4 and M5, the contents of the I register (the high-order 8 bits) and the contents of the address indicated by the address of the vector (the low-order 8 bits) from the CTC or the peripheral LSIs connected externally are put in the program counter.



Figure 3.2.16 Maskable Interrupt Acknowledge Timing

#### (6) Non-maskable interrupt acknowledge operation

Figure 3.2.17 shows the basic timing of non-maskable interrupt acknowledge.

When the non-maskable interrupt request signal ( $\overline{\text{NMI}}$ ) goes low, the internal non-maskable flip-flop is set to "1". The  $\overline{\text{NMI}}$  signal is detected in any timing of each instruction. However, the internal NMI flip-flop is sampled at the rising edge of the last clock of each instruction. Therefore, the  $\overline{\text{NMI}}$  signal should go low until the last clock state of an instruction

The Opcode fetch cycle for non-maskable interrupt acknowledge is generally the same as the ordinary Opcode fetch cycle. However, the Opcode on the data bus at the time is ignored. The current contents of the program counter are saved into the stack in the subsequent machine cycles (M2 and M3). In the following machine cycle, the operation jumps to address 0066H, the non-maskable interrupt vector address. The machine cycles after these depend on the contents of the fetched Opcode.

# TOSHIBA



Figure 3.2.17 Non-Maskable Interrupt Acknowledge Timing

#### (7) Halt operation

Having fetched a HALT instruction in the Opcode fetch cycle, the MPU sets the  $\overline{\text{HALT}}$  signal to "0" in synchronization with the falling edge of clock state T4 to tell peripheral LSIs of the fetch and stops operating. if the system clock is kept supplied in the halt state, the MPU continues executing NOP instructions. This is done to output refresh signals when the memory is used. The NOP instruction execution cycle is the same as the ordinary Opcode fetch cycle in which the data on the data bus are ignored.

The halt state is cleared when an interrupt is accepted or the RESET signal is set to "0" to reset the MPU. Figure 3.2.18 shows the halt state clear operation by interrupt acknowledge. An interrupt is sampled at the rising edge of the last clock (clock state T4) of the NOP instruction. A maskable interrupt can be accepted when the INT signal is "0". A non-maskable interrupt is accepted when the internal NMI flip-flop which is set at the falling edge of the  $\overline{\text{NMI}}$  signal is set at "1". However, it is required that the interrupt enable flip-flop is set to "1" for a maskable interrupt to be accepted. The interrupt processing for the type of the accepted interrupt gets started from the following cycle.

However, when the supply of the system clock from the CGC has been stopped by the power down operation, it is required to restart the supply of the system clock and input the INT signal until the execution of one instruction is completed or the RESET signal at least 3 clocks are output. Figure 3.2.9 shows the timing of clearing the halt state caused by power down.

For the reset opration, see (8) "Reset operation" below. Note that the  $\overline{INT}$  and  $\overline{NMI}$  signals are shown on the same diagram in Figures 3.2.18 and 3.2.19 for convenience.



Figure 3.2.18 Timing of Clearing Halt State Caused by Interrupt Acknowledge



Figure 3.2.19 Timing of Clearing Halt State Caused by Power Down

### (8) Reset opration

Figure 3.2.20 shows the basic timing of reset operation.

To reset the MPU, the  $\overline{\text{RESET}}$  signal must be kept at "0" for at least 3 clocks. When the  $\overline{\text{RESET}}$  signal goes "1", instruction execution starts from address 0000H after a dummy cycle of at least 2 clock states.



120489

Figure 3.2.20 Reset Timing

To clear the power down state by the <u>RESET</u> signal, the <u>RESET</u> signal must be input until 3 clocks or more are supplied by restarting the supply of the system clock from the CGC.

### (9) Evaluation operation

Each of the MPU signals (A0 through A15, D0 through D7,  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{HALT}}$  and  $\overline{\text{M1}}$ ) can be put in the high-impedance state by EV and  $\overline{\text{BUSREQ}}$  signals to electrically disconnect them from the system.



Figure 3.2.21 Evaluation Timing



120489

# Figure 3.2.22 Block Diagram of the TMPZ84C011A Functioning As Evaluator

### TOSHIBA

### 3.2.4 TMPZ84C011A Instruction Set

This subsection lists the TMPZ84C011A instruction codes and their functions. The table below lists the symbols and abbreviations used to describe the instruction set. The symbols which require special attention are described in the locations in which they appear.

### • Symbols (1/2)

| Classification | Symbol          | Meaning                                       |  |  |  |  |  |  |  |  |
|----------------|-----------------|-----------------------------------------------|--|--|--|--|--|--|--|--|
| Register       | r, g            | Register B, C, D, E, H, L, A,                 |  |  |  |  |  |  |  |  |
|                | t               | Register pair BC, DE, HL                      |  |  |  |  |  |  |  |  |
|                |                 | Stack pointer SP                              |  |  |  |  |  |  |  |  |
|                | q               | Register pair BC, DE, HL, AF                  |  |  |  |  |  |  |  |  |
|                | р               | Register pair BC, DE                          |  |  |  |  |  |  |  |  |
|                |                 | Index register IX                             |  |  |  |  |  |  |  |  |
|                |                 | Stack pointer SP                              |  |  |  |  |  |  |  |  |
|                | S               | Register pair BC, DE                          |  |  |  |  |  |  |  |  |
|                |                 | Index register IY                             |  |  |  |  |  |  |  |  |
|                |                 | Stack pointer SP                              |  |  |  |  |  |  |  |  |
|                | t <sub>H</sub>  | Higher register of register pair              |  |  |  |  |  |  |  |  |
|                | (E              |                                               |  |  |  |  |  |  |  |  |
|                |                 | Higher 8 bits of stack pointer (SP)           |  |  |  |  |  |  |  |  |
|                | qн              | Higher register of register pair              |  |  |  |  |  |  |  |  |
|                |                 | (B, D, H, A)                                  |  |  |  |  |  |  |  |  |
|                | IX <sub>H</sub> | Higher 8 bits of index register IX            |  |  |  |  |  |  |  |  |
|                | IY <sub>H</sub> | Higher 8 bits of index register IY            |  |  |  |  |  |  |  |  |
|                | PCH             | Higher 8 bits of program counter (PC)         |  |  |  |  |  |  |  |  |
|                | tL              | Lower register of register pair               |  |  |  |  |  |  |  |  |
|                |                 | (C, E, L)                                     |  |  |  |  |  |  |  |  |
|                |                 | Lower 8 bits of stack pointer (SP)            |  |  |  |  |  |  |  |  |
|                | qL              | Lower register of register pair               |  |  |  |  |  |  |  |  |
|                |                 | (C, E, L, F)                                  |  |  |  |  |  |  |  |  |
|                | IXL             | Lower 8 bits of index register IX             |  |  |  |  |  |  |  |  |
|                | IYL             | Lower 8 bits of index register IY             |  |  |  |  |  |  |  |  |
|                | PCL             | Lower 8 bits of program counter (PC)          |  |  |  |  |  |  |  |  |
|                | rb              | Bit b (0-7) of register (B, C, D, E, H, L, A) |  |  |  |  |  |  |  |  |

# • Symbols (2/2)

| Classification     | Symbol                | Meaning                                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|--------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| Memory             | mn                    | Memory address represented in 16 bits.                                                                                                                                 |  |  |  |  |  |  |  |  |  |
|                    | (HL) <sub>b</sub>     | Bit b (0-7) of the contents of the memory<br>address indicated by register pair HI                                                                                     |  |  |  |  |  |  |  |  |  |
|                    | (IX + d) <sub>b</sub> | Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index                                 |  |  |  |  |  |  |  |  |  |
|                    | (IY + d) <sub>b</sub> | register IX.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IY. |  |  |  |  |  |  |  |  |  |
| Flag change symbol | 0                     | Reset to "0" by operation.                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|                    | 1                     | Set to "1" by operation.                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | -                     | No change                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    | *                     | Affected by operation                                                                                                                                                  |  |  |  |  |  |  |  |  |  |
|                    | х                     | Undefined                                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    | Р                     | Handled as parity flag.                                                                                                                                                |  |  |  |  |  |  |  |  |  |
|                    |                       | P = 0: odd parity                                                                                                                                                      |  |  |  |  |  |  |  |  |  |
|                    |                       | P = 1: even parity                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|                    | v                     | Handled as overflow flag.                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    |                       | V = 0: No overflow                                                                                                                                                     |  |  |  |  |  |  |  |  |  |
|                    |                       | V = 1: Overflow                                                                                                                                                        |  |  |  |  |  |  |  |  |  |
| Operator           | ←                     | Transfer                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | ↔                     | Exchange                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | +                     | Add                                                                                                                                                                    |  |  |  |  |  |  |  |  |  |
|                    | -                     | Subtract                                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | ^                     | Logical and between bits.                                                                                                                                              |  |  |  |  |  |  |  |  |  |
|                    | V                     | Logical or between bits.                                                                                                                                               |  |  |  |  |  |  |  |  |  |
|                    | Ð                     | Exclusive or between bits                                                                                                                                              |  |  |  |  |  |  |  |  |  |
| Others             | IFF                   | Interrupt enable flip-flop                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|                    | CY                    | Carry flag                                                                                                                                                             |  |  |  |  |  |  |  |  |  |
|                    | Z                     | Zero flag                                                                                                                                                              |  |  |  |  |  |  |  |  |  |

# TMPZ84C011A Instruction Set (1/9)

| ITEM/        | Assembler                | Object code                            |                    | Object code        |                   |   |        | F                |        | No.        | No.           |              |               |               |                         |
|--------------|--------------------------|----------------------------------------|--------------------|--------------------|-------------------|---|--------|------------------|--------|------------|---------------|--------------|---------------|---------------|-------------------------|
| -FICA-       | mnemonic                 | Binary                                 | Hex                | Function           |                   |   |        |                  |        |            |               |              | CY-           | STA-          |                         |
| TION         |                          | 76 543 210                             |                    |                    | s                 | Z |        | н                |        | P/V        | N             | С            | CLES          | TES           |                         |
|              | LD r,g ·<br>LD r,n       | 01 rrr ggg<br>00 rrr 110               | 40+r×8+g<br>06+r×8 | r←g<br>r←n         | <del>.</del><br>- | - | X<br>X |                  | x<br>x | -          | -             | <br>-        | <u>1</u><br>2 | 4<br>7        | r rrr                   |
|              | LD r,(HL)<br>LD r,(IX+d) | 01 rrr 110<br>11 011 101               | 46+r×8<br>DD       | r←(HL)<br>r←(IX+d) | -                 | - | X      | -                | x<br>x | -          | -             | <br><u>-</u> | 2<br>5        |               | 9 999<br>B 000<br>C 001 |
|              |                          | 01 rrr 110<br>dd ddd ddd               | 46+r×8<br>d        | ·····              |                   |   |        |                  |        |            |               |              |               |               | D 010<br>E 011          |
|              | LD r,(IY+d)              | 11 111 101<br>01 rrr 110<br>dd ddd ddd | FD<br>46+r×8<br>d  | r←(IY+d)           | -                 | - | х      | -                | x      | -          | -             | -            | 5             | 19            | H 100<br>L 101          |
|              | LD (HL),r                | 01 110 rrr                             | 70+r               | (HL)←r             | -                 | - | Х      | _                | x      | -          | - 1           | -            | 2             | 7             | <u></u>                 |
|              | LD (IX+d),r              | 11 011 101                             | DD                 | (IX+d)←r           | -                 | - | X      | -                | X      |            | - 1           | -            | 5             | 19            |                         |
|              |                          | 01 110 rrr<br>dd ddd ddd               | 70+r<br>d          |                    |                   |   |        |                  |        |            |               |              |               |               |                         |
|              | LD (IY+d),r              | 11 111 101<br>01 110 rrr               | FD<br>70+r         | (IY+d)←r           | -                 | - | х      | -                | х      | -          | -             | -            | 5             | 19            |                         |
| LOA          | LD (HL),n                | dd ddd ddd<br>00 110 110               | d<br>36            | (HL)←n             | -                 | - | x      | -                | x      | -          | -             | -            | 3             | 10            |                         |
| A            | LD (IX+d), n             | 11 011 101<br>00 110 110               | DD<br>36           | (IX+d)←n           | -                 | - | x      | -                | x      | -          | -             | -            | 5             | 19            |                         |
| D A          |                          | dd ddd ddd<br>nn nnn nnn               | d<br>n             |                    |                   |   |        |                  |        |            |               |              |               |               |                         |
| B I T        | LD (IY+d),n              | 11 111 101<br>00 110 110<br>dd ddd ddd | FD<br>36<br>d      | (IY+d)←n           | -                 | - | X      | -                | х      | -          | -             | -            | 5             | 19            |                         |
| <b>"</b>     |                          |                                        | n<br>              | A. (PC)            |                   |   |        |                  |        | }          |               |              |               |               |                         |
|              | (D, A, (D, C))           | 00 011 010                             | 1 A                | A+(DE)             |                   |   | ŀ.ŷ    | <del>.</del>     | ŀ      | }          | <u></u> +.⊐.∤ |              |               | ···· <u>'</u> |                         |
|              | $LD \wedge (mn)$         | 00 111 010                             | 24                 | A+(DE)             |                   |   | ÷      | · . <del>.</del> | ŀ      | } <u>−</u> | <u>↓</u>      |              |               |               |                         |
|              |                          | nn nnn nnn<br>mm mmm mmm               | n                  |                    | -                 | _ | ^      | _                | Ŷ      | -          | -             | _            | 4             | 13            |                         |
|              | LD (BC),A                | 00 000 010                             | 02                 | (BC)←A             | -                 | - | Х      | -                | X      | -          | - 1           | -            | 2             | 7             |                         |
| 1            | LD (DE),A                | 00 010 010                             | 12                 | (DE)←A             | -                 | - | Х      | -                | X      | -          | -             | -            | 2             | 7             |                         |
|              | LD (mn),A                | 00 110 010<br>nn nnn nnn<br>mm mmm mmm | 32<br>n<br>m       | (mn)←A             | -                 | - | х      | -                | x      | -          | -             | -            | 4             | 13            |                         |
|              | LD A,I                   | 11 101 101<br>01 010 111               | ED<br>57           | A←I                | *                 | * | х      | 0                | Х      | IFF        | 0             | -            | 2             | 9             |                         |
|              | LD A,R                   | 11 101 101<br>01 011 111               | ED<br>5F           | A←R                | *                 | * | x      | 0                | X      | IFF        | 0             | -            | 2             | 9             |                         |
| 1            | LD I,A                   | 11 101 101<br>01 000 111               | ED<br>47           | ] I←A              | -                 | - | x      | -                | x      | -          | -             | -            | 2             | 9             |                         |
|              | LD R,A                   | 11 101 101<br>01 001 111               | ED<br>4F           | R←A                | -                 | - | X      | -                | X      | -          | -             | -            | 2             | 9             |                         |
| DATA<br>LOAD | ιυ τ, mn                 | 00 TTO 001<br>nn nnn nnn<br>mm mmm mmm | 01+t×10<br>n<br>m  | <b>↓↓</b>          | -                 | - | X      | -                | X      | -          | -             | -            | 3             | 10            | t tt<br>BC 00           |
| 16-BIT       | LD IX,mn                 | 11 011 101<br>00 100 001<br>nn nnn nnn | DD<br>21<br>n      | IX←mn              | -                 | - | x      | -                | Х      | -          | -             | -            | 4             | 14            | DE 01<br>HL 10<br>SP 11 |

Note : r,g means any of the registers A, B, C, D, E, H, L.

IFF in "Flag" column indicates that the content of the interrupt enable flip-flop is copied into the P/V flag.

# TMPZ84C011A Instruction Set (2/9)

| ITEM/            | Assembler      | Object      |         |                                                |              |       | F   | No.       | No.      |                  |              |         |           |            |         |
|------------------|----------------|-------------|---------|------------------------------------------------|--------------|-------|-----|-----------|----------|------------------|--------------|---------|-----------|------------|---------|
| CLASSI<br>-FICA- | mnemonic       | Binary      | Hex     | Function                                       |              |       |     |           |          |                  |              |         | OF<br>CY- | OF<br>STA- |         |
| TION             |                | 76 543 210  |         |                                                | s            | z     |     | н         |          | P/V              | Ν            | С       | CLES      | TES        |         |
|                  | LD IY,mn       | 11 111 101  | FD      | IY←mn                                          | -            | -     | х   | -         | х        | -                | -            | -       | 4         | 14         |         |
|                  |                | 00 100 001  | 21      |                                                |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                |             | n<br>m  |                                                | 1            |       |     |           |          |                  |              |         |           |            |         |
|                  | LD HI (mn)     |             | 24      | H←(mn+1)                                       |              | ·     | Y   | · · · · · |          |                  | ÷            |         |           | 16         | tltt    |
|                  | 10 110, (1111) |             | 0       | L←(mn)                                         | -            | _     | Ŷ   |           | ^        |                  |              |         |           | 10         | BC 00   |
|                  |                | mm mmm mmm  | m       | - ()                                           |              |       |     |           |          |                  |              |         |           |            | DE 01   |
|                  | LD t,(mn)      | 11 101 101  | ED      | t <sub>H</sub> ←(mn+1)                         | -            | -     | Х   | -         | X        | -                |              | -       | 6         | 20         | HL 10   |
|                  |                | 01 tt1 011  | 4B+t×10 | tL←(mn)                                        |              |       |     |           |          |                  | 1            |         |           |            | SP 11   |
|                  |                | nn nnn nnn  | n       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
| 1                |                | mm mmm mmm  | m       |                                                |              |       |     |           |          | ;                |              |         |           |            |         |
|                  | LD IX,(mn)     | 11 011 101  | DD      | IX <sub>H</sub> ←(mn+1)                        | -            | -     | Х   | -         | Х        | -                | -            | -       | 6         | 20         |         |
|                  |                | 00 101 010  | ZA      | TXL+(mn)                                       |              |       |     |           |          |                  | 1            |         |           |            |         |
| 1                |                | mm mmm mmm  | m       |                                                |              |       |     |           |          |                  | -            |         |           |            |         |
| 0                | LD TY. (mn)    | 11 111 101  | FD      | TYu←(mn+1)                                     | ·····        | ····· | Ŷ   | · · · · · | <br>У    |                  |              | ·       | 6         | 20         |         |
| o o              |                | 00 101 010  | 2A      | IYı ←(mn)                                      |              |       | Â   |           |          |                  |              |         | ľ         | 20         |         |
| <u> </u>         |                | nn nnn nnn  | n       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                | mm mmm mmm  | m       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
| ∣∢               | LD (mn),HL     | 00 100 010  | 22      | (mn+1)←H                                       | -            | -     | Х   | -         | X        | -                | -            | -       | 5         | 16         |         |
| <                |                | nn nnn nnn  | n       | (mn)←L                                         |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                | mm mmm mmm  | m       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
| ⊢                | LD (mn),t      | 11 101 101  | ED      | (mn+1)←tH                                      | -            | -     | Х   | -         | X        | -                | -            | -       | 6         | 20         |         |
| -                |                | 01 tto 011  | 43+t×10 | (mn)←tL                                        |              |       |     |           |          |                  | 1            |         |           |            |         |
| •                |                | mm mmm mmm  | m       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                | 11 011 101  | 00      | (mn+1) ← I Xu                                  | ·            | ·     | Ŷ   | ·         |          | ··· <u>-</u> ··· | <u></u>      | ·       | <br>6     | 20         |         |
| -                | (111),11       | 00 100 010  | 22      | (mn) + IX                                      | -            | _     | Ŷ   | _         | î.       |                  |              |         | ľ         | 20         |         |
|                  |                | nn nnn nnn  | n       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                | നന നനന നനന  | m       |                                                |              |       |     |           |          |                  | -            |         |           |            |         |
|                  | LD (mn),IY     | 11 111 101  | FD      | (mn+1)←IY <sub>H</sub>                         | -            | -     | Х   | -         | Х        | -                | -            | -       | 6         | 20         |         |
|                  |                | 00 100 010  | 22      | (mn)←IYL                                       |              |       |     |           |          |                  | -            |         |           |            |         |
|                  |                | nn nnn nnn  | n       |                                                |              |       |     |           |          |                  |              |         |           |            |         |
|                  |                | mm nimm mmm | . m     |                                                |              |       |     |           |          | ļ                | ļ            |         |           |            |         |
|                  | LD SP,HL       | 11 111 001  | 159     | SP4HL                                          | <del>.</del> |       | . X |           | X        | <del></del>      | <del>.</del> |         | 1.        | 6          |         |
|                  | LU 3P,1A       | 11 111 001  | FQ      | 31417                                          | -            | -     | X   | -         | ×        | -                | : -          | -       | 2         | 10         |         |
|                  | LD SP.IY       | 11 111 101  | FD      | SP+IY                                          | ·····        |       | x   | · ·       | <br>x    | ·····            |              |         | 2         | 10         |         |
|                  |                | 11 111 001  | F9      | -· -·                                          |              |       | ^   |           | ^        |                  | 1            |         | 1         |            |         |
|                  | PUSH q         | 11 qq0 101  | C5+q×10 | (SP-2)+qL,(SP-1)+qH,                           | -            | -     | Х   | -         | X        | -                | -            | -       | 3         | 11         | 9 q q q |
|                  |                |             |         | SP+SP-2                                        |              |       |     |           |          |                  |              |         |           |            | BC 00   |
|                  | PUSH IX        | 11 011 101  | DD      | (SP-2)←IXL,(SP-1)←IXH                          | -            | -     | Х   | -         | X        | - 1              | -            | -       | 4         | 15         | DE 01   |
|                  |                | 11 100 101  | E5      | SP←SP-2                                        | ļ            |       |     |           |          |                  | į            |         |           |            | HL 10   |
|                  | PUSH IY        | 11 111 101  | FD      | (SP-2)←IYL,(SP-1)←IYH                          | -            | -     | Х   | -         | Х        | -                | -            | -       | 4         | 15         | AF 11   |
|                  |                | 11 100 101  | E5      | SP←SP−2                                        |              |       |     |           |          | ;<br>            |              |         |           |            |         |
|                  | P 404          | 11 440 001  | L1+q×10 | qH+(SP+1),qL+(SP),                             | -            | -     | X   | -         | X        | -                | : -          | -       | 3         | 10         |         |
|                  |                | 11 011 101  | <br>nn  | 1 37-3772<br>TX106(SP+1) TX16(SP)              |              |       |     |           | ·        | ···_··           | ÷            | · · · · | ····,·    | 14         |         |
|                  | 101 11         | 11 100 001  | E1      | SP+SP+2                                        | -            | -     | ٨   | -         |          | -                | -            | -       | 4         | 14         |         |
|                  | POP IY         | 11 111 101  | FD      | IY <sub>H</sub> ←(SP+1), IY <sub>I</sub> ←(SP) | -            |       | х   |           | x        |                  | -            | -       | 4         | 14         |         |
| 1                |                | 11 100 001  | E1      | SP←SP+2                                        |              |       | , î |           | <b>^</b> |                  | 1            |         | '         | *          |         |
|                  | EX DE,HL       | 11 101 011  | EB      | DE⇔HL                                          | -            | -     | х   | -         | X        | -                | -            | -       | 1         | 4          |         |
| *1               | EX AF, AF'     | 00 001 000  | 08      | AF⇔AF′                                         | -            | -     | Х   | -         | х        | -                | -            | -       | 1         | 4          |         |
|                  | EXX            | 11 011 001  | D9      | BC⇔BC',DE⇔DE',HL↔HL'                           | -            | -     | Х   | -         | Х        | -                | -            | -       | 1         | 4          |         |

Note : t is any of the register pairs BC, DE, HL, SP.

q is any of the register pairs AF, BC, DE, HL.

 $(PAIR)_{H}$ ,  $(PAIR)_{L}$  refer to high order and low order eight bits of the register pair respectively. (Ex)  $BC_{L} = C$ ,  $AF_{H} = A$ .

120489

\*1 : EXCHANGE

MPUZ80-337
# TMPZ84C011A Instruction Set (3/9)

| ITEM/            | Amerikar     | Object     | code  |                                             |           |          |              |           |            |             |              |                  | No.        | No.        |         |                      |
|------------------|--------------|------------|-------|---------------------------------------------|-----------|----------|--------------|-----------|------------|-------------|--------------|------------------|------------|------------|---------|----------------------|
| CLASSI           | mpemonic     | Binary     | Hex   | Function                                    |           |          |              |           | ay         |             |              | 1                | OF         | OF<br>STA- |         |                      |
| TION             | limentonic   | 76 543 210 |       |                                             | s         | Z        |              | н         |            | P/V         | N            | с                | CLES       | TES        |         |                      |
| ω                | EX (SP),HL   | 11 100 011 | E3    | H⇔(SP+1),L⇔(SP)                             | -         | -        | X            | -         | X          | -           | -            | -                | 5          | 19         |         |                      |
| z                | EX (SP),IX   | 11 011 101 | DD    | IX <sub>H</sub> ⇔(SP+1)                     | -         | -        | X            | -         | X          | -           | -            | -                | 6          | 23         |         |                      |
| ₹<br>1           |              | 11 100 011 | E3    | IXL↔(SP)                                    |           |          | <u>.</u>     |           |            |             |              |                  |            | ļ          |         |                      |
| U X              | EX (SP),IY   | 11 111 101 | FD    | IY <sub>H</sub> ⇔(SP+1)                     | -         | -        | X            | -         | х          | -           | -            | -                | 6          | 23         |         |                      |
| w                |              | 11 100 011 | E3    | IY <sub>L</sub> ⇔(SP)                       |           |          | <u> </u>     |           |            |             |              | <u> </u>         |            |            |         |                      |
|                  | LDI          | 11 101 101 | ED    | (DE)←(HL),DE←DE+1                           | -         | -        | X            | 0         | X          | *м          | 0            | -                | 4          | 16         |         |                      |
|                  |              | 10 100 000 | A0    | HL←HL+1,BC←BC−1                             |           | ļ        | ÷            |           |            |             |              |                  | <u>.</u> . |            |         |                      |
|                  | LDIK         | 10 100 000 | ED    | (DE) + (HL), DE+DE+I                        | -         | -        | X            | 0         | X          | 0           | 0            | -                | 5          | 21         |         | xc∼ol                |
|                  |              | 10 110 000 | 80    | BC-0                                        | Ì         |          |              |           |            |             |              |                  | 4          | 10         | , . [ C | sc-0]                |
| ω                |              | 11 101 101 | ED.   | $(DE) \leftarrow (HL) DE \leftarrow DE = 1$ | · · · · · | !··_··   | ÷v           |           |            | *           |              | · · <u>·</u> · · |            | 16         |         |                      |
| L H              |              | 10 101 000 | AS    | $H_{+}H_{-}$                                | -         | -        | : ^          |           | ^          | M           |              |                  | 1          | 10         |         |                      |
| Zĸ               | LDDR         | 11 101 101 | ED    | (DE)+(HL), DE+DE-1                          |           | ·        | x            | 0         | x          | 0           | 0            | ·                | 5          | 21         | ¢ГЕ     | C< > 01              |
| Μ<br>N<br>N<br>N |              | 10 111 000 | B8    | HL←HL−1,BC←BC−1 Repeat until                |           | 1        |              | ÷.        |            |             |              | -                | 4          | 16         | €ΓE     | C=01                 |
| чч               |              |            |       | BC=0                                        |           | 1        | 1            | -         | -          |             |              | -                |            |            | 1.      | -                    |
| ××               | CPI          | 11 101 101 | ED    | A-(HL)                                      | *         | *N       | X            | *         | X          | *м          | 1            | -                | 4          | 16         | 1       |                      |
| 00               |              | 10 100 001 | A1    | HL←HL+1,BC←BC-1                             | ļ         |          |              |           |            |             |              |                  |            |            |         |                      |
| 22               | CPIR         | 11 101 101 | ED    | A-(HL),HL←HL+1,BC←BC-1                      | *         | *N       | X            | *         | Х          | *м          | 1            | -                | 5          | 21         | +[E     | 8C < > 0 &           |
| œ œ              |              | 10 110 001 | B1    | Repeat until A=(HL) or BC=0                 |           |          | <u>.</u>     |           |            |             |              |                  | 4          | 16         | , A     | < > (HL)             |
|                  | CPD          | 11 101 101 | ED    | A-(HL)                                      | *         | *N       | X            | *         | Х          | *м          | 1            | -                | 4          | 16         | ۲L<br>۲ | BC=0 or<br>\= (HL)]  |
|                  |              | 10 101 001 | A9    | HL←HL-1,BC←BC-1                             | l         |          | ļ            |           |            |             |              |                  |            | <b>.</b>   | · ·     | . (=/]               |
|                  | CPDR         | 11 101 101 | ED    | A-(HL),HL←HL-1,BC←BC-1                      | *         | *N       | X            | *         | х          | *м          | 1            | -                | 5          | 21         | +[E     | SC < > 0 &           |
|                  |              | 10 111 001 | B9    | Repeat until A=(HL)or BC=0                  |           |          |              |           |            |             |              |                  | 4          | 16         | . A     | < > (HL)]<br>PC=0 on |
|                  | ADD A,r      | 10 000 rrr | 80+r  | A←A+r                                       | *         | : *<br>: | <u> </u>     | *         | X          | V           | 0            | **               | 1          | 4          | <u></u> | V= (HL)]             |
|                  | ADD A,n      | 11 000 110 | C6    | A←A+n                                       | *         | *        | X            | *         | X          | v           | 0            | *                | 2          | 7          |         |                      |
|                  |              | nn ann nnn | n     |                                             | <b> </b>  | ļ        | ļ            |           |            |             |              |                  |            |            |         |                      |
|                  | ADD A, (HL)  | 10 000 110 | 86    | A←A+(HL)                                    |           | ÷*       | <u>. X</u> . | ÷*        | . X.       | V           | 0            | ÷*               | 2          |            | r       | rrr                  |
|                  | AUD A,(IX+d) |            |       | A+A+(1X+d)                                  | *         |          | ÷×           |           | X          | · V         | : 0          | *                | 5          | 19         | В       | 000                  |
| -                |              | dd ddd ddd | 00    |                                             |           |          | -            |           |            |             |              |                  |            |            | С       | 001                  |
| υŪ               | ADD A (IV+d) | 11 111 101 | FD    | Δ+Δ+(IY+d)                                  | *         |          | ÷            | *         | v          | · · · · · · | 0            | *                |            | 10         | D       | 010                  |
| 5                | 100 1,(11.4) | 10 000 110 | 86    | (11.4)                                      |           |          | : ^          |           | : ^        | •           |              |                  |            | 15         | E       | 011                  |
| ŏ                |              | dd ddd ddd | d     |                                             |           | 1        |              |           |            |             |              |                  |            |            | н       | 100                  |
| -                | ADC A.r      | 10 001 rrr | 88+r  | A←A+r+CY                                    | *         | *        | x            | *         | x          | v           | 0            | *                | 1          | 4          |         | 111                  |
| 9                | ADC A,n      | 11 001 110 | CE    | A←A+n+CY                                    | *         | *        | X            | *         | x          | v           | 0            | *                | 2          | 7          | 1       | ***                  |
| Ā                |              | nn nnn nnn | n     |                                             | 1         | 1        | 1            | -         |            |             |              |                  |            |            |         |                      |
| U                | ADC A,(HL)   | 10 001 110 | 8E    | A←A+(HL)+CY                                 | *         | *        | X            | *         | Х          | V           | 0            | *                | 2          | 7          |         |                      |
| 1 -              | ADC A,(IX+d) | 11 011 101 | DD    | A←A+(IX+d)+CY                               | *         | *        | X            | *         | X          | V           | 0            | *                | 5          | 19         |         |                      |
| L L              |              | 10 001 110 | 8E    |                                             |           | -        | 1            |           |            |             |              |                  |            |            |         |                      |
| Σ                |              | dd ddd ddd | d     |                                             |           | ļ        | <u>.</u>     |           | ļ          |             |              | ļ                |            | ļ          | Į       |                      |
| 1                | ADC A,(IY+d) | 11 111 101 | FD    | A←A+(IY+d)+CY                               | *         | *        | X            | *         | X          | V           | 0            | *                | 5          | 19         |         |                      |
| 12               |              | 10 001 110 | 8E    |                                             |           | 1        |              | 1         |            | -           | -            | 1                |            |            |         |                      |
| Ā.               |              | dd ddd ddd | d     |                                             |           | ;<br>    |              |           |            | ;           |              |                  |            | <b>.</b>   |         |                      |
| ⊢                | SUB r        | 10 010 rrr | 190+r |                                             |           |          | . X.         | · · • · · | . <u>x</u> | v           | 1.           | ÷                | 11         | 44         |         |                      |
| -                | 300 11       | 11 010 110 | 00    | ATA-II                                      | 1         | . *      | ×            | . *       | ×          | : v         | 1            | : "              | 2          | '          |         |                      |
| <b>"</b>         | SUB (HL)     |            | 96    | Α <sub>4</sub> Α <sub>-</sub> (Η)           | <br>*     |          | ÷            |           |            |             |              |                  | ·····      | ····;·     |         |                      |
| ~                | SUB (TX+d)   | 11 011 101 | 00    | $A \leftarrow A - (TX + d)$                 | <br>*     | *        | ÷            | *         | • • • •    |             | <del>!</del> | *                | <u>ć</u> . | 10         |         |                      |
| 1                |              | 10 010 110 | 96    |                                             |           |          | ^            |           | ^          |             | 1            |                  | 5          | 1 19       |         |                      |
| 1                |              | dd ddd ddd | d     |                                             |           | 1        | 1            | :         | :          | :           | -            | 1                | 1          |            |         |                      |
| 1                | SUB (IY+d)   | 11 111 101 | FD    | A←A−(IY+d)                                  | *         | *        | ×χ           | (<br>; *  | ×          | v           | 1            | *                | 5          | 19         | 1       |                      |
| 1                |              | 10 010 110 | 96    |                                             |           |          |              |           |            |             |              |                  | 1          |            |         |                      |
|                  |              | dd ddd ddd | d     |                                             |           | 1        | 1            | ;         | :          | -           | :            | 1                |            |            |         |                      |

Note : \*M P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1.

\*N Z flag is 1 if A = (HL), otherwise Z = 0.

[ ]indicates the total condition of the number of cycles and states indicated by arrow.

r means any of the registers A, B, C, D, E, H, L.

# TMPZ84C011A Instruction Set (4/9)

| ITEM/            | Assembler          |                 |            | Object     | code        |                                 |            |          |            | E             | an       |      |          |       | No.           | No.        |                |
|------------------|--------------------|-----------------|------------|------------|-------------|---------------------------------|------------|----------|------------|---------------|----------|------|----------|-------|---------------|------------|----------------|
| CLASSI<br>-FICA- | mnemonic           |                 | Bin        | ary        | Hex         | Function                        |            |          |            |               |          |      |          |       | OF<br>CY-     | OF<br>STA- |                |
| TION             |                    | 76              | 543        | 210        |             |                                 | S          | Z        |            | н             |          | P/V  | Ν        | С     | CLES          | TES        |                |
|                  | SBC A,r<br>SBC A,n | 10<br>11        | 011        | rrr<br>110 | 98+r<br>DE  | A+A-r-CY<br>A+A-n-CY            | *          | *        | X<br>X     | *             | X        | v    | 1        | *:*   | 1             | 4<br>7     | r rrr<br>B 000 |
|                  |                    | nn              | nnn        | nnn        | n           |                                 |            |          |            |               |          |      |          |       |               |            | C 001          |
|                  | SBC A, (HL)        | 10              | 011        | 110        | 9E          | A←A−(HL)−CY                     | *          | *        | X          |               | . X.     | . v  | .1       |       | 2.            |            | D 010          |
|                  | SBC A,(1X+0)       | 10              | 011        | 101        | 9E          | A+A-(1X+d)-CT                   | 1 T        |          | X          | Ī             |          | Ý    | 1        | Ĩ     | 5             | 19         | H 100          |
|                  |                    | dd              | ddd        | ddd        | d           |                                 |            |          |            |               |          |      |          |       |               |            | L 101          |
|                  | SBC A,(IY+d)       | 11              | 111        | 101        | FD          | A←A-(IY+d)-CY                   | *          | ٠        | Х          | *             | х        | v    | 1        | *     | 5             | 19         | A 111          |
|                  |                    | 10<br>dd        | 011<br>ddd | 110<br>ddd | 19E         |                                 |            |          |            |               |          |      |          |       |               |            |                |
| <u>ب</u>         | AND r              | 10              | 100        | rrr        | A0+r        | A←A∧r                           | *          | *        | X          | 1             | X        | Р    | 0        | 0     | 1             | 4          |                |
| ∢                | AND n              | 11              | 100        | 110        | E6          | A←A∧n                           | *          | •        | Х          | 1             | Х        | Р    | 0        | 0     | 2             | 7          |                |
| -                |                    | nn              | nnn<br>100 |            | n           | A. A.A. (111.)                  | ······     | <u>.</u> |            |               |          |      |          |       |               |            |                |
| U                | AND (IX+d)         | 11              | 011        | 101        | DD          | $A \leftarrow A \land (IX + d)$ | ····       | *        | X X        | <u>1</u><br>1 | ^<br>X   | Р    | 0        | <br>0 | <u>4</u><br>5 | 19         |                |
|                  |                    | 10              | 100        | 110        | A6          |                                 |            |          |            |               |          |      |          |       |               |            |                |
|                  |                    | dd              | ddd        | ddd        | d           |                                 |            |          |            |               |          |      |          |       |               |            |                |
| D<br>Z           | AND (IY+d)         | 11              | 111        | 101        | FD<br>A6    | A←A∧(IY+d)                      | *          | *        | х          | 1             | X        | Р    | 0        | 0     | 5             | 19         |                |
| ∢                |                    | dd              | ddd        | ddd        | d           |                                 |            |          |            |               |          |      |          |       |               |            |                |
| υ                | OR r               | 10              | 110        | 111        | B0+r        | A←A∨r                           |            | *        | X          | 0             | X        | Р    | 0        | 0     | 1             | 4          |                |
| _                | OR n               | 11              | 110        | 110        | F6          | A←A∨n                           | *          | *        | х          | 0             | x        | Р    | 0        | 0     | 2             | 7          |                |
| ш.               | OR (HL)            | <u>nn</u><br>10 | nnn<br>110 |            | n<br>B6     | A←A\/(HL)                       |            | *        | x          | 0             | x        | р    | 0        | <br>0 | 2             | 7          |                |
| Σ                | OR (IX+d)          | 11              | 011        | 101        | DD          | A←A∨(IX+d)                      | *          | *        | X          | 0             | Х        | Р    | 0        | 0     | 5             | 19         |                |
| Ē                |                    | 10              | 110        | 110        | B6          |                                 |            |          |            |               |          |      |          |       |               |            |                |
| -                |                    | dd              | ddd        | ddd        | d           |                                 |            |          |            |               |          |      |          |       | · · · · · ·   | 10         |                |
| 4                | 0K (11+0)          | 10              | 110        | 110        | B6          | ATAV(11+u)                      | Ť          |          | <u>^</u>   | U             | ^        | r    |          | 0     | 5             | 19         |                |
| ⊢                | [                  | dd              | ddd        | ddd        | d           |                                 |            |          |            |               |          |      | <u>.</u> |       |               |            |                |
| -                | XOR r              | 10              | 101        | rrr        | A8+r        | A←A∀r                           |            | *        | X          | 0             | X        | Р    | 0        | 0     | 1             | 4          |                |
| - m              | XOR n              | 11              | 101        | 110        | EE          | A←A∀n                           | *          | *        | X          | 0             | X        | Р    | 0        | 0     | 2             | 7          |                |
| œ                | XOR (HL)           | 10              | 101        | 110        | AE          | A←A∀(HL)                        | *          | *        | x          | 0             | x        | Р    | 0        | 0     | 2             | 7          |                |
|                  | XOR (IX+d)         | 11              | 011        | 101        | DD          | A←A∀(IX+d)                      | *          | *        | Х          | 0             | Х        | Р    | 0        | 0     | 5             | 19         |                |
|                  |                    | 10              | 101        | 110        | AE          |                                 |            |          |            |               |          |      |          |       |               |            |                |
|                  | XOR (IY+d)         | 11              | 111        | 101        | FD          | A←A₩(IY+d)                      |            | *        | x          | 0             | <br>x    | P    | 0        | 0     | 5             |            |                |
|                  |                    | 10              | 101        | 110        | AE          |                                 |            |          |            | -             |          |      |          |       | _             |            |                |
|                  |                    | dd              | ddd        | ddd        | d           |                                 | " <b>.</b> |          |            |               |          |      | ļ        |       |               |            |                |
|                  | CP r               | 10              | 111        | 110        | B8+r        | A-r<br>A-n                      |            | *        | X          | *             | . Х<br>У | . V. | 1        | *     | 1             | 4          |                |
|                  |                    | nn              | nnn        | nnn        | n           |                                 |            |          | ^          |               | Ŷ        |      |          |       | -             | '          |                |
|                  | CP (HL)            | 10              | 111        | 110        | BE          | A-(HL)                          | *          | *        | X          | ٠             | Х        | v    | 1        | . *   | 2             | . 7        |                |
|                  | CP (IX+d)          | 11              | 011        | 101        | DD          | A-(IX+d)                        | *          | *        | Х          | *             | х        | v    | 1        | *     | 5             | 19         |                |
|                  |                    | 01<br>66        | 111<br>ddd | ddd        | d           |                                 |            |          |            |               |          |      |          |       |               |            |                |
|                  | CP (IY+d)          | 11              | 111        | 101        | FD          | A-(IY+d)                        | *          | *        | X          | *             | x        | v    | 1        | *     | 5             | 19         |                |
|                  |                    | 10              | 111        | 110        | BE          |                                 |            |          |            |               |          |      |          |       |               |            |                |
|                  |                    | dd              | ddd        | ddd        | d<br>04+n×2 | n4 n+1                          |            |          |            |               |          |      |          |       |               |            |                |
|                  | TNC (HL)           | 00              | 110        | 100        | 34          | (HI) ← (HI) +1                  |            | *        | ×          |               | ^<br>x   |      | 0        | ·     | 3             | 11         |                |
|                  | INC (IX+d)         | 11              | 011        | 101        | DD          | (IX+d)+(IX+d)+1                 | *          | *        | :.^<br>: X | *             | X        | v    | 0        | -     | 6             | 23         |                |
| 1                |                    | 00              | 110        | 100        | 34          |                                 |            |          |            |               |          |      |          |       |               |            |                |
| 1                |                    | dd              | ddd        | ddd        | d           |                                 |            | :        | :          |               | :        | :    | : :      |       |               |            |                |

Note : r means any of the registers A, B, C, D, E, H, L.

### TMPZ84C011A Instruction Set (5/9)

| ITEM/       | Assembler  | Object     | code      |                                |              |                |            | F            | lag        |                   |            |                      | No.          | No.  |       |
|-------------|------------|------------|-----------|--------------------------------|--------------|----------------|------------|--------------|------------|-------------------|------------|----------------------|--------------|------|-------|
| -FICA-      | mnemonic   | Binary     | Hex       | Function                       |              |                |            |              |            |                   |            |                      | CY-          | STA- |       |
| TION        |            | 76 543 210 |           |                                | s            | z              |            | н            |            | P/V               | Ν          | С                    | CLES         | TES  |       |
| U           | INC (IY+d) | 11 111 101 | FD        | (IY+d)←(IY+d)+1                | *            | *              | Х          | *            | х          | v                 | 0          | -                    | 6            | 23   |       |
| F           | · ·        | 00 110 100 | 34        |                                |              |                |            |              |            |                   |            |                      |              |      |       |
| 5           | DE0 -      | dd ddd ddd | d         |                                |              |                |            |              |            |                   |            |                      |              |      |       |
| Ξų          |            | 00 110 101 | 00+FX8    | F+F−1<br>/ /UI ) ← /UI ) −1    |              |                |            |              | . <u>X</u> | · · · ·           | 1          |                      | 1            | 4    | R 000 |
| 20          | DEC (IX+d) | 11 011 101 | 35        | $(1X+d) \leftarrow (1X+d) - 1$ |              |                | Ŷ          | *            | Ŷ          | V<br>V            | 1          | ·- <u>-</u> -        |              |      | C 001 |
| 4 U         | (1,)       | 00 110 101 | 35        | (14/0) (14/0) 1                |              |                | Â          |              | ſ,         |                   |            |                      | Ů            | 2.5  | D 010 |
| Ó           |            | dd ddd ddd | d         |                                |              |                |            |              |            |                   |            |                      |              |      | E 011 |
|             | DEC (IY+d) | 11 111 101 | FD        | (IY+d)←(IY+d)-1                | *            | *              | Х          | ٠            | Х          | v                 | 1          | -                    | 6            | 23   | H 100 |
| ۳. <u>م</u> |            | 00 110 101 | 35        |                                |              |                |            |              |            |                   |            |                      |              |      | L 101 |
| ∞Ā          |            | dd ddd ddd | d         |                                |              |                |            |              |            |                   |            |                      |              |      | A 111 |
| 2           | DAA        | 00 100 111 | 27        | Decimal adjust accumulator     | *            | *              | X          | *            | X          | Р                 |            | *                    | 1            | 4    |       |
| ~           | CPL        | 00 101 111 | 2 F       | A←Ā                            | <del>.</del> | . <del>.</del> | X          | 1            | X          | <u> </u>          | 1          |                      | 1            | 4    |       |
| z           | NEG        | 11 101 101 | ED        | A←0−A                          | *            | *              | х          | *            | Х          | v                 | 1          | *                    | 2            | 8    |       |
| 0           |            | 01 000 100 | 44        |                                |              |                | ļ          |              |            | <b>.</b>          |            |                      |              |      |       |
| - I         | CCF        | 00 111 111 | 3F        | CY+CY                          | <del>.</del> | ļ <del>.</del> | <u>. x</u> | Х.,          | X          | ļ <del></del>     | 0          | *                    | 1.           | 4    |       |
| AP (        | SCF        | 00 110 111 | 37        | CY+1                           |              | <del>.</del>   | <u>. x</u> | 0            | . X.       | ļ <del></del>     | 0          | 1                    | 1            | 4    |       |
| ш 2         |            | 00 000 000 | 00        | no operation                   |              |                | X          |              | . <u>X</u> | <del>.</del>      |            | <del>.</del>         | 1.           | 4    |       |
| 0 Z         |            | 11 110 110 | E 2       |                                |              | ļ              | <u>}</u>   |              | ŀ          | }                 | ÷          | · · <del>.</del> · · |              | 4    |       |
| 8 A<br>  A  | FT         | 11 111 011 | FR        | TFF+1                          | <u>-</u>     | ŀ              |            |              | ·          | <u> </u> <u>-</u> |            |                      |              |      |       |
|             |            | 11 101 101 | FD        | Set interrupt mode 0           |              | ŀ              | }.≎        |              | ·          | <u>-</u>          | - <u>-</u> |                      |              |      |       |
| E.E.        | 1          | 01 000 110 | 46        | Set interrupt mode o           | -            | ,              | ^          |              | î.         | _                 | _          | _                    | 6            | °    |       |
| ₹ž          | IM 1       | 11 101 101 | FD        | Set interrupt mode 1           | ·····        |                | ¥          |              | x          | ·                 |            |                      | 2            | 8    |       |
| μĻ          |            | 01 010 110 | 56        |                                |              |                |            |              | Ϊ.         | 1                 | 1          |                      |              | Ů    |       |
| и и<br>И    | IM 2       | 11 101 101 | ED        | Set interrupt mode 2           |              | -              | X          | -            | X          | -                 | -          |                      | 2            | 8    |       |
| ⊍∢          |            | 01 011 110 | 5E        |                                |              |                |            |              |            |                   |            |                      |              |      |       |
|             | ADD HL,t   | 00 tt1 001 | 09+t×10   | HL+HL+t                        | -            | -              | Х          | Х            | Х          | -                 | 0          | *                    | 3            | 11   | t tt  |
|             | ADC HL,t   | 11 101 101 | ED        | HL←HL+t+CY                     | *            | *              | Х          | Х            | Х          | ٧                 | 0          | *                    | 4            | 15   | BC 00 |
|             |            | 01 tt1 010 | 4A+t×10   |                                |              |                | ļ          |              |            | ļ                 |            |                      |              |      | DE 01 |
| -           | SBC HL,t   | 11 101 101 | ED        | HL←HL-t-CY                     | *            | *              | х          | Х            | Х          | v                 | 1          | *                    | 4            | 15   | HL 10 |
| H-          |            | 01 tt0 010 | 42+t×10   |                                |              |                | ļ          |              |            | <b>.</b>          | į          |                      |              |      | SP 11 |
| Σ           | ADD IX,p   | 11 011 101 | DD        | IX←IX+p                        | -            | -              | х          | Х            | Х          | -                 | 0          | *                    | 4            | 15   |       |
| н           |            | 00 pp1 001 | 09+p×10   |                                |              |                |            |              |            |                   |            |                      |              |      | p pp  |
| -           | ADD IY,S   |            | FD        | 1Y+1Y+S                        | -            | -              | X          | X            | X          | -                 | 0          | *                    | 4            | 15   | BC 00 |
| A R         | TNC +      | 00 551 001 | 02++ x 10 | ++++1                          |              |                |            |              |            | ļ                 |            |                      | ····         |      |       |
|             |            |            | 03+1 × 10 |                                |              |                |            | <del>.</del> |            | ·                 |            | · · · · ·            | ] <u>†</u> . | 0    | SD 11 |
| 12          |            |            | 23        | 17, 17, 1                      | -            | _              | ^          |              | ^          | -                 | -          |                      | 4            | 10   |       |
| -           | INC TY     | 11 111 101 | FD        | TV+TV+1                        | ·····        | ·              |            | · · . · ·    | · · ·      | <u>.</u>          | <u>†</u>   |                      |              | 10   |       |
| . o         |            | 00 100 011 | 23        |                                |              |                | 1          |              | Î,         |                   |            |                      | ) ~          | 1 10 | BC 00 |
| -           | DEC t      | 00 tt1 011 | 0B+t×10   | t+t−1                          | ·····        | -              | x          | -            | x          |                   | -          |                      | 1            | 6    | DE 01 |
| 1           | DEC IX     | 11 011 101 | DD        | IX+IX-1                        |              |                | X          | - 1          | X          | -                 | - 1        | -                    | 2            | 10   | IY 10 |
|             |            | 00 101 011 | 2B        |                                | 1            |                |            |              |            |                   |            |                      | l            |      | SP 11 |
|             | DEC IY     | 11 111 101 | FD        | IY←IY-1                        | -            | -              | X          | -            | Х          | -                 | -          |                      | 2            | 10   |       |
|             |            | 00 101 011 | 2B        |                                |              |                |            |              | 1          | :                 | 1          |                      |              |      |       |
| ATE         |            |            |           |                                |              |                |            |              |            | 1                 |            |                      |              |      |       |
| 10          | RLCA       | 00 000 111 | 07        |                                | -            | -              | X          | 0            | X          |                   | 0          | *                    | 1            | 4    |       |
| ~           | 1          | 1          | 1         | A A                            | 1            | ;              | ÷          | ;            | :          | ;                 | : :        |                      | 1            | 1    |       |

Note : ss is any of the register pairs BC, DE, HL, SP. PP is any of the register pairs BC, DE, IX, SP. rr is any of the register pairs BC, DE, IY, SP.

# TMPZ84C011A Instruction Set (6/9)

| ITEM/<br>CLASSI | Assembler  | Object                                 | code             |                                                                                                                                  |          |   |     | F | lag |     |    |    | No.<br>OF | No.<br>OF   |                         |
|-----------------|------------|----------------------------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------|----------|---|-----|---|-----|-----|----|----|-----------|-------------|-------------------------|
| -FICA-          | mnemonic   | Binary<br>76 543 210                   | Hex              | Function                                                                                                                         | s        | z |     | н |     | P/V | N  | с  | CY-       | STA-<br>TES |                         |
|                 | RLA        | 00 010 111                             | 17               | CY ← 7 ← 0 ← A                                                                                                                   | -        | - | x   | 0 | x   | -   | 0  | *  | 1         | 4           |                         |
|                 | RRCA       | 00 001 111                             | OF               | $\begin{array}{c} \hline \hline \hline 7 \rightarrow 0 \\ \hline A \end{array} \begin{array}{c} \hline CY \\ \hline \end{array}$ | -        | - | x   | 0 | x   | -   | 0  | *  | 1         | 4           |                         |
|                 | RRA        | 00 011 111                             | 1F               |                                                                                                                                  | -        | - | x   | 0 | x   | -   | 0  | ٠  | 1         | 4           |                         |
|                 | RLC r      | 11 001 011                             | СВ               |                                                                                                                                  | *        | * | X   | 0 | Х   | Р   | 0  | *  | 2         | 8           | 7777                    |
| ļ               | RLC (HL)   | 11 001 011                             | CB               |                                                                                                                                  | •        | * | x   | 0 | x   | р   | 0  | •  | 4         | 15          | C 001                   |
|                 |            | 00 000 110                             | 06               |                                                                                                                                  |          |   | ļ   |   |     | ļ   |    |    |           |             | D 010                   |
| F               | RLC (IX+d) | 11 011 101<br>11 001 011<br>dd ddd ddd | DD<br>CB<br>d    | $CY \leftarrow 7 + 0 \leftarrow$                                                                                                 | •        | ٠ | х   | 0 | х   | Р   | 0  | *  | 6         | 23          | E 011<br>H 100<br>L 101 |
| - u             |            | 00 000 110                             | 06               |                                                                                                                                  |          |   |     |   |     |     |    |    |           |             | A 111                   |
| н               | RLC (IY+d) | 11 111 101                             | FD               |                                                                                                                                  | *        | ٠ | x   | 0 | х   | Р   | 0  | *  | 6         | 23          |                         |
|                 |            | dd ddd ddd                             | d                |                                                                                                                                  |          |   |     |   |     |     |    |    |           |             |                         |
| ш<br>н          |            | 00 000 110                             | 06               | 1                                                                                                                                | l        |   |     |   |     |     |    |    |           |             |                         |
| ∢               | RLr        | 11 001 011                             | СВ               |                                                                                                                                  | *        | * | X   | 0 | х   | Р   | 0  | *  | 2         | 8           |                         |
| R O T           | RL (HL)    | 00 010 rrr<br>11 001 011               | 10+r<br>CB<br>16 |                                                                                                                                  | *        | * | x   | 0 | x   | Р   | 0  | *  | 4         | 15          |                         |
| 1               | RL (IX+d)  | 11 011 101                             | DD               |                                                                                                                                  | *        | * | X   | 0 | x   | P   | 0  | •  | 6         | 23          |                         |
| 1               |            | 11 001 011                             | СВ               | CY < 7 + 0 <                                                                                                                     |          | - | -   |   |     |     |    |    |           |             |                         |
|                 |            | dd ddd ddd                             | d                | r,(HL),(IX+d),(IY+d)                                                                                                             |          |   |     |   |     |     |    |    |           |             |                         |
|                 | RI (TY+d)  |                                        | FD               |                                                                                                                                  |          | * | x   | n | x   | p   | n  | •  | 6         | 23          |                         |
| 1               | (= (= ,    | 11 001 011                             | СВ               |                                                                                                                                  |          |   |     |   |     |     |    |    | -         |             |                         |
|                 |            | dd ddd ddd                             | d                |                                                                                                                                  |          |   |     |   |     |     |    |    |           |             |                         |
| ł               |            | 00 010 110                             | 16               |                                                                                                                                  | <u>.</u> |   |     |   |     |     |    |    |           |             |                         |
|                 |            | 00 001 000                             | 08+r             |                                                                                                                                  | ľ        | 1 | : ^ |   | ^   | , P |    | Ţ, | 2         | °           |                         |
|                 | RRC (HL)   | 11 001 011                             | СВ               |                                                                                                                                  | *        | * | X   | 0 | х   | Р   | 0  | *  | 4         | 15          |                         |
| 1               |            | 00 001 110                             | OE               |                                                                                                                                  |          |   | ļ   |   |     | ļ   |    |    |           |             |                         |
|                 | RRC (IX+d) |                                        | DD               |                                                                                                                                  | *        | * | X   | 0 | X   | Р   | 0  | •  | 6         | 23          |                         |
|                 |            | dd ddd ddd                             | d                | 1,(12),(11,0),(11,0)                                                                                                             |          |   |     |   |     |     |    |    |           |             |                         |
|                 |            | 00 001 110                             | OE               |                                                                                                                                  |          |   |     |   |     | Į   |    |    |           |             |                         |
| [               | RRC (IY+d) | 11 111 101                             | FD               |                                                                                                                                  | *        | * | х   | 0 | х   | Р   | 0  | *  | 6         | 23          |                         |
|                 |            | 11 001 011                             | CB               |                                                                                                                                  |          |   | -   |   |     |     |    |    |           |             |                         |
| 1               |            | 00 001 110                             | OE               |                                                                                                                                  |          |   |     |   |     | -   |    |    |           |             |                         |
|                 | RR r       | 11 001 011                             | СВ               |                                                                                                                                  | *        | * | Х   | 0 | Х   | Р   | 0  | *  | 2         | 8           |                         |
|                 |            | 00 011 rrr                             | 18+r             |                                                                                                                                  |          |   | ļ   |   |     |     |    |    |           |             |                         |
|                 | RR (HL)    |                                        | I CB             |                                                                                                                                  | *        | * | X   | 0 | Х   | Р   | 0  | *  | 4         | 15          |                         |
|                 | RR (IX+d)  | 11 011 101                             | DD               | r,(HL),(IX+d)                                                                                                                    | *        | * | x   | 0 | x   | Р   | 0  | •  | 6         | 23          |                         |
|                 |            | 11 001 011                             | СВ               |                                                                                                                                  |          |   | -   |   |     |     |    |    |           |             |                         |
| I               |            | dd ddd ddd                             | d                |                                                                                                                                  |          | - | -   |   |     |     |    |    | ĺ         |             |                         |
|                 | 1          | 100 011 110                            | 1 12             | 1                                                                                                                                |          | : | :   | : | :   | :   | :; | :  |           | 1           |                         |

Note : r means any of the registers A, B, C, D, E, H, L.

# TMPZ84C011A Instruction Set (7/9)

| ITEM/<br>CLASSI | Assembler   | Object                                 | code             |                                                                                                                                                         |   |   |     | F | lag |     |   |   | No.<br>OF   | NO.<br>OF   |                |
|-----------------|-------------|----------------------------------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|---|-----|-----|---|---|-------------|-------------|----------------|
| -FICA-<br>TION  | mnemonic    | Binary<br>76 543 210                   | Hex              | Function                                                                                                                                                | s | z |     | н |     | P/V | N | с | CY-<br>CLES | STA-<br>TES |                |
|                 | RR (IY+d)   | 11 111 101<br>11 001 011<br>dd ddd ddd | FD<br>CB<br>d    | $\begin{array}{c} \hline \hline$ | * | * | x   | 0 | X   | Р   | 0 | * | 6           | 23          |                |
|                 | SLA r       | 00 011 110<br>11 001 011<br>00 100 ccc | 1E<br>CB<br>20+r |                                                                                                                                                         | * | * | x   | 0 | x   | Р   | 0 | * | 2           | 8           |                |
|                 | SLA (HL)    | 11 001 011                             | CB               |                                                                                                                                                         | * | * | x   | 0 | x   | Р   | 0 | * | 4           | 15          | C 001          |
|                 | SLA (IX+d)  | 11 011 101<br>11 001 011               | DD<br>CB         | $CY \leftarrow 7 \leftarrow 0 \leftarrow 0$                                                                                                             | * | * | x   | 0 | x   | Р   | 0 | * | 6           | 23          | E 011<br>H 100 |
|                 | SLA (IY+d)  | 00 100 110<br>11 111 101               | 0<br>26<br>FD    | r,(nL),(1X+d),(11+d)                                                                                                                                    | * | * | x   | 0 | x   | Р   | 0 | * | 6           | 23          | A 111          |
| ⊢               |             | 11 001 011<br>dd ddd ddd<br>00 100 110 | d<br>26          |                                                                                                                                                         |   |   |     |   |     |     |   |   |             |             |                |
| ц.<br>—<br>Т    | SRA r       | 11 001 011<br>00 101 rrr               | CB<br>28+r       |                                                                                                                                                         | * | * | , x | 0 | х   | Р   | 0 |   | 2           | 8           |                |
| s               | SRA (HL)    | 11 001 011<br>00 101 110               | 2E               |                                                                                                                                                         | * | * | X   | 0 | X   | Р   | 0 |   | 4           | 15          |                |
| TATE            | SRA (IX+d)  | 11 011 101<br>11 001 011<br>dd ddd ddd | DD<br>CB<br>d    | $\begin{array}{c} \hline 7 \rightarrow 0 \end{array} \xrightarrow{} CY$                                                                                 | * | * | х   | 0 | x   | Р   | 0 | * | 6           | 23          |                |
| R<br>0          | SRA (IY+d)  | 11 111 101<br>11 001 011<br>dd ddd ddd | FD<br>CB<br>d    | r,(HL),(1X+a),(1T+a)                                                                                                                                    | * | * | x   | 0 | x   | Р   | 0 | ٠ | 6           | 23          |                |
|                 | SRL r       | 00 101 110<br>11 001 011               | 2E<br>CB         |                                                                                                                                                         | * | * | x   | 0 | x   | Р   | 0 | * | 2           | 8           |                |
|                 | SRL (HL)    | 00 111 rrr<br>11 001 011               | 38+r<br>CB       |                                                                                                                                                         | * | * | x   | 0 | x   | Р   | 0 | • | 4           | 15          |                |
|                 | SRL (IX+d)  | 00 111 110<br>11 011 101<br>11 001 011 | 3E<br>DD<br>CB   |                                                                                                                                                         | * | * | x   | 0 | x   | Р   | 0 | * | 6           | 23          |                |
|                 | 001 (11/-1) | dd ddd ddd<br>00 111 110               | d<br>3E          | r,(HL),(IX+d),(IY+d)                                                                                                                                    |   |   |     |   |     |     |   |   |             |             |                |
|                 | SRL (IY+d)  | 11 111 101<br>11 001 011<br>dd ddd ddd | CB<br>d          |                                                                                                                                                         | • | * | x   | 0 | х   | Р   | 0 | * | 6           | 23          |                |
|                 | RLD         | 11 101 101<br>01 101 111               | ED<br>6F         | A 7 43 0 7 43 0 (HL)                                                                                                                                    | * | * | x   | 0 | x   | Р   | 0 | - | 5           | 18          | *1             |
|                 | RRD         | 11 101 101<br>01 100 111               | ED<br>67         | A 7 43 0 7 43 0 (HL)                                                                                                                                    | * | * | x   | 0 | х   | Р   | 0 | - | 5           | 18          | *1             |
| EST             | BIT b,r     | 11 001 011                             | СВ               | 7                                                                                                                                                       | x | * | x   | 1 | x   | x   | 0 | - | 2           | 8           | 0 000          |
| SET<br>T AND T  | BIT b,(HL)  | 11 001 011<br>01 bbb 110               | CB<br>46+b×8     | Z←(HL) <sub>b</sub>                                                                                                                                     | X | * | x   | 1 | x   | x   | 0 | - | 3           | 12          | 2 010<br>3 011 |
| B I T<br>RESE   |             |                                        |                  |                                                                                                                                                         |   |   |     |   |     |     |   |   |             |             | 5 101<br>6 110 |

: \*1: Rotate digit left and right between the accmulator and location (HL). The content of the upper half of the accumulator is unaffected.

The notation (HL)<sub>b</sub> indicates bit  $_b$  (0 to 7) within the contents of the HL register pair. The notation  $r_b$  indicates bit  $_b$  (0 to 7) within the r register.

### TMPZ84C011A Instruction Set (8/9)

| ITEM/<br>CLASSI | Assembler  |           |       |      | Object | code<br>I                                |                              |                                         |                |          | F         | lag       |     |           |        | No.<br>OF  | No.<br>Of |                   |
|-----------------|------------|-----------|-------|------|--------|------------------------------------------|------------------------------|-----------------------------------------|----------------|----------|-----------|-----------|-----|-----------|--------|------------|-----------|-------------------|
| -FICA-          | mnemonic   |           | 76    | Bina | 210    | Hex                                      | Function                     | 5                                       | 7              |          | н         |           | P/V | N         | c      | CY-        | STA-      |                   |
|                 | BIT b (IX+ | <u>d)</u> | 111   | 111  | 101    |                                          |                              | +                                       | *              | . v      | 1         | v         |     | 0         |        | 6          | 20        |                   |
|                 | DIT 0,(1.  | u)        | 111 0 | 001  | 011    | CB                                       | Z+(IX+d)b                    | 1                                       |                | ^        | 1         | ^         | ^   | 0         |        | 5          | 20        |                   |
|                 |            |           | dd i  | bbb  | ddd    | d                                        | - (                          |                                         |                |          |           |           |     |           |        | [          |           |                   |
|                 |            |           | 01 1  | bb   | 110    | 46+b×8                                   |                              |                                         |                |          |           |           |     |           |        |            |           |                   |
|                 | BIT b,(IY+ | d)        | 11    | 111  | 101    | FD                                       |                              | X                                       | •              | X        | 1         | Х         | x   | 0         | -      | 5          | 20        |                   |
| ⊢ ⊢             |            |           | 11 (  | 001  | 011    | СВ                                       | Z←(IY+d)b                    |                                         |                |          |           |           |     |           |        |            |           |                   |
| s               |            |           | dd (  | bbt  | ddd    | d                                        |                              |                                         |                |          |           |           |     |           |        |            |           |                   |
| ш               | [          |           | 01 1  | bb   | 110    | 46+b×8                                   |                              |                                         | İ              | <u>.</u> |           |           |     |           |        |            |           |                   |
| ۳.              | SET b,r    |           | 11 (  | 001  | 011    | СВ                                       | rb←1                         | -                                       | - 1            | X        | -         | Х         | -   | -         | -      | 2          | 8         | <u></u>           |
| 0               |            |           | 11 1  | bb   |        | CO+b×8+r                                 |                              |                                         | ļ              | <u>.</u> |           |           |     |           |        |            |           | в 000             |
| z               | SET b,(HL) |           | 11 0  | 001  | 011    | СВ                                       | (HL) <sub>b</sub> ←1         | -                                       | -              | X        | -         | Х         | -   | -         | -      | 4          | 15        | C 001             |
| ∢               |            |           | 11 1  | bb   | 110    | C6+b×8                                   |                              |                                         | ļ              | ļ        |           |           |     |           |        |            |           | D 010             |
| ⊢ ⊢             | SEI D,(IX+ | d)        |       | )11  | 101    | 00                                       | (1X+d)b+1                    | -                                       | -              | X        | -         | Х         | -   | -         | -      | 6          | 23        | E 011             |
| ш               |            |           |       | 101  | 011    | CB                                       |                              |                                         |                |          |           |           |     |           |        | l I        |           | H 100             |
| s               |            |           |       | 100  | 410    | d                                        |                              |                                         |                |          |           |           |     |           |        | l          |           |                   |
| ш               |            |           |       | 111  | 101    |                                          | (TV) = )                     |                                         |                | ÷        | ·····     |           |     |           |        | <u>.</u> . |           | <u></u>           |
| ۳.              | 3E1 D,(117 | u )       | 111   | 111  | 011    |                                          | (11+0)P+1                    | -                                       | -              |          | -         |           | -   | -         | -      | 6          | 23        | b bbb             |
| ⊢               |            |           | ad a  | 444  | 444    | d                                        |                              |                                         | 1              | 1        |           |           |     |           | -      |            |           | 0 000             |
| ш               |            |           | 111   | hh   | 110    | C6+b x 8                                 |                              |                                         |                | 1        |           |           |     |           |        |            |           | 1 001             |
| S               | RES b.r    | •••••     | 11 0  | 0.1  | 011    | CB                                       |                              | ···                                     | <br>           | y Y      | · · · · · | ¥         |     | · · · · · | ·      | 2          | 8         | 2 010             |
| ⊢ ⊢             |            |           | 10 1  | bb   | rrr    | 80+b × 8+r                               |                              |                                         |                | <b>^</b> |           | n         |     |           |        | -          | Ŭ         | 3 011             |
| -               | RES b.(HL) | • • • • • | 11 (  | 001  | 011    | СВ                                       | (HL)∺+0                      | ·  · _ ·                                | 1              | Ϋ́       |           | x         |     | : _ ·     |        | 4          | 15        | 4 100             |
| ω.              |            |           | 10 1  | obb  | 110    | 86+b×8                                   |                              | 1                                       | 1              | 1        |           |           |     |           |        |            |           | 5 101             |
|                 | RES b,(IX+ | d )       | 11 (  | 011  | 101    | DD                                       | (IX+d) <sub>b</sub> ←0       | - 1                                     |                | X        | -         | X         |     | -         | -      | 6          | 23        | 6 110             |
|                 |            |           | 11 0  | 001  | 011    | СВ                                       |                              |                                         |                |          |           |           |     |           |        |            |           | 7 111             |
|                 |            |           | dd o  | bbb  | ddd    | d                                        |                              |                                         |                |          |           |           |     |           |        |            |           |                   |
|                 |            |           | 10 H  | bb   | 110    | 86+b×8                                   |                              |                                         | Ì              | <u>.</u> |           |           |     |           |        |            |           |                   |
|                 | RES b,(IY+ | d)        | 11 :  | 111  | 101    | FD                                       | (IY+d)b←0                    | -                                       | -              | х        | -         | Х         | -   | -         |        | 6          | 23        |                   |
|                 |            |           | 11 (  | 001  | 011    | СВ                                       |                              |                                         |                |          |           |           |     |           |        |            |           |                   |
|                 |            |           | dd d  | bbt  | ddd    | d                                        |                              |                                         | ;              | 1        |           |           |     |           |        |            |           |                   |
|                 |            |           | 10 1  | bb   | 110    | 86+b×8                                   |                              |                                         | <u> </u>       |          |           |           |     |           |        |            |           |                   |
|                 | JP mn      |           | 111 0 | 000  | 011    | C3                                       | PC←mn                        | -                                       | -              | X        | -         | х         | -   | -         |        | 3          | 10        |                   |
|                 |            |           | nn r  | inn  | nnn    | n                                        |                              |                                         |                |          |           |           |     |           |        |            |           |                   |
|                 | 10 0 mn    | • • • • • | 11    |      | 010    | () () () () () () () () () () () () () ( | DC t-mp                      | · • • • • • • • • • • • • • • • • • • • |                | ÷        |           | · · · · · |     |           | ·····' | ····       |           | e represents the  |
|                 | 0F 0,1111  |           |       |      | 010    | 02+0×0                                   | (Only when condition is mot) | -                                       | -              |          | -         |           | -   | -         | -      | 3          | 10        | extension in the  |
|                 |            |           | mm    | nmm  | mmm    | m                                        | (only when condition is met) |                                         |                |          |           |           |     |           |        |            |           | addressing        |
|                 | JR \$+e    | • • • • • | 00 0  | )11  | 000    | 18                                       | PC←\$+e                      | ·····                                   | ·              | Ϋ́       | · _ ·     | Ŷ         |     | <u> </u>  | ·      |            | 12        | mode, $a = e - 2$ |
| ۵.              | • • •      |           | aa    | iaa  | aaa    | a                                        | 10.0.0                       |                                         |                | : ^      |           | Ŷ         |     |           |        | 5          | 12        | e is a signed     |
| Σ               | JR C.\$+e  |           | 00    | 11   | 000    | 38                                       | If C=0, continue             |                                         | -              | x        | _         | x         | _   | _         | _      | 2          | 7         | two's             |
|                 |            |           | aa a  | aa   | aaa    | a                                        | lf C=1, PC←\$+e              |                                         | -              | x        | -         | x         | -   | _         | _      | 3          | 12        | complement        |
|                 | JR NC,\$+e | • • • • • | 00 1  | 10   | 000    | 30                                       | If C=0, PC←\$+e              | -                                       | -              | X        | - 1       | Х         | -   |           | -      | 3          | 12        | number in the     |
|                 |            |           | aa a  | aa   | aaa    | а                                        | If C=1, continue             | -                                       | -              | X        | -         | Х         | -   | -         | -      | 2          | 7         | range of          |
|                 | JR Z,\$+e  |           | 00    | 01   | 000    | 28                                       | If Z=0, continue             | 1-                                      | -              | X        | -         | Х         | -   | -         | -      | 2          | 7         | -126≲e≤129        |
|                 |            |           | aa a  | aa   | aaa    | a                                        | lf Z=1, PC←\$+e              | -                                       | -              | X        | -         | X         | -   | -         | -      | 3          | 12        |                   |
|                 | JR NZ,\$+e |           | 00 1  | 100  | 000    | 20                                       | lf Z=0, PC←\$+e              |                                         | l. –           | X        | -         | X         |     | -         | - 1    | 3          | 12        |                   |
|                 |            |           | aa a  | aa   | aaa    | a                                        | If Z=1, continue             |                                         | -              | X        | -         | X         |     | -         |        | 2          | 7         |                   |
|                 | DJNZ \$+e  |           | 00 0  | 010  | 000    | 10                                       | B+B−1, If B=0, continue      |                                         |                | X        | -         | X         | -   |           | -      | 2          | 8         |                   |
|                 |            |           | aa a  | aa   | aaa    | a                                        | B←B−1, If B<>0, continue     |                                         | <del>.</del> . | X        |           | . X.      |     |           |        | 3          | 13        |                   |
|                 | JP (HL)    |           | 11 1  | 01   | 001    | E9                                       | PC+HL                        | -                                       | : -            | : X      | -         | Х         | -   | -         | : -    | 1          | 4         | I                 |
|                 |            |           |       |      |        |                                          |                              |                                         |                |          |           |           |     |           |        |            | c   c c   | c Condition       |

Note: • a = e - 2 in the Opcode provides an effective address of PC + e as PC is incremented by 2 before the addition of e.

• \$ indicates the reference to the location counter value of the current segment.

• The notation (HL)<sub>b</sub>, (IX + d)<sub>b</sub> indicates bit  $_{\rm b}$  (0 to 7) within the contents of the register pair.

• The notation r<sub>b</sub> indicates bit <sub>b</sub> (0 to 7) within the r register.

• a = e-2 in the op-code provides effective address of PC + e as PC is incremented by 2 prior to the addition of e.

Z 001 Zero NC 010 No-carry C 011 Carry P0 100 Odd Parity PE 101 Even Parity P 110 Sign Positive

NZ 000 Non-Zero

M 111 Sign Negative

270489

#### MPUZ80-343

### TMPZ84C011A Instruction Set (9/9)

| ITEM/  | Assembler | Object                   | code     | -                                   |     |    |          | F | ag |          |          |   | No.<br>OF | No.<br>OF |            |            |     |
|--------|-----------|--------------------------|----------|-------------------------------------|-----|----|----------|---|----|----------|----------|---|-----------|-----------|------------|------------|-----|
| -FICA- | mnemonic  | Binary                   | Hex      | Function                            |     |    |          |   |    |          |          |   | CY-       | STA-      |            |            |     |
| TION   |           | 76 543 210               |          |                                     | s   | z  |          | н |    | P/V      | N        | С | CLES      | TES       |            |            |     |
| 4      | JP (IX)   | 11 011 101<br>11 101 001 | DD<br>E9 | PC←(IX)                             | -   | -  | х        | - | х  | -        | -        | - | 2         | 8         |            |            |     |
| 0 7    | JP (IY)   | 11 111 101               | FD       | PC←(IY)                             | -   | -  | х        | - | Х  | -        | -        | - | 2         | 8         |            |            |     |
|        | CALL mn   | 11 001 101               | CD       | (SP-1)+PCu, (SP-2)+PCI              | -   | _  | x        | - | x  |          | <u>.</u> | - | 5         | 17        | il         | kkk        |     |
| z      |           | nn nnn nnn               | n        | PC←mn                               |     |    | <i>^</i> |   | î  |          |          |   | ľ         |           | OOH        | 000        |     |
| ∝      |           |                          | m        | SP←SP-2                             |     |    |          |   |    |          | :        |   |           |           | 08H        | 001        |     |
| 2      | CALL c,mn | 11 ccc 100               | C4+cX8   | If condition c is met, same as      | -   | -  | X        | - | Х  | -        | - 1      | - | 5         | 17        | 10H        | 010        |     |
|        |           | nn nnn nnn               | n        | CALL mn.                            |     |    |          |   |    |          |          |   |           |           | 18H        | 011        |     |
| α      |           | <i>mm mmm mm</i> m       | m        | If condition c is not met, continue | -   | -  | X        | - | Х  | -        | - 1      | - | 3         | 10        | 20H        | 100        |     |
|        | RET       | 11 001 001               | C9       | PCL←(SP), PCH←(SP+1)<br>SP←SP+2     | -   | -  | х        | - | х  | -        | -        | - | 3         | 10        | 28H<br>30H | 101<br>110 |     |
| z      | RET C     | 11 ccc 000               | C0+c×8   | If condition c is met, same as RET. | -   | -  | X        | _ | X  |          |          | - | 3         | 11        | 38H        | 111        |     |
| ∢      |           |                          |          | If condition c is not met, continue | -   | _  | X        | - | Х  | -        | ÷        | - | 1         | 5         |            |            |     |
|        | RETI      | 11 101 101               | ED       | Return from interrupt Processing    | -   | _  | X        | - | Х  | -        |          | - | 4         | 14        | r ri       | rr         |     |
|        |           | 01 001 101               | 4D       | routine                             |     |    |          |   |    |          |          |   |           | 1         | B 00       | 00         |     |
| ∣∢     | RETN      | 11 101 101               | ED       | Return from non-maskable            | -   | -  | х        | - | Х  | -        | -        | - | 4         | 14        | C 00       | 01         |     |
|        |           | 01 000 101               | 45       | interrupt Processing routine        |     |    |          |   |    |          |          |   |           |           | D 0:       | 10         |     |
|        | RST j     | 11 kkk 111               | C7+k×8   | (SP-1)←PC <sub>H</sub> ,(SP-2)←PCL  | - 1 | -  | Х        | - | Х  | -        | -        | - | 3         | 11        | E 0:       | 11         |     |
|        |           |                          |          | PCH←0,PCL←j,SP←SP-2                 |     |    |          |   |    |          |          |   |           |           | H 10       | 00         |     |
|        | IN A,(n)  | 11 011 011               | DB       | A←(n)                               | -   | -  | X        | - | Х  | -        |          | - | 3         | 11        | L 10       | 01         |     |
| ]      |           | nn nnn nnn               | n        | n→A0~A7,A→A8~A15                    | l   |    |          |   |    |          | <u>.</u> |   |           | l         | A 1:       | 11         |     |
|        | IN r,(C)  | 11 101 101               | ED       | r←(C) if r=110, only the flags      | *   | •  | x        | * | Х  | P        | 0        | - | 3         | 12        |            |            |     |
|        |           | 01 rrr 000               | 40+rx8   | will be affected.                   |     |    |          |   |    | <u>.</u> | <u>.</u> |   | l         |           |            |            |     |
| 5      | INI       | 11 101 101               | ED       | (HL)←(C),B←B−1,HL←HL+1              | X   | *м | X        | Х | Х  | х        | 1        | х | 4         | 16        |            |            |     |
| ۵.     |           | 10 100 010               | A2       |                                     |     |    |          |   |    |          | <u>.</u> |   |           |           |            |            |     |
|        | INIR      | 11 101 101               | ED       | (HL)←(C),B←B−1,HL←HL+1              | X   | 1  | х        | х | Х  | х        | 1        | х | 5         | 21        | ←[B<>      | 0]         |     |
|        |           | 10 110 010               | B2       | Repeat until B=0                    |     |    | ļ        |   |    | <u>;</u> | į        | į | . 4       | 16        | ←[B=0      | 3          | *1  |
| 0      | IND       | 11 101 101               | ED       | (HL)←(C),B←B−1,HL←HL−1              | X   | *м | х        | х | Х  | X        | 1        | x | 4         | 16        |            |            |     |
|        |           | 10 101 010               | AA       |                                     |     |    |          |   |    | <u>.</u> |          |   |           |           |            | l          |     |
| z      | INDR      | 11 101 101               | ED       | (HL)←(C),B←B−1,HL←HL−1              | X   | 1  | x        | x | х  | X        | 1        | X | 5         | 21        | +[B<>      | •0]        |     |
| ∢      |           | 10 111 010               | BA       | Repeat until B=0                    |     |    | ļ        |   |    | <u>.</u> | <u>.</u> |   | . 4       | 16        | ←[B=0      | ן ני       |     |
|        | OUT (n),A | 11 010 011               | D3       | (n)←A                               | -   | -  | x        | - | Х  | -        |          | - | 3         | 11        |            |            |     |
| 5      |           | nn nnn nnn               | n        | n→A0~A7,A→A8~A15                    |     |    |          |   |    | <u>.</u> | <u>.</u> | i |           |           |            |            |     |
| ۵.     | 0UT (C),r | 11 101 101               | ED       | (C)+r                               | -   | -  | X        | - | Х  | -        | -        | - | 3         | 12        |            |            |     |
| z      |           | 01 rrr 001               | 41+rX8   |                                     |     |    |          |   |    | <u>.</u> | <u>.</u> |   | 1         |           |            |            |     |
| -      | OUTI      | 11 101 101               | ED       | (C)←(HL),B←B−1,HL←HL+1              | X   | *м | X        | x | Х  | X        | 1        | X | 4         | 16        |            |            |     |
|        |           | 10 100 011               | A3       |                                     |     |    |          |   |    |          | <u>.</u> |   |           |           |            |            |     |
|        | OTIR      | 11 101 101               | ED       | (C)←(HL),B←B-1,HL←HL+1              | X   | 1  | х        | Х | х  | X        | 1        | х | 5         | 21        | ←B[<>      | 0]         |     |
|        |           | 10 110 011               | B3       | Repeat until B=0                    |     |    |          |   |    | <u>.</u> | <u>.</u> |   | . 4       | 16        | ←[B=0      | ]          | 1.1 |
|        | OUTD      | 11 101 101               | ED       | (C)←(HL),B←B−1,HL←HL−1              | X   | *м | х        | Х | х  | X        | 1        | X | 4         | 16        |            |            |     |
|        |           | 10 101 011               | AB       |                                     |     |    |          |   |    | ļ        | ļ        | ļ |           |           |            |            | l   |
|        | UIDR      | 11 101 101               | ED       | (C)←(HL),B←B-1,HL←HL-1              | X   | 1  | X        | X | X  | X        | 1        | X | 5         | 21        | +[B<>      | >0]        |     |
| . 1    |           | 1 10 111 010             | 1 88     | I Report until R=0                  |     |    |          |   |    |          |          |   |           |           |            | 1.1        | ŧ.  |

Note : • \*M If the result of B – 1 is zero, the Z flag is set, otherwise it is reset. • A0 through A15 indicate the address bus.

• [ ] indicates the total condition of the number of cycles and states indicated by arrow.



### TMPZ84C011A Instruction Map (1/7)

|        |               |               |               |               |                |               |                |               |             | ( + )        |               |              |                |             |                |             |
|--------|---------------|---------------|---------------|---------------|----------------|---------------|----------------|---------------|-------------|--------------|---------------|--------------|----------------|-------------|----------------|-------------|
| L<br>H | 0             | 1             | 2             | 3             | 4              | 5             | 6              | 7             | 8           | 9            | A             | В            | с              | D           | E              | F           |
| 0      | NOP           | LD<br>BC, mn  | LD<br>(BC), A | INC<br>BC     | INC<br>B       | DEC<br>B      | LD<br>B, n     | RLCA          | EX<br>AF,AF | ADD<br>HC,BC | LD<br>A, (BC) | DEC<br>BC    | INC<br>C       | DEC<br>C    | LD<br>C, n     | RRCA        |
| 1      | DJNZ<br>e     | LD<br>DE, mn  | LD<br>(DE), A | INC<br>DE     | INC<br>D       | DEC<br>D      | LD<br>D,N      | RLA           | JE<br>e     | ADD<br>HL,DE | LD<br>A, (DE) | DEC<br>DE    | INC<br>E       | DEC<br>E    | LD<br>E, n     | RRA         |
| 2      | JR NZ,<br>e   | LD<br>HL, mn  | LD<br>(mn),HL | INC<br>HL     | INC<br>D       | DEC<br>H      | LD<br>H, n     | DAA           | JR Z<br>e   | ADD<br>HL,HL | LD<br>HL,(mn) | DEC<br>HL    | INC<br>L       | DEC<br>L    | LD<br>L, n     | CPL         |
| 3      | JR NC,<br>e   | LD<br>SP, mn  | LD<br>(mn),A  | INC<br>SP     | INC<br>(HL)    | DEC<br>(HL)   | LD<br>(HL), n  | SCF           | JR C<br>e   | ADD<br>HL,SP | LD<br>A,(mn)  | DEC<br>SP    | INC<br>A       | DEC<br>A    | LD<br>A, n     | CCF         |
| 4      | LD<br>B, B    | LD<br>B, C    | LD<br>B, D    | LD<br>B, E    | LD<br>B, H     | LD<br>B, L    | LD<br>B, (HL)  | LD<br>B, A    | LD<br>C, B  | LD<br>C, C   | LD<br>C, D    | LD<br>C, E   | LD<br>C, H     | LD<br>C, L  | LD<br>C, (HL)  | LD<br>C, A  |
| 5      | LD<br>D, B    | LD<br>D, C    | LD<br>D, D    | LD<br>D, E    | LD<br>D, H     | LD<br>D, L    | LD<br>D, (HL)  | LD<br>D, A    | LD<br>E, B  | LD<br>E, C   | LD<br>E, D    | LD<br>E, E   | LD<br>E, H     | LD<br>E, L  | LD<br>E, (HL)  | LD<br>E, A  |
| 6      | LD<br>H, B    | LD<br>H, C    | LD<br>H, D    | LD<br>H, E    | LD<br>H, H     | LD<br>H, L    | LD<br>H, (HL)  | LD<br>H, A    | LD<br>L, B  | LD<br>L, C   | LD<br>L, D    | LD<br>L, E   | LD<br>L, H     | LD<br>L, L  | LD<br>L, (HL)  | LD<br>L, A  |
| 7      | LD<br>(HL), B | LD<br>(HL), C | LD<br>(HL), D | LD<br>(HL), E | LD<br>(HL), H  | LD<br>(HL), L | HALT           | LD<br>(HL), A | LD<br>A, B  | LD<br>A, C   | LD<br>A, D    | LD<br>A, E   | LD<br>A, H     | LD<br>A, L  | LD<br>A, (HL)  | LD<br>A, A  |
| 8      | ADD<br>A, B   | ADD<br>A, C   | ADD<br>A, D   | ADD<br>A, E   | ADD<br>A, H    | ADD<br>A, L   | ADD<br>A, (HL) | ADD<br>A, A   | ADC<br>A, B | ADC<br>A, C  | ADC<br>A, D   | ADC<br>A, E  | ADC<br>A, H    | ADC<br>A, L | ADC<br>A, (HL) | ADC<br>A, A |
| 9      | SUB<br>B      | SUB<br>C      | SUB<br>D      | SUB<br>E      | SUB<br>H       | SUB<br>L      | SUB<br>(HL)    | SUB<br>A      | SBC<br>A, B | SBC<br>A, C  | SBC<br>A, D   | SBC<br>A, E  | SBC<br>A, H    | SBC<br>A, L | SBC<br>A, (HL) | SBC<br>A, A |
| A      | AND<br>B      | AND<br>C      | AND<br>D      | AND<br>E      | AND<br>H       | AND<br>L      | AND<br>(HL)    | AND<br>A      | XOR<br>B    | XOR<br>C     | XOR<br>D      | XOR<br>E     | XOR<br>H       | XOR<br>L    | XOR<br>(HL)    | XOR<br>A    |
| В      | OR<br>B       | OR<br>C       | OR<br>D       | OR<br>E       | OR<br>H        | OR<br>L       | OR<br>(HL)     | OR<br>A       | CP<br>B     | CP<br>C      | CP<br>D       | CP<br>E      | СР<br>Н        | CP<br>L     | CP<br>(HL)     | XOR<br>A    |
| с      | RET<br>NZ     | POP<br>BC     | JP NZ,<br>mn  | JP<br>mn      | CALL<br>NZ, mn | PUSH<br>BC    | ADD<br>A, n    | RST<br>00H    | RET<br>C    | RET          | JP Z,<br>mn   | 1            | CALL<br>Z, mn  | CALL<br>mn  | ADC<br>A, n    | RST<br>08H  |
| D      | RET<br>NC     | POP<br>DE     | JP NC,<br>mn  | OUT<br>(n), A | CALL<br>NC, mn | PUSH<br>DE    | SUB<br>n       | RST<br>10H    | RET<br>C    | EXX          | JP C,<br>mn   | IN<br>A, (n) | CALL<br>C, mn  | 3           | SBC<br>A, n    | RST<br>18H  |
| E      | RET<br>PO     | POP<br>HL     | JP PO,<br>mn  | EX<br>(SP),HL | CALL<br>PO, mn | PUSH<br>HL    | AND<br>n       | RST<br>20H    | RET<br>PE   | JP<br>(HL)   | JP PE,<br>mn  | EX<br>DE,HL  | CALL<br>Pl, mn | 2           | XOR<br>n       | RST<br>28H  |
| F      | RET<br>P      | POP<br>AF     | JP P,<br>mn   | DI            | CALL<br>P, mn  | PUSH<br>AF    | OR<br>n        | RST<br>30H    | RET<br>M    | LD<br>SP, HL | JP M,<br>mn   | EI           | CALL<br>M, mn  | 4           | CP<br>n        | RST<br>38H  |
|        |               |               |               |               | •••••          |               |                |               |             | •            | •             |              | •              |             | •              | 120489      |

MPU Instruction Table (I)

Note  $\textcircled{O} \sim \textcircled{A}$ : Multi-Opcode Instructions (ref. Table (II )~(VI))

# TMPZ84C011A Instruction Map (2/7)

# ① Byte 1 "CB"

| L<br>H | 0           | 1           | 2           | 3           | 4           | 5           | 6              | 7           | 8           | 9           | A           | В           | с                                     | D           | E              | F           |
|--------|-------------|-------------|-------------|-------------|-------------|-------------|----------------|-------------|-------------|-------------|-------------|-------------|---------------------------------------|-------------|----------------|-------------|
| 0      | RLC            | RLC         | RRC         | RRC         | RRC         | RRC         | RRC                                   | RRC         | RRC            | RRC         |
|        | B           | C           | D           | E           | H           | L           | (HL)           | A           | B           | C           | D           | E           | H                                     | L           | (HL)           | A           |
| 1      | RL             | RL          | RR          | RR          | RR          | RR          | RR                                    | RR          | RR             | RR          |
|        | B           | C           | D           | E           | H           | L           | (HL)           | A           | B           | C           | D           | E           | H                                     | L           | (HL)           | A           |
| 2      | SLA            | SLA         | SRA         | SRA         | SRA         | SRA         | SRA                                   | SRA         | SRA            | SRA         |
|        | B           | C           | D           | E           | H           | L           | (HL)           | A           | B           | C           | D           | E           | H                                     | L           | (HL)           | A           |
| 3      |             |             |             |             |             |             |                |             | SRL<br>B    | SRL<br>C    | SRL<br>D    | SRL<br>E    | SRL<br>H                              | SRL<br>L    | SRL<br>(HL)    | SRL<br>A    |
| 4      | BIT         | ВІТ         | BIT         | BIT         | віт         | BIT         | BIT            | BIT         | BIT         | ВІТ         | BIT         | BIT         | ВІТ                                   | BIT         | BIT            | BIT         |
|        | O, B        | 0, С        | 0, D        | O, E        | 0, н        | 0, L        | 0,(HL)         | 0, A        | 1, B        | 1, С        | 1, D        | 1, E        | 1, Н                                  | 1, L        | 1, (HL)        | 1, A        |
| 5      | BIT         | BIT         | BIT         | BIT         | ВІТТ        | BIT         | BIT            | BIT         | BIT         | ВІТ         | BIT         | BIT         | ВІТ                                   | BIT         | BIT            | BIT         |
|        | 2, B        | 2, C        | 2, D        | 2, E        | 2, Н        | 2, L        | 2, (HL)        | 2, A        | 3, B        | 3, С        | 3, D        | 3, E        | 3, Н                                  | 3, L        | 3, (HL)        | 3, A        |
| 6      | BIT         | ВІТ         | BIT         | BIT         | ВІТ         | BIT         | BIT            | BIT         | BIT         | BIT         | BIT         | BIT         | ВІТ                                   | BIT         | BIT            | BIT         |
|        | 4, B        | 4, С        | 4, D        | 4, E        | 4, Н        | 4, L        | 4, (HL)        | 4, A        | 5, B        | 5, C        | 5, D        | 5, E        | 5, Н                                  | 5, L        | 5, (HL)        | 5, A        |
| 7      | BIT         | ВІТ         | BIT         | BIT         | ВІТ         | BIT         | BIT            | BIT         | BIT         | BIT         | BIT         | BIT         | ВІТ                                   | BIT         | BIT            | BIT         |
|        | 6, B        | 6, С        | 6, D        | 6, E        | 6, Н        | 6, L        | 6, (HL)        | 6, A        | + 7, B      | 7, C        | 7, D        | 7, E        | 7, Н                                  | 7, L        | 7, (HL)        | 7, A        |
| 8      | RES            | RES         | RES         | RES         | RES         | RES         | RES                                   | RES         | RES            | RES         |
|        | O, B        | 0, C        | 0, D        | 0, E        | 0, H        | 0, L        | 0, (HL)        | 0, A        | 1, B        | 1, C        | 1, D        | 1, E        | 1, H                                  | 1, L        | 1, (HL)        | 1, A        |
| 9      | RES<br>2, B | RES<br>2, C | RES<br>2, D | RES<br>2, E | RES<br>2, H | RES<br>2, L | RES<br>2, (HL) | RES<br>2, A | RES<br>3, B | RES<br>3, C | RES<br>3, D | RES<br>3, E | <ul> <li>RES</li> <li>3, H</li> </ul> | RES<br>3, L | RES<br>3, (HL) | RES<br>3, A |
| A      | RES            | RES         | RES         | RES         | RES         | RES         | RES                                   | RES         | RES            | RES         |
|        | 4, B        | 4, C        | 4, D        | 4, E        | 4, H        | 4, L        | 4, (HL)        | 4, A        | 5, B        | 5, C        | 5, D        | 5, E        | 5, H                                  | 5, L        | 5, (HL)        | 5, A        |
| В      | RES            | RES         | RES         | RES         | RES         | RES         | RES                                   | RES         | RES            | RES         |
|        | 6, B        | 6, C        | 6, D        | 6, E        | 6, H        | 6, L        | 6, (HL)        | 6, A        | 7, B        | 7, C        | 7, D        | 7, E        | 7, H                                  | 7, L        | 7, (HL)        | 7, A        |
| с      | SET            | SET         | SEТ         | SET         | SET         | SET         | SEТ                                   | SET         | SET            | SET         |
|        | 0, B        | 0, C        | 0, D        | O, E        | 0, H        | 0, L        | 0, (HL)        | 0, A        | 1, В        | 1, C        | 1, D        | 1, E        | 1, Н                                  | 1, L        | 1, (HL)        | 1, A        |
| D      | SET            | SET         | SEТ         | SET         | SET         | SEТ         | SET                                   | SET         | SET            | SET         |
|        | 2, B        | 2, C        | 2, D        | 2, E        | 2, H        | 2, L        | 2, (HL)        | 2, A        | 3, В        | 3, C        | 3, D        | 3, Е        | 3, Н                                  | 3, L        | 3, (HL)        | 3, A        |
| E      | SET            | SET         | SET         | SET         | SET         | SET         | SET                                   | SET         | SET            | SET         |
|        | 4, B        | 4, C        | 4, D        | 4, E        | 4, Н        | 4, L        | 4, (HL)        | 4, A        | 5, B        | 5, C        | 5, D        | 5, E        | 5, Н                                  | 5, L        | 5, (HL)        | 5, A        |
| F      | SET            | SET         | SEТ         | SET         | SET         | SET         | SET                                   | SET         | SET            | SET         |
|        | 6, B        | 6, C        | 6, D        | 6, E        | 6, Н        | 6, L        | 6, (HL)        | 6, A        | 7, В        | 7, C        | 7, D        | 7, E        | 7, Н                                  | 7, L        | 7, (HL)        | 7, A        |

# TMPZ84C011A Instruction Map (3/7)

# ② Byte 1 "ED"

# Instruction Table (III) (Byte 2 of 2-byte Opcode)

| L<br>H | 0            | 1             | 2            | 3             | 4   | 5    | 6   | 7          | 8            | 9             | A            | В             | с | D    | Е   | F          |
|--------|--------------|---------------|--------------|---------------|-----|------|-----|------------|--------------|---------------|--------------|---------------|---|------|-----|------------|
| 0      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 1      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 2      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 3      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 4      | IN<br>B, (C) | ОUТ<br>(С), В | SBC<br>HL,BC | LD<br>(mn),BC | NEG | RETN | IMO | LD<br>I, A | IN<br>C, (C) | OUT<br>(C), C | ADC<br>HL,BC | LD<br>BC,(mn) |   | RETI |     | LD<br>R, A |
| 5      | IN<br>D, (C) | OUT<br>(C), D | SBC<br>HL,DE | LD<br>(mn),DE |     |      | IM1 | LD<br>A, I | IN<br>E, (C) | OUT<br>(C), E | ADC<br>HL,DE | LD<br>DE,(mn) |   |      | IM2 | LD<br>A, R |
| 6      | IN<br>H, (C) | ОUТ<br>(С), Н | SBC<br>HL,HL | LD<br>(mn),HL |     |      |     | RRD        | IN<br>L, (C) | OUT<br>(C), L | ADC<br>HL,HL | LD<br>HL,(mn) |   |      |     | RLD        |
| 7      |              |               | SBC<br>HL,SP | LD<br>(mn),SP |     |      |     |            | IN<br>A, (C) | OUT<br>(C), A | ADC<br>HL,SP | LD<br>SP,(mn) |   |      |     |            |
| 8      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 9      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| A      | LDI          | CPI           | INI          | OUTI          |     |      |     |            | LDD          | CPD           | IND          | OUTD          |   |      |     |            |
| В      | LDIR         | CPIR          | INIR         | OTIR          |     |      |     |            | LDDR         | CPDR          | INDR         | OTDR          |   |      |     |            |
| с      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| D      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| E      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| F      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |

# TMPZ84C011A Instruction Map (4/7)

# ③ Byte 1 "DD"

### Instruction Table ( IV ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | A             | В         | с | D | E                  | F |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|---------------|-----------|---|---|--------------------|---|
| 0      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,BC  |               |           |   |   |                    |   |
| 1      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,DE  |               |           |   |   |                    |   |
| 2      |                       | LD<br>IX, mn          | LD<br>(mn), IX        | INC<br>IX             |                       |                       |                       |                       |   | ADD<br>IX, IX | LD<br>IX,(mn) | DEC<br>IX |   |   |                    |   |
| 3      |                       |                       |                       |                       | INC<br>(IX + d)       | DEC<br>(IX + d)       | LD<br>(IX + d)<br>, n |                       |   | ADD<br>IX, SP |               |           |   |   |                    |   |
| 4      |                       |                       |                       |                       |                       |                       | LD B,<br>(IX + d)     |                       |   |               |               |           |   |   | LD C,<br>(IX + d)  |   |
| 5      |                       |                       |                       |                       |                       |                       | LD D,<br>(IX + d)     |                       |   |               |               |           |   |   | LD E,<br>(IX + d)  |   |
| 6      |                       |                       |                       |                       |                       |                       | LD H,<br>(IX + d)     |                       |   |               |               |           |   |   | LD L,<br>(IX + d)  |   |
| 7      | LD<br>(IX + d)<br>, B | LD<br>(IX + d)<br>, C | LD<br>(IX + d)<br>, D | LD<br>(IX + d)<br>, E | LD<br>(IX + d)<br>, H | LD<br>(IX + d)<br>, L |                       | LD<br>(IX + d)<br>; A |   |               |               |           |   |   | LD A,<br>(IX + d)  |   |
| 8      |                       |                       |                       |                       |                       |                       | ADD<br>(IX + d)       |                       |   |               |               |           |   |   | ADC 1,<br>(IX + d) |   |
| 9      |                       |                       |                       |                       |                       |                       | SUB<br>(IX + d)       |                       |   |               |               |           |   |   | SBC A,<br>(IX + d) |   |
| 8      |                       |                       |                       |                       |                       |                       | AND<br>(IX + d)       |                       |   |               |               |           |   |   | XOR<br>(IX + d)    |   |
| 9      |                       |                       |                       |                       |                       |                       | OR<br>(IX + d)        |                       |   |               |               |           |   |   | CP<br>(IX + d)     |   |
| с      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               | 5         |   |   |                    |   |
| D      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               |           |   |   |                    |   |
| E      |                       | POP<br>IX             |                       | EX<br>(SP), IX        |                       | PUSH<br>IX            |                       |                       |   | JP<br>(IX)    |               |           |   |   |                    |   |
| F      |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IX  |               |           |   |   |                    |   |

Note (5: Special 2 byte Opcode Instructions (ref. Table (VI ))

# TMPZ84C011A Instruction Map (5/7)

# ④ Byte 1 "FD"

# Instruction Table ( $\mathbb {V}$ ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | A              | В         | с | D | E                      | F |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|----------------|-----------|---|---|------------------------|---|
| 0      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,BC  |                |           |   |   |                        |   |
| 1      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,DE  |                |           |   |   |                        |   |
| 2      |                       | LD<br>IY, nn          | ID<br>(mn), IY        | INC<br>IY             |                       |                       |                       |                       |   | ADD<br>IY, IY | LD<br>IY, (mn) | DEC<br>IY |   |   |                        |   |
| 3      |                       |                       |                       |                       | INC<br>(IY + d)       | DEC<br>(IY + d)       | LD<br>(IY + d)<br>, n |                       |   | ADD<br>IY, SP |                |           |   |   |                        |   |
| 4      |                       |                       |                       |                       |                       |                       | LD B,<br>(IY + d)     |                       |   |               |                |           |   |   | LD C,<br>(IY + d)      |   |
| 5      |                       |                       |                       |                       |                       |                       | LD D,<br>(IY + d)     |                       |   |               |                |           |   |   | LD E,<br>(IY + d)      |   |
| 6      |                       |                       |                       |                       |                       |                       | LD H,<br>(IY + d)     |                       |   |               |                |           |   |   | LD L,<br>(IY + d)      |   |
| 7      | LD<br>(IY + d)<br>, B | LD<br>(IY + d)<br>, C | LD<br>(IY + d)<br>, D | LD<br>(IY + d)<br>, E | LD<br>(IY + d)<br>, H | LD<br>(IY + d)<br>, L |                       | LD<br>(IY + d)<br>, A |   |               |                |           |   |   | LD A,<br>(IY + d)      |   |
| 8      |                       |                       |                       |                       |                       |                       | ADD<br>(IY + d)       |                       |   |               |                |           |   |   | ADDC<br>A,<br>(IY + d) |   |
| 9      |                       |                       |                       |                       |                       |                       | SUB<br>(IY + d)       |                       |   |               |                |           |   |   | SUBC<br>A,<br>(IY + d) |   |
| 8      |                       |                       |                       |                       |                       |                       | AND<br>(IY + d)       |                       |   |               |                |           |   |   | XOR<br>(IY + d)        |   |
| 9      |                       |                       |                       |                       |                       |                       | OR<br>(IY + d)        |                       |   |               |                |           |   |   | CP<br>(IY + d)         |   |
| с      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                | 6         |   |   |                        |   |
| D      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                |           |   |   |                        |   |
| E      |                       | POP<br>IY             |                       | EX<br>(SP), IY        |                       | PUSH<br>IY            |                       |                       |   | JP<br>(IY)    |                |           |   |   |                        |   |
| F      |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IY  |                |           |   |   |                        |   |

120489

Note ©: Special 2 byte Opcode Instructions (ref. Table (VI))

# TMPZ84C011A Instruction Map (6/7)

⑤ Byte 1 "DD"

Byte 2 "CB"

# Instruction Table (VI) (Special case of 2-byte Opcode : Byte 3)

| L<br>H | 0 | 1 | 2 | 3 | 4 | 5 | 6                  | 7 | 8 | 9 | A | В | с | D | E                  | F |
|--------|---|---|---|---|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0      |   |   |   |   |   |   | RLC<br>(IX + d)    |   |   |   |   |   |   |   | RRC<br>(IX + d)    |   |
| 1      |   |   |   |   |   |   | RL<br>(IX + d)     |   |   |   |   |   |   |   | RR<br>(IX + d)     |   |
| 2      |   |   |   |   |   |   | SLA<br>(IX + d)    |   |   |   |   |   |   |   | SRA<br>(IX + d)    |   |
| 3      |   |   |   |   |   |   |                    |   |   |   |   | - |   |   | SRL<br>(IX + d)    |   |
| 4      |   |   |   |   |   |   | BIT 0,<br>(IX + d) |   |   |   |   |   |   |   | BIT 1,<br>(IX + d) |   |
| 5      |   |   |   |   |   |   | BIT 2,<br>(IX + d) |   |   |   |   |   |   |   | BIT 3,<br>(IX + d) |   |
| 6      |   |   |   |   |   |   | BIT 4,<br>(IX + d) |   |   |   |   |   |   |   | BIT 5,<br>(IX + d) |   |
| 7      |   |   |   |   |   |   | BIT 6,<br>(IX + d) |   |   |   |   |   |   |   | BIT 7,<br>(IX + d) |   |
| 8      |   |   |   |   |   |   | RES 0,<br>(IX + d) |   |   |   |   |   |   |   | RES 1,<br>(IX + d) |   |
| 9      |   |   |   |   |   |   | RES 2,<br>(IX + d) |   |   |   |   |   |   |   | RES 3,<br>(IX + d) |   |
| A      |   |   |   |   |   |   | RES 4,<br>(IX + d) |   |   |   |   |   |   |   | RES 5,<br>(IX + d) |   |
| В      |   |   |   |   |   |   | RES 6,<br>(IX + d) |   |   |   |   |   |   |   | RES 7,<br>(IX + d) |   |
| с      |   |   |   |   |   |   | SET 0,<br>(IX + d) |   |   |   |   |   |   |   | SET 1,<br>(IX + d) |   |
| D      |   |   |   |   |   |   | SET 2,<br>(IX + d) |   |   |   |   |   |   |   | SET 3,<br>(IX + d) |   |
| E      |   |   |   |   |   |   | SET 4,<br>(IX + d) |   |   |   |   |   |   |   | SET 5,<br>(IX + d) |   |
| F      |   |   |   |   |   |   | SET 6,<br>(IX + d) |   |   |   |   |   |   |   | SET 7,<br>(IX + d) |   |

# TMPZ84C011A Instruction Map (7/7)

⑥ Byte 1 "FD"

Byte 2 "CB"

### Instruction Table (VII) (Special case of 2-byte Opcode : Byte 3)

| н | 0 | 1 | 2 | 3 | 4 | 5 | 6                  | 7 | 8 | 9 | А | в | с | D | ε                  | F |
|---|---|---|---|---|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0 |   |   |   |   |   |   | RLC<br>(IY + d)    |   |   |   |   |   |   |   | RRC<br>(IY + d)    |   |
| 1 |   |   |   |   |   |   | RL<br>(IY + d)     |   |   |   |   |   |   |   | RR<br>(IY + d)     |   |
| 2 |   |   |   |   |   |   | SLA<br>(IY + d)    |   |   |   |   |   |   |   | SRA<br>(IY + d)    |   |
| 3 |   |   |   |   |   |   |                    |   |   |   |   |   |   |   | SRL<br>(IY + d)    |   |
| 4 |   |   |   |   |   |   | BIT 0,<br>(IY + d) |   |   |   |   |   |   |   | BIT 1,<br>(IY + d) |   |
| 5 |   |   |   |   |   |   | BIT 2,<br>(IY + d) |   |   |   |   |   |   |   | BIT 3,<br>(IY + d) |   |
| 6 |   |   |   |   |   |   | BIT 4,<br>(IY + d) |   |   |   |   |   |   |   | BIT 5,<br>(IY + d) |   |
| 7 |   |   |   |   |   |   | BIT 6,<br>(IY + d) |   |   |   |   |   |   |   | BIT 7,<br>(IY + d) |   |
| 8 |   |   |   |   |   |   | RES 0,<br>(IY + d) |   |   |   |   |   |   |   | RES 1,<br>(IY + d) |   |
| 9 |   |   |   |   |   |   | RES 2,<br>(IY + d) |   |   |   |   |   |   |   | RES 3,<br>(IY + d) |   |
| А |   |   |   |   |   |   | RES 4,<br>(IY + d) |   |   |   |   |   |   |   | RES 5,<br>(IY + d) |   |
| В |   |   |   |   |   |   | RES 6,<br>(IY + d) |   |   |   |   |   |   |   | RES 7,<br>(IY + d) |   |
| с |   |   |   |   |   |   | SET 0,<br>(IY + d) |   |   |   |   |   |   |   | SET 1,<br>(IY + d) |   |
| D |   |   |   |   |   |   | SET 2,<br>(IY + d) |   |   |   |   |   |   |   | SET 3,<br>(IY + d) |   |
| E |   |   |   |   |   |   | SET 4,<br>(IY + d) |   |   |   |   |   |   |   | SET 5,<br>(IY + d) |   |
| F |   |   |   |   |   |   | SET 6,<br>(IY + d) |   |   |   |   |   |   |   | SET 7,<br>(IY + d) |   |

### 3.3 CGC Operations

This subsection describes the system configuration, functions, and basic operations of the clock generator/controller (CGC).

### 3.3.1 Block Diagram

Figure 3.3.1 shows the block diagram of the CGC.



120489

Figure 3.3.1 Block Diagram

#### 3.3.2 CGC System Configuration

The internal configuration of the CGC is shown in Figure 3.3.1. The waveform from the external oscillated by the internal oscillator and divided by the divider is converted into the square waveform for clock. The clock is controlled by the controller and the counter to be sent to the outside the CGC. The following describes the CGC's main components and their functions.

- (1) Clock Generation
- (2) Operation Modes

### [1] Clock Generation

The CGC contains an oscillator. By connecting oscillating elements to external pins (XTAL1 and XTAL2), the required clock can be produced easily. The CGC provides the clock whose frequency is 1/2 of the oscillation frequency. Figure 3.3.2 shows an example of crystal connection.





Figure 3.3.2 (a) Example of Crystal Connection

Figure 3.3.2 (b) Oscillator Equivalent Circuit

 For the quartz crystal oscillator, use the MR8000-C20 (oscillation frequency 8 MHz) or MR12000-C20 (oscillation frequency 12 MHz) manufactured by Tokyo Denpa Company Ltd., or the equivalent;

| Product No. | Holder<br>Type | Frequency<br>(MHz) | Cin<br>(pF) | Cout<br>(pF) | Quar<br>Para | rtz Crysta<br>meter (1                     | al<br>yp.) | Drive Level<br>(mW) | Condition<br>Load<br>Capacitance |
|-------------|----------------|--------------------|-------------|--------------|--------------|--------------------------------------------|------------|---------------------|----------------------------------|
|             | •••            |                    |             |              | C1 (pr)      | $(p_{F}) \subset_{O}(p_{F}) R_{I}(\Omega)$ |            |                     | (pF)                             |
| MR8000-C20  |                | 8                  | 22          | 33           |              | 4.00                                       | 30.0       |                     | —                                |
| MR8000-C14  | HC-49          | 8                  | 20          | 20           | 0.0189       | 3.87                                       | 6.0        | 0.5                 | 12.67                            |
| MR12000-C20 | -0             | 12                 | 33          | 33           |              | 4.00                                       | 25.0       |                     | —                                |
| MR12000-C14 | (TR-49)        | 12                 | 20          | 20           | 0.0190       | 3.81                                       | 6.9        | 0.5                 | 12.55                            |
| P           |                |                    |             |              |              |                                            |            |                     | 310589                           |

Note: The load capacitance in the condition does not include any stray capacitance.

(2) For the ceramic resonater, use the CSA8.00MT, CST8.00MT (oscillation frequency 8 MHz) or CSA12.00MT, CST12.00MT (oscillation frequency 12 MHz) manufactured by Murata MFG Co., Ltd.

| Product No. | Frequency (MHz) | Cin (pF) | Cout (pF) |
|-------------|-----------------|----------|-----------|
| CSA8.00MT   | 8               | 30       | 30        |
| CST8.00MT   | 8               |          |           |
| CSA12.0MT   | 12              | 30       | 30        |
| CST12.0MT   | 12              |          |           |
|             |                 |          | 190589    |

Note: The CST8.00MT and CST12.0MT need no outer capacitance.

### [2] Operation Modes

The CGC has the capability to control 3 types of operational modes: Run, Idle and Stop. Anyone of them can be selected by MS1, MS2 (Mode Select 1 and 2) pin.

These modes become valid when the MPU executes a HALT instruction. Fetching a HALT instruction, the MPU sets the  $\overline{\text{HALT}}$  signal to "0", telling that it has been put in the halt state. After the execution of the HALT instruction, CGC performs the operation of the specified mode. Table 3.3.1 shows the operations of these modes.

| MS1 | MS2 | Operation Mode | Description                                                                                                         |
|-----|-----|----------------|---------------------------------------------------------------------------------------------------------------------|
| 0   | 0   | ldle mode      | Only the internal oscillator operates, stopping the supply of clock outside. The clock output (CLK) is held at "0". |
| 0   | 1   |                | Not used.                                                                                                           |
| 1   | 0   | Stop mode      | All internal operations are stopped. The clock output (CLK) is held at "0".                                         |
| 1   | 1   | Run mode       | The supply of clock outside is continued.                                                                           |
| •   |     |                | 120489                                                                                                              |

| Table 3.3.1 C | GC Operation | Modes |
|---------------|--------------|-------|
|---------------|--------------|-------|

The restart from the clock stop state in Idle or Stop mode is performed by reset ( $\overline{\text{RESET}}$  signal) or acknowledge of maskable interrupt ( $\overline{\text{INT}}$  signal) or non-maskable interrupt ( $\overline{\text{INT}}$  signal).

### [3] Warm-up Time for Restart (from Stop mode)

Clearing the halt state by interrupt acknowledge, the MPU begins executing interrupt processing. Therefore, when restarting the clock by the  $\overline{\rm NMI}$  or  $\overline{\rm INT}$  restart signal in the Stop mode, its oscillation must be fully stabilized before being supplied outside. The CGC provides, by means of the internal counter, the warm-up time enough for the clock to reach the stabilize frequency. The warm-up ends at the rising edge of the internal counter output derived from dividing the oscillation frequency to start clock output. The warm-up time is equal to the time derived by dividing the frequency of the externally attached oscillator by  $2^{14}$ .

Figure 3.3.3 shows the block diagram of the internal counter. Table 3.3.2 shows the relationship between the oscillation frequency and the warm-up time.

In the restart by the  $\overline{\text{RESET}}$  signal, no warm-up is performed for the quick operation at power-up. Therefore, expand the width of the  $\overline{\text{RESET}}$  signal adequately to provide the warm-up time.



Figure 3.3.3 Block Diagram of Internal Counter

| Тa | able | 3.3 | 3.2 | Warm-up | Time   |
|----|------|-----|-----|---------|--------|
|    | abic | J   |     | wunn up | 1 mile |

| Counter output |        | Warm-up time  |              |
|----------------|--------|---------------|--------------|
| 215            | 214/fc | fXTAL = 12MHz | fXTAL = 8MHz |
| <u>Z</u> 13    | 214/10 | 2.7 ms        | 4 ms         |
|                |        |               | 120489       |

\* fc =  $f_{XTAL}/2$ 

### 3.3.3 CGC Status Transition Diagram and Basic Timing

The following describes the status transition and basic timing to be provided when the CGC operates.

[1] Status Transition Diagram



Figure 3.3.4 Status Transition Diagram

### [2] Basic Timing

The following describes the CGC basic timing.

(1) Operation at execution of HALT instruction

The following describes the basic timing in each mode to be provided when the MPU executes a HALT instruction. The MPU sets the  $\overline{\text{HALT}}$  signal to "0" in synchronization with the falling edge of clock state T4 of the HALT instruction Opcode fetch cycle (M1). This signal tells the CGC that the MPU is going to get in the halt state.

(a) Run mode (MS1 = 1, MS2 = 1)

Figure 3.3.5 shows the basic timing in the Run mode. In the Run mode, the CGC continues supplying the clock to the outside even when the MPU is in the halt state. Therefore, the MPU continues executing NOPs during the halt state. The systems which need memory address refresh use this mode.



Figure 3.3.5 Basic Timing in Run Mode

(b) Idle mode (MS1 = MS2 = 0), and Stop mode (MS1 = 1, MS2 = 0)

Figure 3.3.6 shows the basic timing in the Idle and Stop modes. In these modes, the clock output is stopped with clock state T4 being "0" by the  $\overline{\text{HALT}}$  signal and the  $\overline{\text{M1}}$  signal which follows the HALT instruction.

However, in the Stop mode, the CGC's internal oscillator also stops.



Figure 3.3.6 Basic Timing in Idle and Stop Modes

(2) Clock output restart from each mode

The clock stopped state in the Idle or Stop mode is cleared by setting any of the following signals to "0" (for the system restart operation, see Subsection 3.3.4):

- **INT** (level trigger input)
- <u>NMI</u> (edge trigger input)
- RESET (level trigger input)
- (a) Clock output restart from Idle mode

Figure 3.3.7 shows the basic timing for the sequence of the output restart from the clock stopped state in the Idle mode. In the restart in the Idle mode, the clock output is restarted in a relatively short delay time because the internal oscillator is operating even in the clock stopped state.



### (b) Clock output restart from Stop mode

Figure 3.3.8 shows the basic timing for the sequence of the restart from the clock stopped state in the Stop mode. When restarting by setting the  $\overline{\text{INT}}$  or  $\overline{\text{NMI}}$  signal to "0", the warm-up time is automatically created by the internal counter. In the restart by the  $\overline{\text{RESET}}$  signal. oscillation restarts without warm-up.



#### 3.3.4 Relationship with MPU

The following describes the relationship between the CGC and the MPU mainly in terms of the halt clear operation.

### [1] RESET Signal

Figure 3.3.9 shows an example of the timing for the restart from the Stop mode on the TMPZ84C011A sharing the MPU and CGC  $\overline{\text{RESET}}$  signals. To reset the MPU, the  $\overline{\text{RESET}}$  signal must be set to "0" for at least 3 stable clocks. When the  $\overline{\text{RESET}}$  signal goes "1", the MPU gets out of the halt state after a dummy cycle of 2 clock states to start executing instructions from address 0000H.

To restart the clock output by the RESET signal in the Stop mode, the internal counter to determine the warm-up time does not operate. Therefore, if the MPU does not restart correctly due to the unstable clock output immediately after the restart of the internal oscillator, or when the stability of the crystal at power-up is considered, the RESET signal must be held at "0" for a time long enough for the MPU to be reset securely.



Figure 3.3.9 Example of Clock Restart Timing by RESET Signal

#### [2] Clearing Halt State by Interrupt Signal

The CGC restarts the clock output from the Idle or Stop mode by the input of  $\overline{INT}$  or  $\overline{NMI}$  signal. By this clock, the MPU starts operating. However, when the CGC restarts the clock output, the MPU is still in the halt state executing NOPs. To clear the halt state, the interrupt signal must be entered into the MPU (in the case of the  $\overline{INT}$  signal, the signal for at least one instruction). The MPU interrupt is detected at the rising edge of the last clock of each instruction (NOP for the halt state).

(1) When using non-maskable interrupt (NMI)

MPU's non-maskable interrupt is triggered by edge. The MPU contains the flip-flop to detect an interrupt. That is, the state of this internal NMI flip-flop is sampled at the rising edge of the last clock of each instruction. Therefore, when a short active low ("0") pulse has been inserted before the interrupt detection timing, the interrupt is acknowledged. The  $\overline{\text{NMI}}$  input of the TMPZ84C011A is connected to the  $\overline{\text{NMI}}$  input of the MPU via the CGC, performing the same operations as above. (See Figure 3.3.11.)

(2) When using maskable interrupt (INT)

With a maskable interrupt, the maskable interrupt enable flip- flop (IFF) must be set to "1" by program before "0" of the  $\overline{INT}$  input signal is detected. Even if the CGC accepts the  $\overline{INT}$  signal to restart supply the clock, no interrupt is acknowledge unless the  $\overline{INT}$  signal is kept inserted until one instruction (NOP) has been executed. Figure 3.3.10 shows the timing for clearing the halt state by the interrupt signal.



Figure 3.3.10 Timing for Clearing Halt State by Interrupt Signal

[3] Connecting CGC to MPU on TMPZ84C011A

Figure 3.3.11 shows the connection between the CGC and the MPU on the TMPZ84C011A.



Figure 3.3.11 Connection Between CGC and MPU

MPUZ80-361

### 3.4 CTC Operational Description

The CTC has 4 independent channels. To these channels, addresses are allocated on the TMPZ84C011A's I/O map, permitting the read/write of the channels in the MPU's I/O cycle. (See Figure 3.4.1.) This subsection mainly describes the operation to be performed after the CTC is accessed.

### 3.4.1 CTC Block Diagram

Figure 3.4.1 shows the block diagram of the CTC.





### 3.4.2 CTC System Configuration

The CTC system consists of the following 4 logic circuits:

- (1) MPU bus I/O logic circuit
- (2) Internal control logic circuit
- (3) Interrupt control logic circuit
- (4) Four independent counter/timer channel logic circuits
- [1] MPU Bus I/O Logic Circuit

This circuit transfer data between the MPU and the CTC.

[2] Internal Control Logic Circuit

This circuit controls the CTC's operation functions such as the CTC selector chip enable, reset, and read/write circuits.

[3] Interrupt Control Logic Circuit

This circuit performs the MPU interrupt related processing such as priority determination. The priority with other LSIs is determined by the physical location in daisy chain connection.

[4] Counter/Timer Channel Logic Circuit

This circuit consists of the following 2 registers and 2 counters. Figure 3.4.2 shows the configuration of this circuit.

- Time-constant register (8 bits)
- Channel control register (8 bits)
- Down-counter (8 bits)
- Prescaler (8 bits)



Figure 3.4.2 Configuration of Counter/Timer Channel Logic Circuit

(1) Time-constant register

This register holds the time constant to be written in the down counter. When the CTC is initialized or the down-counter has reached zero, the time constant is loaded into down- counter. The time constant is set immediately after the MPU has written the channel control word to the channel control register. For a time constant, an integer from 1 to 256 can be used.

(2) Channel control register

This register is used to choose the channel mode or condition according to the channel control word sent from the MPU.

(3) Down-counter

The contents of the time-constant register are loaded into the down counter. In the counter mode, these contents are decremented at each edge of the external clock; in the timer mode, they are decremented for each prescaler clock output. The contents of the time-constant register are loaded at initialization or when the down-counter has reached zero.

The contents of the down-counter can be read any time. Also, the system can be programmed so that an interrupt request is generated each time the down-counter has reached zero.

(4) Prescaler

The prescaler, used only in the timer mode, divides the system clock by a factor of 16 or 256. The prescaler factor can be programmed by channel control word. The output of the prescaler becomes the clock input to the down-counter.

### 3.4.3 CTC Basic Operations

### [1] Reset

The state of the CTC is unstable after it is powered on. To initialize the CTC, the low level signal needs to be applied to the  $\overline{\text{RESET}}$  pin. On any channel, the channel control word and time-constant data must be written to the channel to be started before it is started in the counter or timer mode. To program the system to enable interrupts, the interrupt vector word must be written to the interrupt controller. When these data have been written to the CTC, it is ready to start.

### [2] Interrupt

The CTC can cause an interrupt when the MPU is operating in the mode 2. The CTC interrupt can be programmed for each channel. Each time the channel's down-counter has reached zero, the CTC outputs the interrupt request signal ( $\overline{INT}$ ). When the MPU accepts the CTC's interrupt request, the CTC outputs the interrupt vector. Based on this interrupt vector, the MPU specifies the start address of the interrupt processing routine and calls it to start interrupt processing.

Because the MPU specifies the start address of the interrupt processing routine by the interrupt vector from the CTC, the user can change the vector value to call any desired address.

The interrupt processing is terminated when the MPU executes an RETI instruction. The CTC has the circuit which decodes the RETI instruction. By constantly monitoring the data bus CTC can know the termination of the interrupt processing.

The interrupt priority with the Z80 peripheral LSIs is determined by the daisy chain connection. That is, the periperal LSIs are connected in series and physically nearer the MPU, a higher priority is given. Inside the CTC, channel 0 is given the highest priority followed by channels 1, 2 and 3 in this order.

The CTC has the signal lines IEO and IEI. Connect the IEO of a higher peripheral LSI to the IEI of a lower peripheral LSI. Connect the IEI of the highest peripheral LSI to VCC. Leave the IEO of the lowest peripheral LSI unused. In this connection, the CTC interrupt is caused under the following conditions:

- When both IEI and IEO are high, no interrupt is caused. At this time, the INT signal is high. An interrupt can be requested in this state.
- When the CTC outputs the interrupt request signal (INT), the IEO of the CTC becomes low. When the MPU accepts the interrupt, the INT pin goes high again.
- When the IEI goes low, the IEO also goes low.
- While the IEI is low, no interrupt can be requested.
- When the IEI goes low while an interupt is being serviced, the interrupt processing is aborted.

#### [3] Operation Modes

The CTC operates in either the counter mode or the timer mode. Mode selection is programmed by writting the channel control word.

#### (1) Counter mode

In the counter mode, the number of edge of the pulses applied to the channel's CLK/TRG pin is counted. When pulses have been input, the contents of the downcounter are decremented in synchronization with the rising edge of the next system clock. The pulse's rising edge or falling edge to be counted can be specified by the channel control word.

When the down-counter has read zero, the high level pulses is output from the ZC/TO pin. When the interrupt is enabled by the channel control word, the  $\overline{\text{INT}}$  pin goes low and an interrupt is requested. When the down-counter has reached zero, the time constant data written in the time constant register is automatically loaded into the down-counter. To load a new time constant value into the down-counter, write the data to the time constant register, and it is loaded into the down-counter after the end of the current count operation.

#### (2) Timer mode

In the timer mode, the time intervals which are integral multiples of the system clock period. A timer interval is measured against the system clock. The system clock is supplied to the prescaler which divides it by a factor of 16 or 256. The output of the prescaler provides the clock to decrement the down-counter by 1. The time constant data is automatically loaded in the down-counter each time it has reached zero as in the counter mode. When the down-counter has reached zero, the high level pulse is output from the ZC/TO pin.

The period of this pulse is given by the following expression:

tc\*P\*TC

Where, tc = System clock period P = Prescaler value (16 or 256)TC = Time constant data (256 for 00H)

The user can specify, by means of the channel control word, whether to start the timer automatically or not and start the timer at the edge of the pulse at CLK/TRG pin or not, and, if the edge is used, start the timer at the rising edge or the falling edge.

### 3.4.4 CTC Status Transition Diagram and Basic Timing

#### [1] Transition Diagram

Figure 3.4.3 shows the CTC status transition diagram.







120489

Figure 3.4.3 (b) CTC Transition Diagram (b)

#### [2] Basic Timing

### (1) Write cycle

The write cycle is used to write a channel control word, an interrupt vector, or a time constant. The MPU makes low the  $\overline{\text{IORQ}}$  pin of the CTC in the subsequent system clock cycle T2 to start the write cycle. It is required to make high the M1 pin of the CTC to indicate that the write cycle is on.

At the start of the cycle, the channel is specified by  $CS_1(A_1)$  and  $CS_0(A_0)$  of the CTC. Thus, the CTC's internal registers are ready to acquire data in system clock T3. Tw is the wait state to be automatically inserted by the MPU.



Figure 3.4.4 Write Timing

(2) Read cycle

The read cycle is used to read the contents of the down-counter. In system clock cycle T2, the MPU makes low the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins of the CTC to start the read cycle. It is required to make high the  $\overline{\text{M1}}$  pin to indicate that the read cycle is on. At the start of the read cycle, the channel is specified by CS<sub>1</sub> (A<sub>1</sub>) and CS<sub>0</sub> (A<sub>0</sub>) of the CTC. On the rising edge of system clock T<sub>W</sub>, the contents of the down-counter at the time of the rising edge of T2 are put on the data bus. T<sub>W</sub> is the wait state to be automatically inserted by the MPU.





### [3] Counter mode

In the counter mode, the down-counter is decremented in synchronization with the system clock, at the edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be 2 times greater than the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the down-counter is decrmented one system clock later. When the down-counter has reached zero, a high level pulse is output from the ZC/TO pin.



Figure 3.4.6 Counter Mode Timing

### [4] Timer mode

The timer starts operating at the second rising edge of the system clock from the rising edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the timer starts one system clock cycle later.



Figure 3.4.7 Timer Mode Timing

### [5] Interrupt acknowledge cycle

Having received the interrupt request signal ( $\overline{INT}$ ) from the CTC, the MPU makes low the CTC's  $\overline{M1}$  pin and  $\overline{IORQ}$  pin to provide the acknowledge signal. The  $\overline{IORQ}$  pin goes low 2.5 system clocks later than the  $\overline{M1}$  pin. To stabilize the signal lines (IEI and IEO) in daisy chain connection, the interrupt request cannot be changed on each channel while the  $\overline{M1}$  pin is low. The  $\overline{RD}$  pin is held high to make distinction between the instruction fetch cycle and the interrupt acknoledge cycle. While the  $\overline{RD}$  pin is high, the CTC's interrupt control circuit determines the interrupt-requesting channel with the highest priority. When the CTC's IEI is high and the  $\overline{M1}$  pin and  $\overline{IORQ}$  pin go low, the interrupt vector is output from the interrupt requesting channel with the highest priority on the data bus. At this time, 2 system clock cycles are automatically inserted by the MPU as a wait state to maintain the stabilization of the daisy chain connection.



Figure 3.4.8 Interrupt Acknowledge Timing

### [6] Return from interrupt processing

Return from the interrupt processing is performed by MPU's executing the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When this instruction is executed by the MPU, the CTC's IEI and IEO return to the state active before the interrupt has been serviced.

The RETI instruction is a 2-byte instruction. Its code is EDH 4DH. The CTC decodes this instruction to check if there is the next interrupt request channel.

In the diasy chain structure, the interrupting LSI's IEI and IEO are held high and low respectively at the time the instruction code EDH has been decoded.

The code following EDH is 4DH, only the peripheral LSI which has sent the interrupt vector (that is, the LSI whose IEI is high and IEO is low) returns from the interrupt processing. This restarts the processing of the pending interrupt of the next higher peripheral LSI.



Figureure 3.4.9 Interrupt Return Timing

### 3.4.5 CTC Operational Procedure

To operates the CTC in the counter mode or the timer mode, the channel control word and time-constant data must be written to the CTC. To enable interrupts by the channel control word, the interrupt vector must be written to the CTC.

#### [1] I/O Address and Channel Control Word

To write the channel control word to the CTC, the channel must be specified by the corresponding channel I/O address. Table 3.4.1 shows the channel I/O addresses.

| Table 3.4 | I. I Channel I/O Addresses |
|-----------|----------------------------|
| Channel   | I / O address              |
| 0         | #10                        |
| 1         | #11                        |
| 2         | #12                        |
| 3         | #13                        |
|           | 120489                     |

| Table 3.4.1 | Channel I/C | Addresses |
|-------------|-------------|-----------|
|-------------|-------------|-----------|

The channel control word to be written to the CTC consists of 8 bits. The system data bus bit D0 through D7 correspond to bit 0 through 7 respectively. Figure 3.4.10 shows the meaning of each bit. Table 3.4.2 shows the function of each bit.

| D7        | D6                 | D5        | D4   | D3      | D2               | D1    | D0 |
|-----------|--------------------|-----------|------|---------|------------------|-------|----|
| Interrupt | Counter /<br>timer | Prescaler | Edge | Trigger | Time<br>constant | Reset | 1  |

120489

Figure 3.4.10 Channel Control Word

For the channel control word, D0 must always be 1.
| Di+           | Meaning ar                                                                                                                                                                                                                    | nd function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BIL           | 0                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Bit 7<br>(D7) | Disables channel interrupt                                                                                                                                                                                                    | Enables channel interrupt. When this bit is<br>set to "1", the interrupt vector must be<br>written to the CTC before the down-counter<br>starts. When the channel control word<br>whose D7 bit is "1" is written to an already<br>operating channel, the interrupt occurs only<br>when the down-counter has reached zero<br>for the first time after the writing of the<br>new channel control word.                                                                                                                                                                                                                                                                    |
| Bit 6<br>(D6) | Puts the channel in the timer mode. Puts<br>the system clock into the prescaler and<br>outputs the divided signal to the down-<br>counter.                                                                                    | Puts the channel in the counter mode. The<br>down-counter is decremented at the edge<br>trigger entered at the CLK / TRG pin. In the<br>counter mode, the prescaler is not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Bit 5<br>(D5) | Used only in the timer mode. The prescaler<br>is set to that it divides the system clock by<br>16.                                                                                                                            | Used only in the timer mode. The prescaler<br>is set to that it divides the system clock by<br>256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 4<br>(D4) | In the timer mode, the timer operation<br>starts at the falling edge of the trigger pulse<br>(CLK/TRG). In the counter mode, the down-<br>counter is decremented at the falling edge<br>of the external clock pulse (CLK/TRG) | In the timer mode, the timer operation<br>starts at the rising edge of the trigger pulse<br>(CLK/TRG). In the counter mode, the down-<br>counter is decremented at the rising edge of<br>the trigger pulse (CLK/TRG).                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 3<br>(D3) | Used only in the timer mode. The timer<br>operation starts on the rising edge<br>following 2 system clocks after the timer<br>constant has been loaded into the down-<br>counter.                                             | Used only in the timer mode. The timer<br>operation is started by the external trigger<br>pulse. That is, the timer starts opreating at<br>the trigger pulse entered after the rising<br>edge following 2 system clocks after the<br>time constant has been loaded into the<br>down counter. If the interval between the<br>system clock and the trigger pulse satisfies<br>the setup time, the prescaler starts<br>operating on the second rising edge.<br>Otherwise, the prescaler starts operating on<br>the rising edge following 3 system clocks. If<br>the trigger pulse is entered before the time<br>constant is loaded, the same effect as when<br>bit 3 = "0" |

| Table 3.4.2 | Meanings and Functio | n of Channel | Control Words | (1/2) |
|-------------|----------------------|--------------|---------------|-------|
|-------------|----------------------|--------------|---------------|-------|

|               |                                                                                                                                                                                                                                                                                                                                              | (2/2)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|---------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D:4           | Meaning ar                                                                                                                                                                                                                                                                                                                                   | nd function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| ы             | 0                                                                                                                                                                                                                                                                                                                                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Bit 2<br>(D2) | Indicates that the channel control word is<br>not followed by the writing of time<br>constant. When the channel is in the reset<br>state, this bit cannot be set to "0" in the first<br>channel control word. To change states<br>with the time constant unchanged, the<br>channel control word with this bit set to "0"<br>must be entered. | Indicates that the channel control word is<br>followed by the writing of time constant. If<br>the time constant is written during down-<br>counter operation, the new time constant is<br>set to the time constant register with<br>proceeding the current counting. When the<br>down-counter has reached zero, the new<br>time constant is loaded into the down-<br>counter.                                                                                                                              |
| Bit 1<br>(D1) | Continues the current channel operaiton.                                                                                                                                                                                                                                                                                                     | Stops the down-counter operation. When<br>this bit is set to "1", the channel operation<br>stops but the channel control register bits<br>remain unchanged. When bit $2 =$ "1" and<br>bit $1 =$ "1", the channel remains stopped<br>until a new time constant is written.<br>Channel restart is set up after the new time<br>constant is programmed. The channel is<br>restarted according to the state of bit 3.<br>When bit $2 =$ "0" and bit $1 =$ "1", the<br>channel operation does not start until a |

#### [2] Time-Constant Data

In either the time mode or the counter mode, the time-constant data must be loaded into the time constant register. When bit 2 (D2) of the channel control word is "1", the time constant is loaded into the time constant register immediately after the channel control word is written. A time-constant value must be an integer in a range of 1 to 256. When the 8 bits of a time constant are all "0"s, such a time constant is assumed to be 256. Figure 3.4.11 shows the bit configuration of time- constant data.

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |
|-----|-----|-----|-----|-----|-----|-----|-----|
| TC7 | TC6 | TC5 | TC4 | TC3 | TC2 | TC1 | TC0 |

| 1 | 20100 |
|---|-------|
|   | 20409 |

120489

new channel control word is written.

Figure 3.4.11 Time-Constant Data

#### [3] Interrupt Vector

In the MPU mode-2 interrupt, the interrupting channel must give an interrupt vector to the MPU. An interrupt vector is written to the channel-0 interrupt vector register with bit 0 (D0) = "0". The vector is written in the same way as the channel control word is written to channel 0. However, bit 0 (D0) of the vector should always be "0". Bit 7 (D7) through bit 3 (D3) are user-defined values. Bit 2 (D2) and bit 1 (D1) are automatically given and contain the code of the interrupt- requesting channel having the highest priority. Table 3.4.3 shows the channel codes. Figure 3.4.12 shows the interrupt vector bit configuration.

| Bit 2(D2) | Bit 1(D1) | Channel number | Interrupt priority |
|-----------|-----------|----------------|--------------------|
| 0         | 0         | 0              | (High)             |
| 0         | 1         | 1              |                    |
| 1         | 0         | 2              | <b>•</b>           |
| 1         | 1         | 3              | (low)              |
|           |           |                |                    |

Table 3.4.3 Channel Codes

120489



Figure 3.4.12 Interrupt Vector

#### 3.4.6 Using CTC

#### [1] Counter Mode

The follwing describes how to use the CTC by referring to a program using channel 0 with interrupt disabled.

(a) The counter programming procedure is shown in Figure 3.4.13.



Figure 3.4.13 Counter Programming Procedure

(b) The block diagram for converting the 100 kHz system clock into the 10 kHz equivalent is shown in Figure 3.4.14.



Figure 3.4.14 Down-Counter Block Diagram

(c) The channel control word configuration is shown in Figure 3.4.15.





MPUZ80-377

#### [2] Timer Mode

(a) The timer programming procedure without using interrupt is shown in Figure 3.4.16.





(b) The block diagram for converting the 4 MHz system clock into the 1 kHz equivalent is shown in Figure 3.4.17.







(c) The channel control word is shown in Figure 3.4.18.



#### 3.5 Description of I/O Operation

This subsection describes the system configuration and operations of the input/output (I/O) section of the TMPZ84C011A. The I/O consists of five 8-bit general-purpose ports (a total of 40 I/Os). Each bit can be programmed for an input or output port.

#### 3.5.1 I/O Block Diagram

Figure 3.5.1 shows the I/O block diagram.



Figure 3.5.1 I/O Block Diagram

#### 3.5.2 I/O System Configuration

The I/O system consists of the I/O setting registers, the port registers, the output buffers, and the input control logics.

The I/O setting registers specify whether the port to be used is to operate as an input port or an output port. Each register corresponds to each port bit. The port registers latch the output data to the port pin. The latched output data can also be taken by program into the TMPZ84C011A. These registers and control logics are controlled by the program-controlled  $\overline{IORQ}$ ,  $\overline{RD}$ ,  $\overline{WR}$ , and I/O address signals.

Figure 3.5.2 shows the logic diagram of the I/O port.



Notes: (1) At reset • I/O register = "0" ... Input mode

Port register = "0"

(2) I/O read... Enabled by CPU's I/O input instruction.

(3) I/O write ... Enabled by CPU's I/O output instruction.dc

120489

#### Figure 3.5.2 I/O Port Logic Diagram

#### 3.5.3 I/O Port Basic Operations

The I/O setting registers and port registers of the 5 port of the TMPZ84C011A are assigned with the addresses listed in Table 3.5.1 and are enabled by the MPU's I/O instructions.

| Register                | I/O address |
|-------------------------|-------------|
| PA I/O setting register | #54         |
| PB I/O setting register | #55         |
| PC I/O setting register | #56         |
| PD I/O setting register | #34         |
| PE I/O setting register | #44         |
| PA port register        | #50         |
| PB port register        | #51         |
| PC port register        | #52         |
| PD port register        | #30         |
| PE port register        | #40         |
|                         | 120489      |

| Table 3.5.1 I/O Addres | sses of I/O Port |
|------------------------|------------------|
|------------------------|------------------|

#### [1] I/O Setting Registers

The I/O setting registers specify whether an I/O port is to operate as an input port or an output port. As listed in Table 3.5.2, when the register content is "0", the specified port is an input port; when it is "1", the specified port is an output port.

| ing register contents Poi | rt type  |
|---------------------------|----------|
| 0 (Note) Inp              | ut port  |
| 1 Outp                    | out port |
| 1 Outp                    | out      |

Table 3.5.2 I/O Setting Register Contents and Port Types

[2] Port Registers / I/O Buffer

The port registers latch the data put on the data bus from the MPU and output it to the port pin. They hold the data until it is rewritten.

When using a port register for input, the data can be rewritten by the MPU's I/O output instruction without directly affecting the register operation. When the type of a port registers are switched from input to output during operation, the contents of the port registers are output to the port pins immediately.

When reading the port output data during an output operation, the outputs of the port registers in front of the output buffer are read, if the port pin's load of the port pin gets heavy, making it possible to read the correct data when the output level goes low. When a port is used for input, it becomes the non-latch type in which the input port state of time when the MPU's I/O input instruction has been executed is read. At reset, the port register contents are cleared to "0".

[3] I/O Setting Registers vs. Port Registers

As shown in Figure 3.5.3, the I/O setting registers correspond to the port register one by one.



Figure 3.5.3 I/O Setting Registers vs. Port registers

Therefore, the partial change of port bits requires to rewrite contents of the I/O setting registers of the port containing the change bit.

[4] Precautions

The following points must be taken into account in using the I/O ports:

- (1) When the port types are changed from input to output, the old contents of the port register are output. To avoid this, the contents of the port register must be rewritten with the data to be output before changing the port types. Then, when the port types are changed from input to output, the desired datas are output to the port pins, preventing the operational errors of the peripheral devices connected to the pin.
- (2) After reset, all ports are in the input mode and the port register contents are cleared to "0". Therefore, port type change must not be performed immediately. Instead, the content of the port register corresponding the bit to be used for an output port must be replaced with the desired data by the MPU's I/O output instruction before changing the port types to the output port. This streamlines the port operation.

#### 3.5.4 I/O System Basic Timing

Figure 3.5.4 and 3.5.5 show the basic timings of the I/O ports. The I/O ports of the TMPZ84C011A perform I/O operations according to the MPU's I/O instructions. Therefore, an I/O port address is specified by the low-order 8 bits of the address bus for I/O operations.

In the I/O operation timing, a wait state  $(\rm T_W)$  is automatically inserted after clock state  $\rm T_2$  like the operation of the TLCS-Z80 MPU.





# 4. ELECTRICAL CHARACTERISTICS

## 4.1 MAXIMUM RATINGS

| SYMBOL  | ITEM                                          | RATING               |
|---------|-----------------------------------------------|----------------------|
| VCC     | Vcc Supply Voltage with respect to Vss        | – 0.5V to 7V         |
| VIN     | Input Voltage                                 | – 0.5V to VCC + 0.5V |
| PD      | Power Dissipation (TA = 85°C)                 | 250mW                |
| TSOLDER | Soldering Temperature (Soldering Time 10 sec) | 260°C                |
| TSTG    | Storage Temperature                           | – 65°C to 150°C      |
| TOPR    | Operating Temperature                         | – 40°C to 85°C       |

120489

#### 4.2 DC ELECTRICAL CHARACTERISTICS (1)

| $\mathrm{TA} = -40^{\circ}\mathrm{C} \sim +85^{\circ}$ | $Vcc = 5V \pm 10\%, Vss =$ | 0V |
|--------------------------------------------------------|----------------------------|----|
|--------------------------------------------------------|----------------------------|----|

| SYMBOL | PARAMETER                                            | TEST CONDITI                   | ON     | MIN.      | TYP. | MAX. | UNIT. |
|--------|------------------------------------------------------|--------------------------------|--------|-----------|------|------|-------|
| VIL    | Input Lo <u>w Volt</u> age<br>(except RESET, XTAL1)  |                                |        | - 0.5     | -    | 0.8  | V     |
| VIH    | Input Hig <u>h Vol</u> tage<br>(except RESET, XTAL1) | · · · ·                        |        | 2.2       | -    | VCC  | v     |
| VILR   | In <u>put Lo</u> w Voltage<br>(RESET)                |                                |        | - 0.5     | -    | 0.45 | V     |
| VIHR   | In <u>put Hig</u> h Voltage<br>(RESET)               |                                |        | VCC – 0.6 | -    | VCC  | V     |
| VOLC   | Output Low Voltage<br>(CLK)                          | IOL = 2.0mA                    |        | _         | -    | 0.6  | V     |
| VOHC   | Output High Voltage<br>(CLK)                         | IOH = - 2.0mA                  |        | VCC – 0.6 | -    | -    | v     |
| VOL    | Output Low Voltage                                   | IOL = 2.0mA                    |        | -         | -    | 0.4  | V     |
| VOH1   | Output High Voltage 1                                | IOL = - 1.6mA                  |        | 2.4       | -    | -    | V     |
| VOH2   | Output High Voltage 2                                | IOH = -250µmA                  |        | VCC – 0.8 | -    | -    | V     |
| ILI    | Input Leakage Current                                | Vss≦VIN≦Vcc                    |        | -         | -    | ± 10 | μA    |
| ILO    | 3-state Output Leakage<br>Current in Float           | $Vss + 0.4 \leq Vout \leq VCC$ |        | -         | -    | ± 10 | μA    |
| ICC1   | Power Supply Current                                 | Vcc = 5V,<br>fCLK = (1)        | 4MHz   | -         | 15   | 20   | mA    |
|        |                                                      | VIH = VČČ – 0.2V<br>VIL = 0.2V | 6MHz   | -         | 22   | 30   |       |
| ICC2   | Stand-by supply current                              | Vcc = 5V,<br>(2)               | 4MHz / | -         | 0.5  | 50   | μA    |
|        |                                                      | VIH = VCC - 0.2V<br>VIL = 0.2V | 6MHz   |           |      |      |       |
| ICC3   | Power Supply Current<br>(IDLE MODE)                  | Vcc = 5V,<br>fCLK = (1)        | 4MHz   | -         | 1.0  | 2.5  | mA    |
|        |                                                      | VIH = VCC - 0.2V<br>VIL = 0.2V | 6MHz   | -         | 1.5  | 4    |       |

120489

Note: (1) fCLK = 1/TCC (MIN)

(2) ICC2 Stand-by Supply Current is guaranteed only when the supplied clock is stopped at a low level during T4 state of the following machine Cycle (M1) next to OP code fetch Cycle of HALT instruction.

### 4.2 DC ELECTRICAL CHARACTERISTICAS (2)

 $TA = -40^{\circ}C \sim +85^{\circ}C, \ Vcc = 2.7V \pm 5.5V, \ Vss = 0V \quad (Low \ Voltage \ operation)$ 

| SYMBOL | PARAMETER                                     | TEST CONDITION                                      | MIN.      | TYP. | MAX.      | UNIT |
|--------|-----------------------------------------------|-----------------------------------------------------|-----------|------|-----------|------|
| VIL    | Input Lo <u>w Volt</u> age<br>(except RESET)  |                                                     | - 0.3     | -    | 0.2       | Ý    |
| VIH    | Input Hig <u>h Volt</u> age<br>(except RESET) |                                                     | VCC – 0.2 | -    | VCC + 0.3 | V    |
| VOL    | Output Low Voltage                            | IOL = 1.2mA                                         | -         | -    | 0.4       | V    |
| VOH    | Output High Voltage                           | IOL = -0.7mA                                        | 2.2       | -    | -         | V    |
| ILI    | Input Leakage Current                         | Vss≦VIN≦Vcc                                         | -         | -    | ± 2       | μA   |
| ILO    | 3-state Output Leakage<br>Current in Float    | Vss≦Vout≦VCC                                        | -         | -    | ± 2       | μA   |
| ICC1   | Power Supply Current                          | Vcc = 3V,<br>fCLK = 2MHz<br>VIH = VCC<br>VIL = 0.0V | -         | -    | 10        | mA   |
| ICC2   | Stand-by supply current                       | Vcc = 3V,<br>(2)<br>VIH = VCC<br>VIL = 0.0V         | -         | -    | 10        | μA   |
| ICC3   | Power Supply Current<br>(IDLE MODE)           | Vcc = 3V,<br>fCLK = 2MHz<br>VIH = VCC<br>VIL = 0.0V | -         | 1.0  | 2.5       | mA   |

310589

#### 4.3 AC ELECTRICAL CHARACTERISTICS (1) (IN ACTIVE STATE)

 $TA = -40^{\circ}C \sim +85^{\circ}C, VCC = 5V \pm 10\%, VSS = 0V$ 

### 4.3.1 AC Characteristics of MPU (in Active State)

|     |              |                                                        |             |                             |                    |      |      |      | (1/3) |
|-----|--------------|--------------------------------------------------------|-------------|-----------------------------|--------------------|------|------|------|-------|
| NO. | SYMBOL       | PARAMETER                                              | TMPZ<br>Vcc | 284C01<br>= 2.7V~<br>(2MHz) | 1AF-6<br>5.5V<br>) | TMP2 | UNIT |      |       |
|     |              |                                                        | MIN.        | TYP.                        | MAX.               | MIN. | TYP. | MAX. |       |
| 1   | TcC          | Clock Cycle Time                                       | 500         | -                           | DC                 |      | 165  |      | ns    |
| 2   | TwCh         | Clock Pulse Width (High)                               | 220         | -                           | DC                 | -    | 70   | -    | ns    |
| 3   | TwCl         | Clock Pulse Width (Low)                                | 220         |                             | DC                 | -    | 70   | -    | ns    |
| 4   | TfC          | Clock Fall Time                                        | -           | -                           | 30                 | -    | 12   | -    | ns    |
| 5   | TrC          | Clock Rise Time                                        | -           | -                           | 30                 | -    | 12   | -    | ns    |
| 6   | TdCr (A)     | Clock ↑ to Address Valid Delay                         | -           | -                           | 180                | -    | -    | 90   | ns    |
| 7   | TdA (MREQf)  | Address Valid to $\overline{MREQ} \downarrow Delay$    | 180         | -                           | -                  | -    | 32   | -    | ns    |
| 8   | TdCf (MREQf) | $Clock \downarrow to \overline{MREQ} \downarrow Delay$ | -           | -                           | 150                | -    | -    | 70   | ns    |
| 9   | TdCr (MREQr) | Clock ↑ to MREQ ↑ Delay                                | -           | -                           | 180                | -    | -    | 70   | ns    |
| 10  | TwMREQh      | MREQ Pulse Width (High)                                | 190         | -                           | -                  | -    | 62   | -    | ns    |
| 11  | TwMREQI      | MREQ Pulse Width (Low)                                 | 460         | -                           | -                  | -    | 135  | -    | ns    |
| 12  | TdCf (MREQr) | Clock ↓ to $\overline{MREQ}$ ↑ Delay                   | -           | -                           | 190                | -    | _    | 70   | ns    |

|     |                |                                                                    |      |                 |           |      |       |       | (2/3)  |
|-----|----------------|--------------------------------------------------------------------|------|-----------------|-----------|------|-------|-------|--------|
|     |                |                                                                    | TMPZ | 84C01           | 1AF-6     | TMPZ | 84C01 | 1AF-6 |        |
| NO. | SYMBOL         | PARAMETER                                                          | Vcc  | =2.7V~<br>(2MHz | 5.5V<br>) |      | (6MHz | )     | UNIT   |
|     |                |                                                                    | MIN. | TYP.            | MAX.      | MIN. | TYP.  | MAX.  |        |
| 13  | TdCf (RDf)     | Clock $\downarrow$ to $\overline{RD} \downarrow$ Delay             | —    | -               | 180       | -    |       | 80    | ns     |
| 14  | TdCr (RDr)     | Clock $\uparrow$ to $\overline{RD}$ $\uparrow$ Delay               | -    | —               | 180       | -    | -     | 70    | ns     |
| 15  | TsD (Cr)       | Data Setup Time to Clock ↑                                         | 60   | —               | -         | 30   |       |       | ns     |
| 16  | ThD (RDr)      | Data Hold Time to $\overline{RD}$ $\uparrow$                       | 0    | -               | -         | 0    | —     | -     | ns     |
| 17  | TsWAIT (Cf)    | WAIT Setup Time to Clock ↓                                         | 80   | -               |           | 60   |       | -     | ns     |
| 18  | ThWAIT (Cf)    | ₩AIT Hold Time after Clock↓                                        | 15   | -               |           | 10   | -     | -     | ns     |
| 19  | TdCr (M1f)     | Clock ↑ to M1 ↓ Delay                                              | —    | -               | 170       | -    |       | 80    | ns     |
| 20  | TdCr (M1r)     | Clock ↑ to M1 ↑ Delay                                              | -    | —               | 170       |      | _     | 80    | ns     |
| 21  | TdCr (RFSHf)   | Clock ↑ to RFSH ↓ Delay                                            | -    | —               | 220       | -    | -     | 110   | ns     |
| 22  | TdCr (RFSHr)   | Clock ↑ to RFSH ↑ Delay                                            |      | -               | 220       | -    | -     | 100   | ns     |
| 23  | TdCr (RDr)     | Clock↓to RD↑Delay                                                  |      | -               | 180       | -    | —     | 70    | ns     |
| 24  | TdCr (RDf)     | Clock ↑ to RD ↓ Delay                                              | _    | -               | 150       | -    |       | 70    | ns     |
| 25  | TsS (Cf)       | Data Setup to Clock↓during M2, M3,<br>M4 or M5 Cycles              | 70   | -               | _         | 40   | -     | -     | ns     |
| 26  | TdA (IORQf)    | Address Stable prior IORQ ↓                                        | 400  | -               | -         | -    | 110   | -     | ns     |
| 27  | TdCr (IORQf)   | Clock ↑ to IORQ ↓ Delay                                            | _    | _               | 150       | -    | _     | 65    | ns     |
| 28  | TdCf (IORQr)   | Clock↓to IORQ↑Delay                                                | -    | _               | 180       | -    | _     | 70    | ns     |
| 29  | TdD (WRf)      | Data Stable Prior to ₩R↓                                           | 240  | -               | -         | -    | 25    | -     | ns     |
| 30  | TdCf (WRf)     | Clock↓to ₩R↓Delay                                                  | -    | _               | 150       |      | -     | 70    | ns     |
| 31  | TwWR           | WR Pulse Width                                                     | 420  | _               | -         | -    | 135   | -     | ns     |
| 32  | TdCf (WRr)     | Clock↓to WR↑Delay                                                  | -    | _               | 180       |      | -     | 70    | ns     |
| 33  | TdD (WRf)      | Data Stable Prior to ₩R↓                                           | 70   |                 | -         |      | - 58  | _     | ns     |
| 34  | TdCr (WRf)     | Clock ↑ to ₩R ↓ Delay                                              | -    |                 | 120       |      |       | 60    | ns     |
| 35  | TdWRr (D)      | Data Stable from WR ↑                                              | 200  |                 | -         |      | 27    | -     | ns     |
| 36  | TdCf (HALT)    | Clock↓to HALT↑or↓                                                  | -    | -               | 350       | -    | -     | 260   | ns     |
| 37  | TwNMI          | NMI Pulse Width                                                    | 180  | _               | -         | 70   | -     | -     | ns     |
| 38  | TsBUSREQ (Cr)  | BUSREQ Setup Time to Clock ↑                                       | 100  | -               | -         | 50   |       | -     | ns     |
| 39  | ThBUSREQ (Cr)  | BUSREQ Hold Time after Clock ↑                                     | 15   |                 | -         | 10   | -     |       | ns     |
| 40  | TdCr (BUSACKf) | Clock ↑ to BUSACK ↓ Delay                                          | -    | -               | 180       | -    | -     | 90    | ns     |
| 41  | TdCf(BUSACKr)  | Clock↓to BUSACK↑Delay                                              |      | -               | 160       | -    | -     | 90    | ns     |
| 42  | TdCr (Dz)      | Clock ↑ to Data Float Delay                                        |      | -               | 120       | -    | -     | 80    | ns     |
| 43  | TdCr (CTz)     | Clock ↑ to Control Outputs Float Delay<br>(MREQ, IORQ, RD, and WR) |      | _               | 140       | -    | -     | 70    | ns     |
| 44  | TdCr (Az)      | Clock ↑ to Address Float Delay                                     | -    |                 | 140       | -    | -     | 80    | ns     |
| ,   |                |                                                                    |      |                 |           |      |       |       | 200590 |

MPUZ80-386

|     |               |                                                                                                                 |             |                           |                    |      |       |            | (3/3) |
|-----|---------------|-----------------------------------------------------------------------------------------------------------------|-------------|---------------------------|--------------------|------|-------|------------|-------|
| NO. | SYMBOL        | PARAMETER                                                                                                       | TMPZ<br>Vcc | 84C01<br>= 2.7V~<br>(2MHz | 1AF-6<br>5.5V<br>) | TMPZ | 84C01 | 1AF-6<br>) | UNIT  |
|     |               |                                                                                                                 | MIN.        | TYP.                      | MAX.               | MIN. | TYP.  | MAX.       |       |
| 45  | TdCr (A)      | $\frac{MREQ}{Address} \uparrow, \overline{IORQ} \uparrow, \overline{RD} \uparrow and \overline{WR} \uparrow to$ | 200         | _                         | —                  | _    | 32    | -          | ns    |
| 46  | TsRESET (Cr)  | RESET to Clock ↑ Setup Time                                                                                     | 140         | -                         | -                  | 60   |       | -          | ns    |
| 47  | ThRESET (Cr)  | RESET to Clock ↑ Hold Time                                                                                      | 20          | -                         | -                  | 10   | —     | -          | ns    |
| 48  | TsINTf (Cr)   | INT to Clock ↑ Setup Time                                                                                       | 100         | -                         | -                  | 70   |       | -          | ns    |
| 49  | TsINTr (Cr)   | INT to Clock ↑ Hold Time                                                                                        | 15          | -                         |                    | 10   | —     | -          | ns    |
| 50  | TdM1f (IORQf) | $\overline{M1}\downarrow$ to $\overline{IORQ}\downarrow$ Delay                                                  | 1050        | —                         | -                  | —    | 362   | -          | ns    |
| 51  | TdCf (IORQf)  | Clock $\downarrow$ to $\overline{IORQ} \downarrow$ Delay                                                        | -           | -                         | 185                | —    | -     | 70         | ns    |
| 52  | TdCr (IORQr)  | Clock ↑ to <del>IORQ</del> ↑ Delay                                                                              | -           | -                         | 200                | -    | —     | 70         | ns    |
| 53  | TdCf (D)      | Clock↓to Data Valid Delay                                                                                       | -           | -                         | 300                | —    | _     | 130        | ns    |

290589

## 4.3.2 AC Characteristics of CGC (in Active State)

| NO. | SYMBOL         | PARAMETER                                | TMPZ84C011AF-6<br>Vcc = 2.7V~5.5V<br>(2MHz) |                             |      | TMP  | UNIT                          |      |        |
|-----|----------------|------------------------------------------|---------------------------------------------|-----------------------------|------|------|-------------------------------|------|--------|
|     |                |                                          | MIN.                                        | TYP.                        | MAX. | MIN. | TYP.                          | MAX. |        |
| 54  | TRST (INT) S   | CLK restart time by INT<br>(STOP Mode)   | _                                           | 2 <sup>14</sup> +<br>2.5TcC | -    | -    | (2 <sup>14</sup> +<br>2.5)TcC | -    | ns     |
| 55  | TRST (NMI) S   | CLK restart time by NMI<br>(STOP Mode)   | _                                           | 214 +<br>2.5TcC             | _    | _    | (2 <sup>14</sup> +<br>2.5)TcC | _    | ns     |
| 56  | TRST (INT) I   | CLK restart time by INT<br>(IDLE Mode)   | -                                           | 2.5<br>*TcC                 | -    | _    | 2.5<br>TcC                    | _    | ns     |
| 57  | TRST (NMI) I   | CLK restart time by NMI<br>(IDLE Mode)   | -                                           | 2.5<br>*TcC                 | -    | -    | 2.5<br>TcC                    | —    | ns     |
| 58  | TRST (RESET) I | CLK restart time by RESET<br>(IDLE Mode) | —                                           | TcC                         | -    | _    | TcC                           | —    | ns     |
|     |                |                                          |                                             |                             |      |      |                               |      | 290589 |

## 4.3.3 AC Characteristics of CTC (in Active State)

|     |              | · · ·                                                                                                          |                                             |      |      |      |      |      | (1/2) |
|-----|--------------|----------------------------------------------------------------------------------------------------------------|---------------------------------------------|------|------|------|------|------|-------|
| NO. | SYMBOL       | PARAMETER                                                                                                      | TMPZ84C011AF-6<br>Vcc = 2.7V~5.5V<br>(2MHz) |      |      | TMPZ | UNIT |      |       |
|     |              |                                                                                                                | MIN.                                        | TYP. | MAX. | MIN. | TYP. | MAX. |       |
| 59  | TdM1 (IEO)   | Delay from $\overline{M1}$ fall to IEO fall (in case of generating only interrupt immediately before M1 cycle) | —                                           | —    | 350  | —    | _    | 130  | ns    |
| 60  | TdIEI (IEOf) | Delay from IEI fall to IEO fall                                                                                | -                                           | -    | 200  | -    | -    | 100  | ns    |
| 61  | TdIEI (IEOr) | Delay from IEI rise to IEO rise<br>(after ED decode)                                                           | —                                           | _    | 250  | _    | _    | 110  | ns    |

|     |                |                                                                                                         |                                 |                            |                    |                                 |                |            | (2/2) |
|-----|----------------|---------------------------------------------------------------------------------------------------------|---------------------------------|----------------------------|--------------------|---------------------------------|----------------|------------|-------|
| NO. | SYMBOL         | PARAMETER                                                                                               | TMPZ<br>Vcc                     | 284C01<br>= 2.7V~<br>(2MHz | 1AF-6<br>5.5V<br>) | TMPZ                            | 84C01<br>(6MHz | 1AF-6<br>) | UNIT  |
|     |                |                                                                                                         | MIN.                            | TYP.                       | MAX.               | MIN.                            | TYP.           | MAX.       |       |
| 62  | TsCTR (INT)    | CLK/TRG setup for detection of<br>interrupt<br>TsCTR (C) Satisfied                                      | TcC<br>+ 200<br>+ T68<br>+ T48  |                            | _                  | TcC<br>+ 120<br>+ T68<br>+ T48  | -              | _          | ns    |
|     |                | TsCTR (C) not Satisfied                                                                                 | 2TcC<br>+ 200<br>+ T68<br>+ T48 | _                          | _                  | 2TcC<br>+ 120<br>+ T68<br>+ T48 | _              | _          | ns    |
| 63  | TcCTR          | CLK/TRG Frequency                                                                                       | 2TcC                            | -                          | -                  | 2TcC                            | -              | -          | ns    |
| 64  | TrCTR          | CLK/TRG rising time                                                                                     | -                               | -                          | 50                 | -                               | —              | 40         | ns    |
| 65  | TfCTR          | CLK/TRG falling time                                                                                    | -                               | -                          | 50                 | -                               | -              | 40         | ns    |
| 66  | TwCTRI         | Low CLK/TRG Pulse Width                                                                                 | 240                             | -                          | -                  | 120                             | -              | -          | ns    |
| 67  | TwCTRh         | High CLK/TRG Pulse Width                                                                                | 240                             | -                          | -                  | 120                             | -              | -          | ns    |
| 68  | TsCTR (Cs)     | Set-up time up to CLK/TRG rise for clock<br>rise requiring immediate count<br>(counter mode)            | 300                             | _                          | _                  | 150                             | _              | _          | ns    |
| 69  | TsCTR (CT)     | Set-up time up to CLK/TRG rise for clock<br>rise requiring immediate start of<br>prescaler (timer mode) | 300                             | _                          |                    | 150                             | _              |            | ns    |
| 70  | TdC (ZC / TOr) | Delay from clock rise to ZC/ TO rise                                                                    |                                 | -                          | 300                | _                               |                | 140        | ns    |
| 71  | TdC (ZC / TOf) | Delay from clock fall to ZC/ TO fall                                                                    | -                               | -                          | 220                | -                               | -              | 140        | ns    |

290589

## 4.3.4 AC Characteristics of I/O (in Active State)

| NO. S' | SYMBOL        | PARAMETER                                     | TMPZ<br>Vcc | 84C01<br>= 2.7V~<br>(6MHz) | 1AF-6<br>5.5V<br>) | TMPZ | 84C01<br>(6MHz) | 1AF-6<br>) | UNIT |
|--------|---------------|-----------------------------------------------|-------------|----------------------------|--------------------|------|-----------------|------------|------|
|        |               |                                               | MIN.        | TYP.                       | MAX.               | MIN. | TYP.            | MAX.       |      |
| 72     | TdCf (Pout)   | Delay from clock fall to port<br>data output  |             | —                          | 650                |      |                 | 300        | ns   |
| 73     | TsPIN (IORDf) | Port Input to IORQ and RD fall<br>Set-up time | 0           | —                          | -                  | 0    | _               | -          | ns   |
| 74     | ThPIN         | Port Input to IORQ and RD fall<br>Hold Time   | 0           | -                          | _                  | 0    | -               | -          | ns   |

290589

### 4.4 CAPACITANCE

 $Ta = 25^{\circ}C$ 

| SYMBOL          | ltem               | TEST COINDITION                                 | MIN. | TUP. | MAX. | UNIT.  |
|-----------------|--------------------|-------------------------------------------------|------|------|------|--------|
| C <sub>IN</sub> | Input Capacitance  | f = 1MHz<br>ALL terminals                       | —    | 5    | -    | PF     |
| Cout            | Output Capacitance | except that to be measured<br>should be earthed |      | 30   | -    | PF     |
|                 |                    |                                                 |      |      |      | 290589 |

#### 4.5 AC TIMING CHARTS (1) (IN ACTIVE STATE)

#### 4.5.1 AC Timing Charts of CPU (in Active State)

Figure 4.5.1 through 4.5.8 show the basic timing charts. The circled numbers in these charts correspond to the numbers under the number column of the AC Electrical Characteristics Tables.



Figure 4.5.1 Opcode Fetch Cycle









Figure 4.5.3 I/O Cycle



120489











 Note:
 1. TL : Last state of a given machine cycle

 2. Tx :
 Clock used by peripheral LSI that made request.

120489





Note : INT ssignal is also used for releasing HALT state.

120489

#### Figure 4.5.7 Halt Acknowledge Cycle





MPUZ80-393

### 4.5.2 AC Timing Cfarts of CGC (in Active State)



Figure 4.5.9 Clock Restart Timing (STOP mode)



Figure 4.5.10 Clock Restart Timing (IDLE mode)



Figure 4.5.11 Timing of Clock Start by RESET (IDLE mode)

## 4.5.3 AC Timing Charts of CTC (in Active State)



Figure 4.5.12 CTC Timing Diagram



120489

## Figure 4.5.13 CTC Interrupt Occurrence Timing

## 4.5.4 AC Timing Charts of I/O (in Active State)





### 4.6 AC ELECTRICAL CHARACTERISTICS (2) (IN INACTIVE STATE)

 $Ta = -40^{\circ}C \sim +85^{\circ}C, VCC = 5V \pm 10\%, VSS = 0V$ 

### 4.6.1 AC Characteristics of CGC (in Inactive State)

| NO. | SYMBOL           | PARAMETER                                       |      | 284C01<br>= 2.7V~<br>(2MHz) | 1AF-6<br>5.5V<br>) | TMPZ | UNIT            |      |    |
|-----|------------------|-------------------------------------------------|------|-----------------------------|--------------------|------|-----------------|------|----|
|     |                  |                                                 | MIN. | TYP.                        | MAX.               | MIN. | TYP.            | MAX. |    |
| 1   | T <sub>C</sub> C | CLOCK Cycle                                     | 500  | -                           | DC                 | -    | 165             | -    | ns |
| 2   | TwCh             | CLOCK Width (High)                              | 220  | -                           | DC                 | -    | 70              | 1    | ns |
| 3   | TwCl             | CLOCK Width (Low)                               | 220  | —                           | DC                 | -    | 70              | -    | ns |
| 4   | TfC              | CLOCK Fall Time                                 | -    | -                           | 30                 | -    | 12              | -    | ns |
| 5   | TrC              | CLOCK Rise Time                                 | -    | -                           | 30                 | -    | 12              | -    | ns |
| 6   | TRST (INT) S     | Clock (CLK) restart Time by INT<br>(STOP mode)  | _    | 214 +<br>2.5TcC             | -                  | _    | 214 +<br>2.5TcC |      | ns |
| 7   | TRST (NMI) S     | Clock (CLK) restart Time by NMI<br>(STOP mode)  | _    | 214 +<br>2.5TcC             | _                  |      | 214 +<br>2.5TcC | _    | ns |
| 8   | TRST (INT) I     | Clock (CLK) restart Time by INT<br>(IDLE mode)  |      | 2.5<br>*TcC                 | -                  | -    | 2.5<br>TcC      | _    | ns |
| 9   | TRST (NMI) I     | Clock (CLK) restart Time by NMI<br>(IDLE mode)  | _    | 2.5<br>*TcC                 | -                  | _    | 2.5<br>TcC      | _    | ns |
| 10  | TRST (RESET) I   | Clock (CLK) restart Time by RESET<br>(IDLEmode) | _    | 1TcC                        | -                  | _    | 1TcC            | _    | ns |
| 11  | TsHALT (M1r)     | HALT set-up Time                                | 10   | -                           | -                  | 10   | -               | _    | ns |

## 4.6.2 AC Characteristics of CTC (in Inactive State)

(1/2)

| NO | SYMBOL       | SYMBOL PARAMETER                                                                                   | TMPZ<br>Vcc :          | 84C01<br>= 2.7V~<br>2MHz | 1AF-6<br>5.5V | TMPZ | 1AF-6                          | UNIT         |    |
|----|--------------|----------------------------------------------------------------------------------------------------|------------------------|--------------------------|---------------|------|--------------------------------|--------------|----|
|    | STWDOL       |                                                                                                    | MIN.                   | TYP.                     | MAX.          | MIN. | TYP.                           | MAX.         | 0  |
| 12 | Th           | Hold Time                                                                                          | 20                     |                          | -             | 0    | —                              |              | ns |
| 13 | TsCS (C)     | CS (A1, A0) set-up time to clock ↑                                                                 | 280                    | _                        | -             | 100  | _                              |              | ns |
| 14 | TsCE (C)     | CE (A <sub>7</sub> to A <sub>2</sub> ) set-up time to clock $\uparrow$                             | 220                    | -                        | -             | 150  | -                              | -            | ns |
| 15 | TsIO (C)     | $\overline{IORQ}\downarrowset-up$ time to clock $\uparrow$                                         | 280                    | -                        | -             | 70   | -                              | -            | ns |
| 16 | TsRD (C)     | RD↓set-up time to clock↑                                                                           | 260                    | -                        | -             | 70   | -                              | -            | ns |
| 17 | TdC (DO)     | clock ↑ to Data Valid Delay                                                                        | _                      | -                        | 260           |      |                                | 130          | ns |
| 18 | TdC (DOz)    | $\overline{IORQ}, \overline{RD} \uparrow to Data Float Delay$                                      | _                      | —                        | 250           | —    | -                              | 90           | ns |
| 19 | TsDI (C)     | Data Input set-up time to clock $\uparrow$                                                         | 90                     | -                        | -             | 40   | —                              | -            | ns |
| 20 | TsM1 (C)     | M1 set-up time to clock ↑                                                                          | 240                    | —                        |               | 70   | —                              | _            | ns |
| 21 | TdM1 (IEO)   | clock↑<br>M1↓to IEO↓Delay<br>(in case of generating only interrupt<br>immediately befor M1 ) cycle |                        | —                        | 350           | _    | _                              | 130          | ns |
| 22 | TdIO (DOI)   | $\overline{IORQ}\downarrow$ to Data out delay (INTA cycle)                                         | -                      | -                        | 380           | -    | _                              | 110          | ns |
| 23 | TdIEI (IEOf) | IEI↓to IEO↓Delay                                                                                   | _                      | _                        | 200           | -    | -                              | 100          | ns |
| 24 | TdIEI (IEOr) | IEI↑to IEO↑Delay (after ED decode)                                                                 | _                      |                          | 250           | —    | -                              | 110          | ns |
| 25 | TdC (INT)    | Clock ↑ to ĪNT ↓ Delay                                                                             |                        | -                        | TcC<br>+ 200  | _    | -                              | TcC<br>+ 120 | ns |
| 26 |              | CLK/TRG ↑ to INT ↓ Delay<br>TsCTR(c) Satisfied                                                     | TcC<br>+ 200<br>+ T32  | _                        |               | _    | TcC<br>+ 120<br>+ 70<br>+ T31  |              | ns |
| 26 |              | TsCTR (c) not Satisfied                                                                            | 2TcC<br>+ 200<br>+ T32 |                          |               | _    | 2TcC<br>+ 120<br>+ 70<br>+ T31 | -            | ns |
| 27 | TcCTR        | CLK/TRG Frequency                                                                                  | 2TcC                   | -                        |               | -    | 2TcC                           | -            | ns |
| 28 | TrCTR        | CLK/TRG rising time                                                                                | -                      | -                        | 50            | -    | -                              | 40           | ns |
| 29 | TfCTR        | CLK/TRG falling time                                                                               | -                      | -                        | 50            | -    | -                              | 40           | ns |
| 30 | TwCTRI       | LOW CLK/TRG Pulse width                                                                            | 240                    | _                        | -             | 120  | -                              | 70           | ns |
| 31 | TwCTRh       | High CLK/TRG Pulse width                                                                           | 240                    |                          |               | 120  | -                              | -            | ns |
| 32 | TsCTR (Cs)   | Set-up time up to CLK/TRG rise for clock<br>rise requiring immediate<br>(counter mode)             | 300                    | -                        | -             | 150  | _                              | -            | ns |

|     |                |                                                                                                            |      |                                                                                                     |      |      |      |       | (2/2) |
|-----|----------------|------------------------------------------------------------------------------------------------------------|------|-----------------------------------------------------------------------------------------------------|------|------|------|-------|-------|
| NO. | SYMBOL         | SYMBOL PARAMETER                                                                                           |      | TMPZ84C011AF-6         TMPZ84C           Vcc = 2.7V~5.5V         (6M)           (2MHz)         (6M) |      |      |      | 1AF-6 | UNIT  |
|     |                |                                                                                                            | MIN. | TYP.                                                                                                | MAX. | MIN. | TYP. | MAX.  |       |
| 33  | TsCTR (Ct)     | Set-up time up to CLK/TRG rise for clock<br>rise requiring immediate start of<br>prescaler<br>(timer mode) | 300  | _                                                                                                   | _    | 150  | —    |       | ns    |
| 34  | TdC (ZC / TOr) | Delay from clock rise to ZC/TO rise                                                                        | -    | -                                                                                                   | 300  | -    | -    | 140   | ns    |
| 35  | TdC (ZC / TOf) | Delay from clock fall to ZC/TO fall                                                                        | -    |                                                                                                     | 220  | -    | -    | 140   | ns    |

290589

### 4.6.3 AC Characteristics of I/O (in Inactive State)

| NO | SYMBOL        | PARAMETER                                                                              |     | TMPZ84C011AF-6<br>Vcc = 2.7V~5.5V<br>(2MHz) |     |      | TMPZ84C011AF-6<br>(6MHz) |     |    |
|----|---------------|----------------------------------------------------------------------------------------|-----|---------------------------------------------|-----|------|--------------------------|-----|----|
|    | 5111502       |                                                                                        |     | MIN. TYP. MAX. MI                           |     | MIN. | TYP. MAX.                |     |    |
| 36 | TsCE (Cr)     | CE (A7~A0) to clock↑ Set-up time                                                       | 300 | -                                           | -   | 150  | —                        | -   | ns |
| 37 | TsIO (C)      | Set-up time from clock↑ to IORQ↓                                                       |     | -                                           | -   | 70   | -                        | -   | ns |
| 38 | TsRD (C)      | Set-up time from clock↑ to RD↓                                                         |     |                                             | -   | 70   | —                        | _   | ns |
| 39 | TdC (DO)      | Delay from clock ↑ to Data Output                                                      |     | _                                           | 300 | —    | -                        | 130 | ns |
| 40 | TdC (DOz)     | Delay from clock IORQ and RD ↑<br>to Data Float                                        |     | -                                           | 150 | -    | _                        | 90  | ns |
| 41 | TsDI (C)      | Data Input to clock ↑ Set-up time                                                      |     | _                                           | -   | 0    | -                        | -   | ns |
| 42 | TsWR (C)      | Set-up time from $\overline{WR}\downarrow$ to clock $\uparrow$                         |     |                                             | -   | 70   | -                        | -   | ns |
| 43 | TdIOWRr (D)   | Output Data Stable from $\overline{\text{IORQ}}, \overline{\text{WR}} \downarrow$      |     | -                                           | -   | 20   | —                        |     | ns |
| 44 | TdCf (Pout)   | Delay from clock ↓ to Data Output                                                      |     | -                                           | 650 | -    | -                        | 300 | ns |
| 45 | TSPIN (IORDf) | Port Input to IORQ and RD ↓<br>Set-up time                                             |     |                                             | _   | 0    | _                        | _   | ns |
| 46 | ThPIN (IORDr) | Port Input to $\overline{\text{IORQ}}$ and $\overline{\text{RD}}$ $\uparrow$ Hold Time |     | _                                           | _   | 0    | -                        | _   | ns |

290589

Note : Timing Measurements are made at the following voltage.

Input : VIH=2.4V Output :  $VOHC = V_{CC} - 0.6V$  VOLC = 0.6V (CLK) Output : VOH=2.4V

VIL = 0.4VVOL=0.8V (Except CLK)

 $C_L = 100 pF$ 

## 4.7 AC TIMING CHARTS (2) (IN INACTIVE STATE)

4.7.1 AC Timing Charts of CGC (in Inactive State)



Figure 4.7.1 Clock Restart Timing (STOP mode)



Figure 4.7.2 Clock Restart Timing (IDLE mode)



MPUZ80-400



### 4.7.2 AC Timing Charts of CTC (in Inactive State)



#### MPUZ80-401









Figure 4.7.6 (b) I/O WRITE Timing

#### 4.8 OUT LINE DRAWING

### QFP100-P-1420B





# TMPZ84C013AT-6 / TMPZ84C013AT-8 TLCS-Z80 MICROPROCESSOR

### 1. OUTLINE AND FEATURES

The TMPZ84C013A is a high-performance CMOS 8-bit microprocessor incorporating the counter timer circuit (CTC), the serial I/O port (SIO), the clock generator/controller (CGC), and the watchdog timer (WDT) around the TLCS-Z80 MPU. This microprocessor inherits the basic architecture of the TLCS-Z80 series, allowing the user to utilize the software resources and development tools accumulated so far.

The TMPZ84C013A is based on the new CMOS process and housed in a standard 84pin PLCC package, greatly contributing to system miniaturization and power saving.

The TMPZ84C013A incorporates the high-performance serial I/O port, the counter timer circuit which can be used as the baud rate generator, and the watchdog timer indispensable for control applications, offering the user a wide range of system applications such as the communication controllers including a communication adaptor and the various other controllers which need miniaturization.

#### Features

- Built-in TLCS-Z80 series MPU, CTC, SIO, CGC and watchdog timer features.
- High speed operation (6MHz and 8MHz operations)
- Built-in clock generator (CGC:Clock Generator Controller)
- Built-in standby capability (with the controller built in) provides 4 operation modes:

Run mode(Normal operation)Idle-1 mode(Only clock oscillation goes on. )Idle-2 mode(Wake-up by CTC enabled. )Stop mode(Clock oscillation stopped; standby state)

• Wide operational voltage range  $(5V \pm 10\% : 6MHz VERSION,$ 

 $5V \pm 5\%$ : 8MHz VERSION) supported.

- Wide operating temperature range (-40°C to +85°C: 6MHz VERSION, -10°C to +70°C: 8MHz VERSION)
- Low power dissipation

| In operation: | (RUN mode)    | 22mA TYP.  | at 6 MHz, $$ | 31mA TYP. | at $8  \mathrm{MHz}$ |
|---------------|---------------|------------|--------------|-----------|----------------------|
| In idle:      | (IDLE-1 mode) | 1.5mA TYP. | at 6 MHz,    | 2mA TYP.  | at 8 MHz             |
|               | (IDLE-2 mode) | 11mA TYP.  | at 6 MHz,    | 15mA TYP. | at $8  \mathrm{MHz}$ |
| In standby:   | (STOP mode)   | 500nA TYP. |              |           |                      |

- Built-in TLCS-Z80 series SIO capability
- A pair of independent full duplex channels supports the asynchronous as well as synchronous byte-oriented (monosync and bisync) and bit-oriented HDLC and CCITT-X. 25 protocols.
- Built-in CRC generation and check capability.
- Data transfer rates of up to 1200 K bits/sec (6 MHz) and 1600 K bits/sec (8 MHz)
- Built-in TLCS-Z80 series CTC capability

Four independent built-in channels. The timer or counter modes can be set . Also available as the SIO baud rate generator.

- Built-in watchdog timer
- Programmed daisy-chain interrupt control
- Built-in dynamic RAM refresh controller
- TTL/CMOS compatible
- Housed in compact standard 84-pin PLCC package
- The Toshiba real-time emulator (RTE80) and the commercially available Z80 ICE can be used (the TMPZ84C013A used as the evaluator).
- The Toshiba evaluator board installed.

note: Z80 is a trade mark of Zilog Inc.



2.1 PIN ASSIGNMENTS (TOP VIEW)





Figure 2.1.1 Pin Assignment

## 2.2 (A) PIN FUNCTIONS

| (, , , , , , , , , , , , , , , , , , , |                  |                           | (1/5)                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|----------------------------------------|------------------|---------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin                                    | Q'ty<br>(Number) | Туре                      | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| D0-D7                                  | 8<br>(76-83)     | Input / output<br>3-state | The 8-bit bi-directional data bus.                                                                                                                                                                                                                                                                                                                                                                                                                               |
| A0-A15                                 | 16<br>(1-16)     | Output<br>3-state         | The 16-bit address bus.<br>These pins specify memory and I/O port addresses.<br>During a refresh cycle, the refresh address is output to<br>the low-order 7 bits and A7RF.                                                                                                                                                                                                                                                                                       |
| M1                                     | 1<br>(7)         | Output<br>3-state         | The Machine Cycle 1 signal.<br>In an operation code fetch cycle, this pin goes "0" with<br>the MREQ signal. At the execution of a 2-byte<br>operation code, this pin goes "0" for each operation<br>code fetch. In a maskable interrupt acknowledge<br>cycle, this pin goes "0" with the IORQ signal. When<br>the EV signal is applied, this pin is put in the high-<br>impedance state.                                                                         |
| RD                                     | 1<br>(30)        | Output<br>3-state         | The Read signal. It indicates that the MPU is ready for accepting data from memory or I/O device. The data from the addressed memory or I/O devices is gated by this signal onto the MPU data bus. When the BUSREQ signal is applied, this pin is put in the high-impedance state.                                                                                                                                                                               |
| WR                                     | 1<br>(20)        | Output<br>3-state         | The Write signal. This signal is output when the data to be stored in the addressed memory or I/O device is on the data bus. When the $\overline{\text{BUSREQ}}$ signal is applied, this pin is put in the high-impedance state.                                                                                                                                                                                                                                 |
| MREQ                                   | 1<br>(23)        | Output<br>3-state         | The Memory Request signal. When the execution address for memory access is on the address bus, this pin goes "0". During a memory refresh cycle, this pin also goes "0" with $\overline{\text{RFSH}}$ signal.                                                                                                                                                                                                                                                    |
| IORQ                                   | 1<br>(21)        | Output<br>3-state         | The Input/Output Request signal. This pin goes "0" when the address for an I/O read or write operation is on the low-order 8 bits (A0 through A7) of the address bus. The $\overline{IORQ}$ signal is also output with the $\overline{M1}$ signal at interrupt acknowledge to tell an I/O device that the interrupt response vector can be placed on the data bus. Note that the interrupt priority among the TMPZ84C013A CTC, and SIO is selected by a program. |
| IEO                                    | 1<br>(59)        | Output                    | The Interrupt Enable Output signal. In the daisy chain<br>interrupt control, this signal controls the interrupt<br>from the peripheral LSIs connected next to the<br>TMPZ84C013A. The IEO pin goes "1" only when the<br>IEI pin is "1" and the MPU is not servicing an interrupt<br>from the built-in peripheral LSI.                                                                                                                                            |

|                |                   |                 | (2/5)                                                                                                                                                                                                                                                                                                                                                                                                                |
|----------------|-------------------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin            | Qʻty<br>(Number)  | Туре            | Function                                                                                                                                                                                                                                                                                                                                                                                                             |
| XTAL1<br>XTAL2 | 2<br>(63)<br>(64) | Input<br>Output | The crystal oscillator connection.<br>Connects an oscillator having the oscillation frequency<br>2 times as high as the system clock (CLKOUT)<br>frequency.                                                                                                                                                                                                                                                          |
| CLKIN          | 1<br>(67)         | Input           | The Single-phase Clock Input.<br>When the clock input is placed in the DC state<br>(continued "1" or "0" level), this pin stops operating<br>and holds the state of that time.<br>Normally, this pin is connected with the CLKOUT pin.<br>However, to operate the system with the external<br>clock, connect the external clock to the CLKIN pin.                                                                    |
| CLKOUT         | 1<br>(66)         | Output          | The Single-phase Clock Output.<br>When a Halt instruction is executed in the Stop or Idle-<br>1 mode, the CLKOUT output is retained at "0". In the<br>Run and Idle-2 modes, the clock is kept output. This<br>pin provides the clock to other peripheral ICs.                                                                                                                                                        |
| RESET          | 1<br>(28)         | Input           | The Reset signal input. This signal resets the internal states of the TMPZ84C013A. This signal is also used to return from the standby state in the Stop or Idle mode.                                                                                                                                                                                                                                               |
| ĪNT            | 1<br>(25)         | Input           | The Maskable Interrupt signal. An interrupt is caused<br>by the internal CTC, SIO or the peripheral LSI. An<br>interrupt is acknowledged when the interrupt enable<br>flip-flop (IFF) is set to "1" by software.<br>The INT pin is normally wire-ORed and requires an<br>external pullup resistor for these applications. This<br>signal is also used to return from the stand-by state in<br>the Stop or Idle mode. |
| WAIT           | 1<br>(19)         | Input           | The Wait Request signal. This signal indicates the MPU that the addressed memory or I/O device is not ready for data transfer. As long as this signal is "0", the MPU is in the Wait state.                                                                                                                                                                                                                          |
| BUSREQ         | 1<br>(18)         | Input           | The bus Request signal. The BUSREQ signal forces the MPU address bus, data bus, and control signals MREQ, IORQ, RD, and WR to be placed in the high-impedance state. This signal is normally Wire-ORed and requires an external pullup resistor for these applications.                                                                                                                                              |
| BUSACK         | 1<br>(29)         | Output          | The Bus Acknowledge signal. In response to the $\overline{\text{BUSREQ}}$ signal, the $\overline{\text{BUSACK}}$ signal indicates to the requesting peripheral LSI that the MPU address bus, data bus, and control signals $\overline{\text{MREQ}}$ , $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ and $\overline{\text{WR}}$ have been put in the high-impedance state.                                        |

190589

#### MPUZ80-408

|                           |                  |                   | (3/5)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|---------------------------|------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin                       | Q'ty<br>(Number) | Туре              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| HALT                      | 1<br>(31)        | Output<br>3-state | The Halt signal. This pin goes "0" when the MPU has<br>executed a Halt instruction and is in the Halt state. It is<br>put in the high-impedance state when the EV signal is<br>applied.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RFSH                      | 1<br>(26)        | Output            | The refresh signal. When the dynamic memory refresh address is on the low-order 8 bits of the address bus, this signal goes "0". At the same time, the $\overline{\text{MREQ}}$ signal also goes active ("0"). This pin is put in the high-impedance state when the EV signal is applied.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| CLK/TRG0<br>~<br>CLK/TRG3 | 4<br>(72-75)     | Input             | The external clock/timer trigger. These 4 CLK/TRG pins<br>correspond to 4 channels. In the counter mode, the<br>down counter is decremented by 1 and in the timer<br>mode, the timer is activated at each active edge (a<br>rising or falling edge) of the signal which are input by<br>these pins. It can be selected by program whether the<br>active edge is a rising or falling edge.                                                                                                                                                                                                                                                                                                                              |
| ZC/TO0<br>~ZC/TO3         | 4<br>(68-71)     | Output            | The Zero Count/Timer Out signal. In either the Timer<br>mode, or counter mode, pulses are output from these<br>pins when the down counter has reached zero.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| IE!                       | 1<br>(60)        | Input             | The Interrupt Enable Input signal. This signal is used<br>with the IEO to form a priority daisy chain when there<br>is more than one interrupt-driven peripheral LSI.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| NMI                       | 1<br>(56)        | Input             | The Non-maskable Interrupt Request signal.<br>This interrupt request has a higher priority than the<br>maskable interrupt and is not dependent on the<br>interrupt enable flip-flop (IFF) state. This signal is also<br>used to return from the stand-by state in the Stop or<br>Idle mode.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| EV                        | 1<br>(58)        | Input             | The Evaluator signal. When this signal is active, the M1, HALT, and RFSH pins are put in the high-<br>impedance state. In using the TMPZ84C013A as an<br>evaluator chip, the MPU is electrically disconnected<br>(put in the high-impedance state) after one machine<br>cycle is executed with the EV signal being "1" and the<br>BUSREQ signal being "0", and follows the instructions<br>from other MPU (such as the MPU of ICE). The signals<br>of the disconnected MPU are A0 through A15, D0<br>through D7, MREQ, IORQ, RD, WR, M1, HALT, and<br>RFSH. BUSACK needs to be disconnected by an<br>externally connected circuit. The evaluator board is<br>available to use the TMPZ84C013A as an evaluator<br>chip. |
(4/5)

| Pin <sub>.</sub> | Q'ty<br>(Number) | Туре         | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------------|------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A7RF             | 1<br>(55)        | Output       | The 1-bit auxiliary address bus. This pin outputs the<br>same signal as the bit 7 (A7) of the address bus.<br>However, during a refresh cycle, this pin outputs the<br>address which is the most significant bit of the 8-bit<br>refresh address signal linked to the low-order 7 bits of<br>the address bus.                                                                                                                                                                                                                                                                  |
| W/RDYA<br>W/RDYB | 2<br>(32, 54)    | Output       | The Wait/Ready signal A and the Wait/Ready signal B.<br>These signals can be used as the Wait or Ready<br>depending on SIO programming. When these signals<br>are programmed as "Wait", they go active at "0" to<br>indicate to the MPU that the addressed memory or I/O<br>devices are not ready for data transfer, requesting the<br>MPU to wait. When these signals are programmed as<br>"Ready", they go active at "0" to determine when a<br>peripheral device associated with a DMA port is ready<br>for a read or write data. The DMA is requested to<br>transfer data. |
| SYNCA<br>SYNCB   | 2<br>(33, 53)    | Input/output | The Synchronization signal. In the asynchronous receive mode, these signals act as the $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ signals. In the external sync mode, these signals act as inputs and in the internal sync mode, they act as outputs.                                                                                                                                                                                                                                                                                                                 |
| RXDA<br>RXDB     | 2<br>(34, 52)    | Input        | The Serial Receive Data signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| RXCA<br>RXCB     | 2<br>(35, 51)    | Input        | The Receive Clock signal. In the asynchronous mode,<br>the Receive Clocks may be 1, 16, 32 or 64 times the<br>data transfer rate.                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TXCA<br>TXCB     | 2<br>(36, 50)    | Input        | The Transmitter Clock signal. In the asynchronous mode, the Transmitter Clocks may be 1, 16, 32, or 64 times the data transfer rate.                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TXDA<br>TXDB     | 2<br>(37, 49)    | Output       | The serial transmit data signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| DTRA<br>DTRB     | 2<br>(38, 48)    | Output       | The Data Terminal Ready signal. These signals<br>indicate whether the data terminal is ready to receive<br>serial data or not. When it is ready, these signals go<br>active to enable the transmitter of the terminal.<br>When it is not ready, these signals go inactive to<br>disable the transfer from the terminal.                                                                                                                                                                                                                                                        |
| RTSA<br>RTSB     | 2<br>(39, 47)    | Output       | The Request to Send signal. These pins are "0" when transmitting serial data. That is, to transmit data, these signals are made active to enable their receivers.                                                                                                                                                                                                                                                                                                                                                                                                              |

190589

|              |                  |        | (5/5)                                                                                                                                                                                                                                                                                                                         |
|--------------|------------------|--------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin          | Qʻty<br>(Number) | Туре   | Function                                                                                                                                                                                                                                                                                                                      |
| CTSA<br>CTSB | 2<br>(40, 46)    | Input  | The Clear To Send signal. When these pins are "0",<br>the modem having transmitted these signals is ready<br>to receive serial data. When it is ready, these signals<br>go active to enable the transmitter of the terminal.<br>When it is not ready, these signals go inactive to<br>disable the transfer from the terminal. |
| DCDA<br>DCDB | 2<br>(41, 45)    | Input  | The Data Carrier Detect signal. When these pins are<br>"0" the receive of serial data can be enabled. That is,<br>to transmit data, these signals are made active to<br>enable their receivers.                                                                                                                               |
| ICT          | 2<br>(42, 44)    | Output | The test pins. To be used in the open state.                                                                                                                                                                                                                                                                                  |
| WDTOUT       | 1<br>(61)        | Output | The Watchdog Timer signal.<br>The output pulse width depends on the externally<br>connected pin.                                                                                                                                                                                                                              |
| VCC          | 2<br>(43, 84)    |        | The power supply ( + 5 V) pins.                                                                                                                                                                                                                                                                                               |
| VSS          | 2<br>(22, 62)    |        | The ground (0 V) pins.                                                                                                                                                                                                                                                                                                        |

190589

# 2.2 (B) TMPZ84C013A Internal I/O Address Map

| Internal I/O                                  | Channel                                                                | I/O Address |
|-----------------------------------------------|------------------------------------------------------------------------|-------------|
|                                               | ch 0                                                                   | # 10        |
| CTC                                           | ch 1                                                                   | # 11        |
| (Counter Timer)                               | ch 2                                                                   | # 12        |
|                                               | ch 3                                                                   | # 13        |
|                                               | ch A Send/Receive buffer                                               | # 18        |
| SIO                                           | ch A Command/Status Register                                           | # 19        |
| (Serial I/O)                                  | ch B Send/Receive buffer                                               | # 1A        |
|                                               | ch B Command/Status Register                                           | # 1B        |
| Watch Dog Timer<br>Stand-by mode Register     | WDTER, WDTPR, HALTMR                                                   | # F0        |
| Watch Dog Timer<br>command Register           | Clear command (4E <sub>H</sub> )<br>disable command (B1 <sub>H</sub> ) | # F1        |
| Daisy-chaine interrupt<br>precedence Register | Only use bit2~bit0                                                     | # F4        |
|                                               |                                                                        | 190589      |

# TOSHIBA

# 3. OPERATIONAL DESCRIPTION

## 3.1 BLOCK DIAGRAM AND OPERATIONAL OUTLINE

#### 3.1.1 Block Diagram



MPUZ80-412

## 3.1.2 Operational Outline

The TMPZ84C013A largely consists of a processor (MPU), a counter/timer circuit (CTC), a serial input/output controller (SIO), a watchdog timer (WDT), and a clock generator/controller (CGC).

- The MPU provides all the capabilities and pins of the Toshiba TLCS-Z80 MPU (TMPZ84C00A) to play the role of the TLCS-Z80 microprocessor perfectly.
- The CTC provides the capabilities of the Toshiba TLCS-Z80 CTC (TMPZ84C30A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The four independent timer channels are I/O-addressed internally.
- The SIO provides the capabilities of the Toshiba TLCS-Z80 SIO (TMPZ84C43A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The two independent serial channels are I/O-addressed internally.
- The WDT incorporates one-channel watchdog timer and the read/write-enabled watchdog timer control registers indispensable for control applications. The WDT also has the register to determine interrupt priorities, allowing the user to set the daisy-chain interrupt priorities by program. Additionally, the WDT has the IEI and IEO pins required to process the daisy-chain interrupts caused by the peripheral LSIs to be added both inside and outside the TMPZ84C013A.
- The CGC provides the four operation modes to control the entire TMPZ84C013A chip; the Run, Idle-1, Idle-2, and Stop modes. They are program-selectable. This chip has two clock pins: CLKOUT to supply clock from the CGC and CLKIN to get clock from the outside. Therefore, the TMPZ84C013A can be operated on the clock supplied from the outside at the CLKIN pin without using the CGC. The following briefly describes the four operation modes of the CGC with the CLKOUT and CLKIN pins connected:
- In the Run mode, the clock generated by the CGC is supplied to the TMPZ84C013A and peripheral LSIs to perform the normal programmed microcomputer operations.
- In the Idle-1 mode, clock oscillation is going on but the clock is not supplied to the TMPZ84C013A and peripheral LSI, thereby saving the system power consumption and shortening the time required for system restart.

- In the Idle-2 mode, clock oscillation is performed and the clock is output from the CLKOUT pin. The clock is supplied only to the CTC in the TMPZ84C013A, permitting a wake-up operation by the CTC. Like the Idle-1 mode, the Idle-2 mode saves the system power consumption and shortens the time required for system restart.
- In the Stop mode, clock oscillation is not performed and the system operation can be stopped completely. In this mode, the system can be restarted with the internal data retained with an extremely low power consumption level unique to the CMOS technology.

Note that these modes can be set only when the MPU has executed a HALT instruction.

Additionally, the TMPZ84C013A has also the EV pin which is used with the  $\overline{\text{BUSREQ}}$  pin to put the MPU in the high-impedance state for electrical disconnection, thus functioning as an evaluator chip. That is, the MPU in the TMPZ84C013A is electrically disconnected by these two pins to implement the emulation by the signal from the in-circuit emulator (ICE). For emulation, one machine cycle is performed on the MPU in the TMPZ84C013A with EV being "1" and the  $\overline{\text{BUSREQ}}$  being "0" then the emulation is performed as instructed by the MPU. The MPU signals to be disconnected are A0 through A15, D0 through D7,  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ ,  $\overline{\text{M1}}$ ,  $\overline{\text{HALT}}$ , and  $\overline{\text{RFSH}}$ ,  $\overline{\text{BUSACK}}$  needs to be disconnected by an externally connected circuit.

### 3.2 MPU OPERATIONS

This subsection describes the system configuration, functions and the basic operations of the MPU of the TMPZ84C013A.

### 3.2.1 Block Diagram

Figure 3.2.1 shows the block diagram of the MPU.



120489

Figure 3.2.1 MPU Block Diagram

## 3.2.2 MPU System Configuration

The MPU has the configuration shown in Figure 3.2.1. The address signal is put on the address bus via the address buffer. The data bus is controlled for input or output by the data bus interface. Both the address and data buses are put in the high-impedance state by the BUSREQ signal input to make them available for other peripheral LSIs. The Opcode read from memory via the data bus is written to the instruction register. This Opcode is decoded by the instruction decoder. According to the result of the decoding, control signals are sent to the relevant devices. Receiving these control signals, the ALU performs various arithmetic operations. The register array temporarily hold the information required to perform operation.

The following describes the MPU's main components and functions which the user must understand to operate the TMPZ84C013A:

[1] Internal Register Groups

The configuration of the internal register groups is as follows:

(1) Main registers

A, F, B, C, D, E, H, L

(2) Alternate registers

A', F', B', C', D', E', H', L'

(3) Special purpose registers

I, R, IX, IY, SP, PC

Figure 3.2.3 shows the configuration of the internal register groups. The register groups, each being of a static RAM, consists of eighteen 8-bit registers and four 16-bit registers. The following describes the function of each register:

(1) Main registers (A, F, B, C, D, E, H, L)

(a) Accumulator (A)

The accumulator is an 8-bit register used for arithmetic and data transfer operations.

(b) Flag register (F) (see Figure 3.2.2)

The flag register is an 8-bit register to hold the result of each arithmetic operation. Actually, the 6 of the 8 bits are set ("1")/reset ("0") according to the condition specified by an instruction.





The following 4 bits are directly available to the programmer for setting the jump, call and return instruction conditions:



120489

Figure 3.2.3 Flag Register Configuration

#### • Sign flag (S)

When the result of an operation is negative, the S flag is set to "1". Actually, the content of bit 7 of accumulator is stored in this flag.

Zero flag (Z)

When all bits turn out to be "0" s after operation, the Z flag is set to "1". Otherwise, it is set to "0". With a block search instruction (CPI, CPIR, CPD or CPDR), the Z flag is set to "1" if the source data and the accumulator data match. With a block I/O instruction (INI, IND, OUTI or OUTD), the Z flag is set to "1" if the content of the B register used as the byte counter is "0" at the end of comparison.

#### • Parity/overflow flag (P/V)

This flag has two functions. One is the parity flag (P) that indicates the result of a logical operation (AND A, B etc.). The P flag is set to "1" if the parity is even as a result of the operation on signed values by two's complement. It is reset to "0" if the parity is odd. With a block search instruction (CPI, CPIR, CPD or CPDR) and a block transfer instruction (LDI or LDD), the P flag indicates the state of the byte counter (register pair B and C). It is set to "1" if the byte counter is not "0" and reset to "0" when the byte counter becomes "0" (at the end of comparison or data transfer). The content of the interrupt enable flip-flop (IFF) is saved to the P flag when the contents of the R register or I register are transferred to the accumulator.

The other use of the P/V flag is the overflow flag (V) that indicates whether an overflow has occurred or not as a result of an arithmetic operation. The V flag is set to "1" when the value in the accumulator gets out of a range of the maximum value +127 and the minimum value -128 and therefore cannot be correctly represented as a two's complement notation.

Whether the P/V flag operates as the P flag or V flag is determined by the type of the instruction executed.

Carry flag (C)

The C flag is set to "1" if a carry occurs from bit 7 of the accumulator or a borrow occurs as a result of an operation.

The following two flags are not available to the programmer for the test and set ("1")/reset ("0") purposes. They are internally used by the MPU for BCD arithmetic operations.

# • <u>Half carry flag (H)</u>

The H flag is used for holding the carry or borrow from the low-order 4 bits of a BCD operation result. When a DAA instruction (decimal adjust) is executed, the MPU automatically uses the H flag to adjust the result of a decimal addition or subtraction.

## • Add/subtract flag (N)

In BCD operation, algorithm is different between addition and subtraction. The N flag indicates whether the executed operation is addition or subtraction.

For change of the flag state depending on the instruction, see 3.2.4 "TMPZ84C013A Instruction Set".

## (c) General-purpose registers (B, C, D, E, H, L)

General-purpose registers consist of 8 bits each. They are used as 16-bit register pairs (BC, DE, HL) as well as independent 8-bit registers to supplement the accumulator. The B register and the register pair BC are used as counters when a block I/O, block transfer, or search instruction is executed. The register pair HL has various memory addressing features as compared with the register pairs BC and DE.

## (2) Alternate registers (A', F', B', C', D', E', H', L')

The configuration of the alternate registers is exactly the same as that of the main registers. There is no instruction that handles the alternate registers directly. The data in the alternate registers are processed by moving them into the main registers by means of exchange instructions as shown below:

EX AF, AF'  $(A \leftrightarrow A', F \leftrightarrow F')$ EXX  $(B \leftrightarrow B', C \leftrightarrow C', D \leftrightarrow D', E \leftrightarrow E', H \leftrightarrow H', L \leftrightarrow L')$ 

When a hign-speed interrupt response has been requested within the system, these instruction can be used to quickly move the contents of the accumulator, flag registers, and general-purpose registers into the corresponding registers. This eliminates the need for transferring the register contents to/from the external stack during execution of the interrupt handling routine, thereby shortening the interrupt servicing time greatly.

(3) Special purpose registers (I, R, IX, IY, SP, PC)

#### (a) Interrupt page address register (I)

The TMPZ84C013A provides two kinds of interrupts :maskable interrupt (INT) and non-maskable interrupt (NMI). The maskable interrupt provides three modes (0, 1, and 2) in which the interrupt is handled. These modes can be selected by instructions IM0, IM1, and IM2 respectively. In Mode 2, any memory location can be called indirectly depending on the interrupt. For this purpose, the I register stores the high-order 8 bits of the indirect address. The low-order 8 bits are supplied from the interrupting peripheral LSI. This scheme permits calling the interrupt handling routine from any memory location in an extremely short access time. For the details of interrupts, see [4] "Interrupt Capability".

#### (b) Memory refresh register (R)

The R register is used as the memory refresh counter when the dynamic RAM is used for memory. This permits using of the dynamic memory in the same manner as the static memory. This 8-bit register is automatically incremented for each instruction fetch. While the MPU decodes and executes the fetched instruction, the contents of the R register are synchronized with the refresh signal to place the low-order 7 bits and A7RF on the address bus. This operation is all performed by the MPU and, therefore, dose not need a special processing by program. The MPU operation is not delayed by this operation. During refresh, the contents of the I register are placed on the high-order 8 bits of the address bus.

(c) Index registers (IX, IY)

The two independent index registers IX and IY hold the 16-bit base address when used in the index addressing mode. In this addressing mode, the memory address obtained by adding the contents of an index register to the displacement value (for example, LD IX+40H) is specified. This mode is convenient for using data tables. Also these registers can be used separately for memory addressing and data retaining registers.

### (d) Stack pointer (SP)

The stack pointer is a 16-bit register to provide the start address information in the stack area in the external RAM. The content of the stack pointer is decremented at the execution of a call instruction or PUSH instruction or interrupt handling and is incremented at the execution of a return instruction or POP instruction. At the execution of a call instruction or interrupt handling, the current content of the program counter is saved into the stack. At the execution of a return instruction, the content is restored from the stack to the program counter. These operations are all performed by the MPU automatically. However, the other registers are not saved or restored automatically. For the storing of the contents of these registers, an exchange instruction (EX or EXX) for alternate register, a PUSH or a POP instructions must be used. When a PUSH instruction is executed, the contents of the specified register are saved into the stack. When a POP instruction is executed, the contents of the stack are moved to the specified register.

These data are restored on a last-in, first-out basis. Use of the stack permits processing of multiple-level interrupts, deep subroutine nestings, and various data manipulation very easily. The stack pointer is not initialized in the hardware approach. Therefore, it is required to allocate the stack area in RAM to specify initialization (at the highest address of the stack area) in the initial program.

(ex)



The foregoing example shows the stack pointer and stack operations in which the instructions starting with the CALL at address 1230H and ending with the RET at address 1602H have been executed. However, it is assumed that there is no instruction or interrupt other than shown above that uses the stack during the execution. When the value of the stack pointer before executing the CALL instruction at address 1230H indicates address FFF1H, address 1233H is stored at addresses FFF0H and FFEFH because the CALL instruction consists of 3 bytes, then the stack pointer is decremented. Similarly, the data are saved or restored sequentially according to the instructions. These stack and stack pointer operations are all performed automatically.

#### (e) Program counter (PC)

The program counter holds, in 16 bits, the memory address of the instruction to be executed next. The MPU fetches the instruction from the memory location indicated by the program counter. When the content of the program counter is put on the address bus, the program counter is incremented automatically. However, it is not incremented with a jump instruction, a call instruction, or interrupt processing. Instead, the specified new address is set on it. With a return instruction, the content restored from the stack is set on the program counter.

These operations are all performed automatically and therefore, no care is required for programming.

## [2] Halt Capability

When a HALT instruction has been executed, the MPU is put in the halt state. The halt capability can be used to halt the MPU against the external interrupts, thereby reducing the power dissipation. In the halt state the states of MPU's internal registers are retained. The halt state is cleared by reset or when an interrupt is accepted. For the details of halt operation, see [3] "Basic Timing".

#### (1) Halt operation

When a HALT instruction has been executed, the MPU sets the HALT signal to "0" to indicate that the MPU is going to be put in the halt state. Actually, the MPU in the halt state automatically continues executing NOP instructions if there is the system clock input. However, the program counter is not incremented. This keeps the refresh signal generated when the dynamic memory is used. During halt, the MPU's internal states are retained. The TMPZ84C013A contains the clock generator/controller, easily implementing the clock input control for these halt operations.

## (2) Releasing the halt state

The halt state is cleared by accepting an interrupt (the  $\overline{INT}$  or  $\overline{NMI}$  signal input) or by reset (the  $\overline{RESET}$  signal input). When an interrupt is accepted, the halt state is cleared and the interrupt handling routine is executed. However, a maskable interrupt (INT) cannot be accepted unless the interrupt enable flip-flop (IFF) is set.

Note that when the halt state is cleared by the  $\overline{\text{RESET}}$  signal, the MPU is reset and the program counter is set to "0".

[3] RESET Signal

Holding the  $\overrightarrow{\text{RESET}}$  pin at the low level ("0") under the following conditions, the MPU's internal states are reset:

- (1) The supply voltage level is within the operational voltage range.
- (2) System clock stabilization.
- Holding the RESET signal at the low level ("0") for at least 3 full clock cycles.
  When the RESET signal goes high ("1"), the MPU starts executing instructions from address 0000H after at least 2T state dummy cycles.

When reset, the MPU performs the following processing:

(a) Program counter

0000H is set.

(b) Interrupt

The interrupt enable flip-flop (IFF) is reset to "0" to disable the maskable interrupt. For the maskable interrupt processing, mode 0 is specified.

(c) Control output

All control outputs are made inactive ("1"). Therefore, the halt state is also cleared.

(d) Interrupt page address register (I register)

The content of the R register becomes 00H.

(e) Refresh register (R register)

The content of the R register becomes 00H.

The contents of the registers other than above and the external memory do not change.

Therefore, they must be initialized as required.

#### [4] Interrupt Capability

The interrupt capability is used to suspend the execution of the current program and execute the processing of the requested peripheral LSI. Normally, this interrupt processing routine contains the data exchange and transfer of status and control information between the MPU and the peripheral LSI. When this routine has been completed, the MPU returns to the state before the interrupt has been accepted.

The TMPZ84C013A provides the non-maskable interrupt (NMI) and maskable interrupt (INT) capabilities which are detected by the  $\overline{\text{NMI}}$  and  $\overline{\text{INT}}$  interrupt request signals, respectively. A non-maskable interrupt, when caused by a peripheral LSI, is accepted unconditionally. This interrupt is used to support critical functions such as the protection of the system from unpredictable happening including power failure. A maskable interrupt can be enabled or disabled by program. For example, if the timer is used and, therefore, an interrupt is not desired, the system can be programmed to disable the interrupt. Table 3.2.1 lists the processing by interrupt source.

(1) Interrupt enable/disable

A non-maskable interrupt cannot be disabled by program, while a maskable interrupt can be enabled or disabled by program. The MPU has the interrupt enable flip-flop (IFF). A maskable interrupt can be enabled or disabled by setting this flip-flop to "1" (set) or "0" (reset) through an EI instruction (enable) or a DI instruction (disable) in program. Actually, the IFF consists of two flip-flops IFF1 and IFF2. IFF1 is used to select between the enable and disable of a maskable interrupt. IFF2 holds the state of IFF1 before a maskable interrupt has been accepted. Both IFF1 and IFF2 are reset to "0" when any of the following conditions occurs, disabling an interrupt:

- MPU reset
- Execution of DI instruction
- Acceptance of maskable interrupt

Both IFF1 and IFF2 are set to "1" when the the following condition occurs, enabling an interrupt:

#### • Execution of EI instruction

Actually, the waiting maskable interrupt request is accepted after the execution of the instruction that follows the EI instruction.

This delay by one instruction is caused by accepting an interrupt after completion of the execution of a return instruction if the instruction following the EI instruction is a return instruction.

In the above operation, the contents of IFF1 and IFF2 are the same.

120489

| Interrupt Source          | Priority | Programmed condition |        | Vector address            | Interrupt<br>return<br>instruction |
|---------------------------|----------|----------------------|--------|---------------------------|------------------------------------|
| Non-maskable interrupt    | 1        | None                 |        | Address 66H               | RETN                               |
|                           |          |                      |        | Instruction from          |                                    |
| Maskable interrupt (INT   | 2        | IFF = 1              | Mode 0 | peripheral LSI.           | (Note)                             |
| becomes "0" at            |          |                      |        | Normally, CALL or RST     | RETI                               |
| instruction's last clock) |          |                      |        | instruction.              |                                    |
|                           |          |                      | Mode 1 | Address 38H.              |                                    |
|                           |          |                      |        | The address indicated by  |                                    |
|                           |          |                      |        | the data table (memory)   |                                    |
|                           | 1        |                      | Mode 2 | at the address specified  |                                    |
|                           |          |                      |        | by I register (high-order |                                    |
|                           |          |                      |        | 8 bits) and data from     |                                    |
|                           |          |                      |        | peripheral LSI (low-      |                                    |
|                           |          |                      |        | order 8 bits, LSB = "0"). |                                    |

Table 3.2.1 Processing by Interrupt Source

Note: Mode 0 applies when the instruction from peripheral LSI is CALL or RST instruction.





When a non-maskable interrupt has been accepted, IFF1 is reset to "0" (interrupt disable) until an EI or RETN instruction is executed, so as to prevent from accepting the next interrupt. For this purpose, the state (interrupt enable/disable) of IFF1 immediately before non-maskable interrupt acceptance must be stored. This state is copied into IFF2 upon acceptance of a non-maskable interrupt. The content of IFF2 is copied into the parity flag at the execution of the following instructions, so that the copied data can be tested or stored:

- The load instruction (LD A, I) to load the contents of the I register into the accumulator.
  - The load instruction (LD A, R) to load the contents of the R register into the accumulator.

When the return instruction (RETN) from the non-maskable interrupt is executed, the contents of the current IFF2 are copied back to IFF1. If an operation which changes the contents of IFF2 (due to the execution of EI or DI instruction, for example) has not been performed during interrupt handling, IFF1 automatically returns to the state immediately before the interrupt acceptance. Table 3.2.1 lists the states of IFF1 and IFF2 after execution of interrupt-related instructions.

| Operation sequence | IFF1 | IFF2 | Remarks          |
|--------------------|------|------|------------------|
| MPU reset          | 0    | 0    |                  |
| EI                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| LD A, I            | *    | *    | Parity flag←IFF2 |
| RETN               | 1    | 1    | IFF1←IFF2        |
| LD A, R            | *    | *    | Parity flag←IFF2 |
| INT acceptance     | 0    | 0    |                  |
| RETI               | *    | *    |                  |
| El                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| DI                 | 0    | 0    |                  |
| RETN               | *    | *    |                  |

Table 3.2.2 State of IFF1 and IFF2

Note: \* = no change.

120489

## (2) Interrupt processing

With a non-maskable interrupt, the internal NMI flip-flop is set to "1" on the falling edge of the interrupt signal,  $\overline{\text{NMI}}$ . The state of this flip-flop is sampled on the rising edge of the last clock of each instruction to accept an interrupt. A maskable interrupt is accepted if the interrupt signal  $\overline{\text{INT}}$  is low ("0") on the rising edge of the last clock of each instruction and the interrupt enable state (IFF=1 and  $\overline{\text{BUREQ}}$  signal=inactive ("1")) is on. The following is the processing to be performed after a non-maskable interrupt and a maskable interrupt are accepted:

(a) Non-maskable interrupt (NMI)

When a non-maskable interrupt has been accepted, the MPU performs the following processing:

- 1 The internal NMI flip-flop is reset to "0".
- 2 IFF1 is reset to "0", disabling the maskable interrupt.

The contents of the IFF1 immediately before the interrupt acceptance are copied into the IFF2.

- 3 The content of the current program counter is saved into the stack.
- 4 The instructions starting from non-maskable interrupt vector address 66H are executed.

The non-maskable interrupt processing program terminates after executing the RETN instruction. This return instruction performs the followings:

- 1 The contents of the current IFF2 are copied into IFF1.
- 2 The contents of the program counter are restored from the stack.



120489

Figure 3.2.5 Non-Maskable Interrupt Processing

#### (b) Maskable interrupt (INT)

When a maskable interrupt has been accepted, the MPU performs the following processings:

- 1 Both IFF1 and IFF2 are reset to "0", disabling the maskable interrupts.
- 2 The content of the current program counter is saved into the stack.
- 3 A maskable interrupt is serviced in one of the three modes 0, 1 and 2. A mode is selected by executing the instruction IM0, IM1or IM2 before the interrupt is serviced. The instructions are executed starting from the vector address corresponding to the selected mode.
- Mode 0

In mode 0, the interrupting peripheral LSI puts a restart instruction (RST) or a call instruction (CALL) on the data bus and the MPU executes the interrupt service routine according to that instruction. At reset, this mode is automatically set.



RST from peripheral LSI Address specified by CALL or Execution of RETI instruction.

120489

120489

Figure 3.2.6 Interrupt Processing in Mode 0

• <u>Mode 1</u>

When an interrupt is accepted in mode 1, restart is performed from address 0038H. Therefore, the service routine for this interrupt is programmed from the address 0038H.





MPUZ80-428

## Mode 2

The interrupt processing in mode 2 requires a 16-bit pointer consisting of the high-order 8 bits of the I register and the low-order 8 bits (with the LSB="0") of the data fetched from the interrupting CTC or TLCS-Z80 family peripheral LSI. Therefore, the necessary value must be loaded in the I register beforehand. This pointer is used to specify the memory address in the table. The contents of the specified address and the next address provide the start address of the service routine. Therefore, use of this mode requires the table of the service routine's start address (16 bits) to be set at appropriate location under software control. This location can be anywhere in memory. The LSB of the table pointer is set to "0" because a 2-byte data is needed to specify the service routine start address in 16 bits and start that address from an even-number address. In the table, the start address begins with the low-order byte followed by the high-order byte as shown in Fig. 3.2.8.



Figure 3.2.8 Interrupt Processing in Mode 2

Mode 2 is used in the daisy chain interrupt processing using the CTC and TLCS-Z80 family LSI. The CTC and TLCS-Z80 family peripheral LSIs all contain the interrupt priority controller in daisy chain structure. In this interrupt structure, the interrupt request signals are connected one after another and given priorities for processing when two or more maskable interrupt requests occur at a time. Only the interrupt vector from the peripheral LSI having the highest priority is put on the data bus. By receiving the interrupt vector in mode 2, the processing for that peripheral LSI can be performed. When an interrupt requested by a peripheral LSI having a priority higher than that of the current peripheral LSI during the execution of the interrupt processing routine, the higher priority interrupt can be enabled by the EI instruction to form an interrupt nesting.

The maskable interrupt processing program terminates by executing an RETI instruction. This return instruction performs the following processings:

- Restores the content of the program counter from the stack.
- Notifies the requesting peripheral LSI of the termination of interrupt processing.

#### 3.2.3 MPU Status Transition Diagram and Basic Timing

The following describes the MPU status transition and the basic timing of each MPU operation.

[1] Instruction Cycle

Each TMPZ84C013A instruction is executed by combining the basic operations of memory read/write, input/output, bus request/acknowledge, and interrupt. These basic operations are performed synchronizing with the system clock (the CLK signal).

One clock period is called a state (T). The smallest unit of each basic operation is called a machine cycle (M). Each instruction consists of 1 to 6 machine cycles and each machine cycle consists of 3 to 6 clock states basically. However, the number of clock states in a machine cycle can be increased by the WAIT signal described later on. Figure 3.2.9 shows an example of the basic timing of a 3-machine-cycle instruction.

The first machine cycle (M1) of each instruction is the cycle in which the Opcode of the instruction to be executed next is read (this is called the Opcode fetch cycle). The Opcode fetch cycle basically consists of 4 to 6 clock states. In the machine cycle that follows the Opcode fetch cycle, data is transferred between the MPU and the memory or peripheral LSIs. This operation basically consists of 3 to 5 clock states.



Figure 3.2.9 Example of MPU Basic Timing (3-Machine-Cycle Instruction)

# [2] Status Transition Diagram





MPUZ80-431

### [3] Basic Timing

(1) Opcode fetch cycle (M1)

In the Opcode fetch cycle, MPU fetches an Opcode in the machine-language codes in memory. This is also called the M1 cycle because it is the first machine cycle to execute each instruction.

Figure 3.2.12 shows the basic timing of a basic Opcode fetch cycle.

In clock state T1, the content of the program counter is put on the address bus. The  $\overline{\text{M1}}$  signal goes "0", indicating to the MPU that this is the Opcode fetch cycle. At the same time,  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals go "0". When the  $\overline{\text{MREQ}}$  signal goes "0", the address signal has already been stabilized. Therefore, this signal can be used for the memory chip enable signal. The  $\overline{\text{RD}}$  signal indicates that the MPU is ready to accept the data from memory. By these signals, the MPU accesses memory to fetch the Opcode in the instruction register. The MPU samples the  $\overline{\text{WAIT}}$  signal on the falling edge of clock state T2. If the  $\overline{\text{WAIT}}$  signal is "0" on the falling edge of clock state T2 and the following wait state (TW), the next state becomes clock state TW. Figure 3.2.13 shows the delay state of the Opcode fetch cycle caused by the  $\overline{\text{WAIT}}$  signal.

The data (Opcode) on the data bus is fetched on the rising edge of clock state T3 then, the  $\overline{\text{MREQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{M1}}$  signals go "1". In clock state T3, a memory refresh address is put on the 8 bits consisting of the low-order 7 bits of the address bus and the A7RF corresponding to bit 8 and the  $\overline{\text{RFSH}}$  signal goes "0" and the  $\overline{\text{MREQ}}$ signal goes "0" again. This signal indicates that the memory refresh cycle is on. At this time, the contents of the I register are put on the high-order 8 bits of the address bus and the 7 bits of the R register contents and the A7RF signal corresponding to bit 8 are put on the low-order 8 bits of the address bus. By using the  $\overline{\text{RFSH}}$  and  $\overline{\text{MREQ}}$  signals, memory refresh is performed in clock state T3 and T4. However, the  $\overline{\text{RD}}$  signal remains "1" because the contents of the memory refresh address are not put on the data bus.

The address bus of 8 bits consisting of the low-order 7 bits of address (A6 through A0) and the A7RF are used as the 8-bits refresh address. That is, when A7RF is used for the refresh address, signals "00H" through "FFH" are output. In cycles other than the refresh cycle, the signal equivalent to A7RF are output. However, at reset, the signals to be output are uncertain. Figure 3.2.11 shows the refresh timing.



Figure 3.2.11 Refresh Timing

In clock state T4, the  $\overline{\text{MREQ}}$  signal returns to "1". The refresh address is kept output until the rising edge of the clock state T1 in the next machine cycle, keeping the  $\overline{\text{RFSH}}$  signal set to "0". The cycle delay state caused by setting the  $\overline{\text{WAIT}}$  signal to "0" is the same in the memory read/write, input/output, and maskable interrupt acknowledge cycles. The diagram of the cycle delay state caused by the  $\overline{\text{WAIT}}$  signal set to "0" is omitted in the following description.



Figure 3.2.12 Opcode Fetch Timing

MPUZ80-433



Figure 3.2.13 Opcode Fetch Timing Including Wait State

## (2) Memory read/write operations

Figure 3.2.14 shows the basic timing of memory read/write operations (except for the Opcode fetch cycle) in the same diagram for convenience.

In each operation, the memory address signal to read/write data on the address bus is output in clock state T1. The operation in which the WAIT signal is sampled in clock state T2 and the following TW state is the same as the Opcode fetch cycle.

In memory read, memory data is put on the data bus by the address,  $\overline{\text{MREQ}}$ , and  $\overline{\text{RD}}$  signals. The MPU reads this data.

In memory write, the memory address signal is put on the address bus then the  $\overline{\text{MREQ}}$  signal is set to "0" to put the write data onto the data bus. When the data bus has been stabilized, the  $\overline{\text{WR}}$  signal is output in clock state T2. The  $\overline{\text{WR}}$  signal can be used as the memory write signal.



Figure 3.2.14 Memory Read/Write Cycle Timing

#### (3) Input/output operations

Figure 3.2.15 shows the basic timing of input/output operations. The feature of the I/O operation timing is that, regardless of the state of the WAIT signal in clock state T2, the I/O cycle automatically goes in the wait state (TW\*) after clock T2. The WAIT signal is sampled on the falling edge of TW\*. If the WAIT signal is "0" on the falling edges of TW\* and the following clock state, the I/O operation enters into clock state TW\*. Clock state TW\* is inserted because the IORQ signal goes "0" in clock state T2, so that it is too late to sample the WAIT signal after decoding the I/O port address. In each of input and output operations, the I/O port address is put on the low-order 8 bits of the address bus in clock state T1. On the high-order 8 bits, the contents of the accumulator or B register are output. In clock state T2, the IORQ signal goes "0" instead of the MREQ signal. The IORQ signal can be used as the chip enable signal for a peripheral LSI.

In an input operation, the contents of the input port are read onto the data bus by the address,  $\overline{IORQ}$ , or  $\overline{RD}$  signals. The MPU reads this data.

In an output operation, the output port address and the output data are respectively put on the address bus and data bus in clock state Tl, then the  $\overline{IORQ}$  and  $\overline{WR}$  signals go "0" in clock state T2. The  $\overline{WR}$  signal can be used as the output port write signal.



Figure 3.2.15 I/O Operating Timing

(4) Bus request and bus acknowledge operations

Figure 3.2.16 shows the basic timing of bus request and bus acknowledge operations.

The address bus (A0 through A15), data bus (D0 through D7),  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{WR}}$  signals controlled by the MPU can be put in the high-impedance state (floating) to electrically disconnect them from the MPU. This operation, after sampling the  $\overline{\text{BUSREQ}}$  signal on the rising edge of the last clock of each machine cycle, starts on the rising edge of the next clock if this signal is found "0".

Subsequently, these buses are controlled by external peripheral LSIs. For example, data can be directly transferred between memory and these peripheral LSIs. This state is cleared if the  $\overline{\text{BUSREQ}}$  signal is found "1" after sampling it on the rising edge of each subsequent clock state (TX), and enters into the next machine cycle. During the floating state, the  $\overline{\text{BUSACK}}$  signal goes "0" to indicate it to the peripheral LSIs.

In this state, however, no memory refresh is performed and, therefore, the  $\overline{\text{RFSH}}$  signal is set to "1". Hence, to maintain this state for a long time with a system using dynamic memory, memory refresh must be performed by the external controller.

Note that, in the floating state, neither maskable interrupt (INT) nor non-maskable interrupt (NMI) can be accepted.



Figure 3.2.16 Bus Request and Bus Acknowledge Timing

(5) Maskable interrupt acknowledge operation

Figure 3.2.17 shows the basic timing of the maskable interrupt acknowledge.

The MPU samples the maskable interrupt request signal (INT) on the rising edge of the last clock of each instruction execution. If the INT signal is found "0", a maskable interrupt is accepted except in the following cases:

- The interrupt enable flip-flop is reset to "0".
- The BUSREQ signal is "0".

When a maskable interrupt has been accepted, a special Opcode fetch cycle is generated. In this cycle, 2 clock states of wait state (TW\*) is automatically inserted after the clock state T2. The WAIT signal is sampled on the falling edges of the second clock state TW\* and the following clock state TW and, if the WAIT signal is found "0", the instruction cycle enters in the next clock state TW. In this Opcode fetch cycle, the  $\overline{IORQ}$  signal goes "0" in the first TW\* state instead of the MREQ signal while, in a normal Opcode fetch cycle, the  $\overline{MREQ}$  signal goes "0" in clock state T1. This indicates to the maskable interrupt requesting LSI that the 8-bit interrupt vector can be put on the data bus. The MPU reads this data to perform interrupt processing. Therefore, the contents of the program counter put on the address bus are not used. Unlike an ordinary I/O operation, the  $\overline{RD}$  signal does not go "0".

In clock state T3, the memory refresh address signal is put on the address bus for memory refresh like normal Opcode fetch cycle and the  $\overline{\text{RFSH}}$  signal goes "0". In the subsequent machine cycles (M2 and M3), the contents of the current program counter are saved into the stack. In machine cycles M4 and M5, the contents of the I register (the high-order 8 bits) and the contents of the address indicated by the address of the vector (the low-order 8 bits) from the CTC and the peripheral LSI are fetched in the program counter.



Figure 3.2.17 Maskable Interrupt Acknowledge Timing

#### (6) Non-maskable interrupt acknowledge operation

Figure 3.2.18 shows the basic timing of non-maskable interrupt acknowledge.

When the non-maskable interrupt request signal ( $\overline{\text{NMI}}$ ) goes low, the internal non-maskable flip-flop is set to "1". The  $\overline{\text{NMI}}$  signal is detected in any timing of each instruction. However, the internal NMI flip-flop is sampled on the rising edge of the last clock of each instruction. Therefore, the  $\overline{\text{NMI}}$  signal should go low by the last clock state of an instruction.

The Opcode fetch cycle for non-maskable interrupt request acknowledge is generally the same as the ordinary Opcode fetch cycle. However, the Opcode on the data bus at the time is ignored. The contents of the current program counter are saved into the stack in the subsequent machine cycles (M2 and M3). In the following machine cycle, the operation jumps to address 0066H, the non-maskable interrupt vector address. The machine cycles after these depend on the contents of the fetched Opcode.

## TOSHIBA



Figure 3.2.18 Non-Maaskable Inpterrupt Acknowledge Timing

## (7) Halt operation

When a HALT instruction is fetched in the Opcode fetch cycle, the MPU sets the  $\overline{\text{HALT}}$  signal to "0" synchronized with the falling edge of clock state T4 to indicate it to the peripheral LSI and stops operating. If the system clock is kept supplied in the halt state, the MPU continues executing NOP instructions. This is done to output refresh signals when the dynamic memory is used. The NOP instruction execution cycle is the same as the ordinary Opcode fetch cycle except the data on the data bus are ignored.

The halt state is cleared when an interrupt is accepted or the  $\overline{\text{RESET}}$  signal is set to "0" to reset the MPU. Figure 3.2.19 shows the halt state clear operation by interrupt acknowledge. An interrupt is sampled on the rising edge of the last clock (clock state T4) of the NOP instruction. A maskable interrupt can be accepted when the  $\overline{\text{INT}}$  signal is "0". A non-maskable interrupt is accepted when the internal NMI flip-flop which is set on the falling edge of the  $\overline{\text{NMI}}$  signal is set at "1". However, it is required that the interrupt enable flip-flop is set to "1" for a maskable interrupt to be accepted. The interrupt processing for the accepted interrupt starts from the next cycle. However, when the supply of the system clock from the CGC has been stopped by the power down operation, it is required to restart the supply of the system clock and input the  $\overline{\text{INT}}$  signal until the execution of one instruction is completed or the RESET signal until 3 clocks are output. Figure 3.2.20 shows the timing of clearing the halt state caused by power down.

For the reset operation, see (8) "Reset operation". Note that the  $\overline{INT}$  and  $\overline{NMI}$  signals are shown on the same diagram in Figures 3.2.19 and 3.2.20 for convenience.



Figure 3.2.19 Timing of Clearing Halt State Caused by Interrupt Acknowledge



Figure 3.2.20 Timing of Clearing Halt State Caused by Power Down

## (8) Reset operation

Figure 3.2.21 shows the basic timing of reset operation.

To reset the MPU, the  $\overline{\text{RESET}}$  signal must be kept at "0" for at least 3 clocks. When the  $\overline{\text{RESET}}$  signal goes "1", instruction execution starts from address 0000H after a dummy cycle of at least 2 clock states.



Figure 3.2.21 Reset Timing

To clear the power down state by using the  $\overline{\text{RESET}}$  signal, the  $\overline{\text{RESET}}$  signal must be input until 3 clocks or more are supplied by restarting the supply of the system clock from the CGC.

## (9) Evaluation operation

Each of the MPU signals (A0 through A15, D0 through D7,  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{HALT}}$ ,  $\overline{\text{M1}}$ , and  $\overline{\text{RFSH}}$ ) can be put in the high-impedance state by EV and  $\overline{\text{BUSREQ}}$  signals to electrically disconnect them from the MPU.



Figure 3.2.22 Evaluation Timing

Figure 3.2.23 shows the block diagram of the TMPZ84C013A operating as an evaluator in the evaluation mode.

The operations controlled by signals from the external MPU in the evaluation mode are the same as those of each device constituting the TMPZ84C013A. (However, for the watchdog timer operations, see "WDT Operational Description" because the watchdog timer is of random logic configuration.)

For the electrical characteristics and timing of each device, see "Inactive State".



130489



MPUZ80-444

## 3.2.4 TMPZ84C013A Instruction Set

This subsection lists the TMPZ84C013A instruction codes and their functions. The table below lists the symbols and abbreviations used to describe the instruction set. The symbols which require special attention are described in the locations in which they appear.

• Symbols (1/2)

| Classification | Symbol          | Meaning                                       |                      |  |
|----------------|-----------------|-----------------------------------------------|----------------------|--|
| Register       | r, g            | Register                                      | B, C, D, E, H, L, A, |  |
|                | t               | Register pair                                 | BC, DE, HL           |  |
|                |                 | Stack pointer                                 | SP                   |  |
|                | q               | Register pair                                 | BC, DE, HL, AF       |  |
|                | р               | Register pair                                 | BC, DE               |  |
|                |                 | Index register                                | IX                   |  |
|                |                 | Stack pointer                                 | SP                   |  |
|                | S               | Register pair                                 | BC, DE               |  |
|                |                 | Index register                                | IY                   |  |
|                |                 | Stack pointer                                 | SP                   |  |
|                | t <sub>H</sub>  | Higher register of register pair              |                      |  |
|                |                 |                                               | (B, D, H)            |  |
|                |                 | Higher 8 bits of stack pointer (SP)           |                      |  |
|                | qн              | Higher register of register pair              |                      |  |
|                |                 |                                               | (B, D, H, A)         |  |
|                | IX <sub>H</sub> | Higher 8 bits of index register IX            |                      |  |
|                | IY <sub>H</sub> | Higher 8 bits of ind                          | dex register IY      |  |
|                | PCH             | Higher 8 bits of program counter (PC)         |                      |  |
|                | tL              | Lower register of register pair               |                      |  |
|                |                 | (C, E, L)                                     |                      |  |
|                |                 | Lower 8 bits of stack pointer (SP)            |                      |  |
|                | qL              | Lower register of register pair               |                      |  |
|                |                 | (C, E, L, F)                                  |                      |  |
|                | IXL             | Lower 8 bits of index register IX             |                      |  |
|                | IYL             | Lower 8 bits of index register IY             |                      |  |
|                | PCL             | Lower 8 bits of pro                           | ogram counter (PC)   |  |
|                | rb              | Bit b (0-7) of register (B, C, D, E, H, L, A) |                      |  |

120489
# • Symbols (2/2)

| Classification     | Symbol                | Meaning                                                                                                                                                                |
|--------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory             | mn                    | Memory address represented in 16 bits.                                                                                                                                 |
|                    | (HL) <sub>b</sub>     | m indicates higher 8 bits and n, lower 8 bits.<br>Bit b (0-7) of the contents of the memory<br>address indicated by register pair HL.                                  |
|                    | (IX + d) <sub>b</sub> | Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index                                 |
|                    | (IY + d) <sub>b</sub> | register IX.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IY. |
| Flag change symbol | 0                     | Reset to "0" by operation.                                                                                                                                             |
|                    | 1                     | Set to "1" by operation.                                                                                                                                               |
|                    | -                     | No change                                                                                                                                                              |
|                    | *                     | Affected by operation                                                                                                                                                  |
|                    | х                     | Undefined                                                                                                                                                              |
|                    | Р                     | Handled as parity flag.                                                                                                                                                |
|                    |                       | P = 0: odd parity                                                                                                                                                      |
|                    |                       | P = 1: even parity                                                                                                                                                     |
|                    | v                     | Handled as overflow flag.                                                                                                                                              |
|                    |                       | V = 0: No overflow                                                                                                                                                     |
|                    |                       | V = 1: Overflow                                                                                                                                                        |
| Operator           | ←                     | Transfer                                                                                                                                                               |
| × .                | ↔                     | Exchange                                                                                                                                                               |
|                    | +                     | Add                                                                                                                                                                    |
|                    | -                     | Subtract                                                                                                                                                               |
|                    | Λ                     | Logical and between bits.                                                                                                                                              |
|                    | V                     | Logical or between bits.                                                                                                                                               |
|                    | Ð                     | Exclusive or between bits                                                                                                                                              |
| Others             | IFF                   | Interrupt enable flip-flop                                                                                                                                             |
|                    | CY                    | Carry flag                                                                                                                                                             |
|                    | Z                     | Zero flag                                                                                                                                                              |

# TMPZ84C013A Instruction Set (1/9)

| ITEM/<br>CLASSI | ۵        | Assembler          |                            | Obj                                      | ject o    | ode                     | Eurotion           |                |              |        | FI | ag     |              |   |                | No.<br>Of   | No.<br>OF   |                                  |
|-----------------|----------|--------------------|----------------------------|------------------------------------------|-----------|-------------------------|--------------------|----------------|--------------|--------|----|--------|--------------|---|----------------|-------------|-------------|----------------------------------|
| -FICA-<br>TION  | m        | nnemonic           | 76                         | 543 210                                  |           | Hex                     | Function           | s              | Z            |        | н  |        | P/V          | N | с              | CY-<br>CLES | STA-<br>TES |                                  |
|                 | LD<br>LD | r,g<br>r,n         | 01                         | rrr ggg<br>rrr 110                       |           | 40+r×8+g<br>06+r×8      | r←g<br>r←n         |                | -            | x<br>x | -  | x<br>x | -            | - | -              | 1<br>2      |             | r rrr                            |
|                 | LD       | r,(HL)<br>r,(IX+d) | 01<br>11<br>01             | rrr 110<br>011 101<br>rrr 110            |           | 46+r×8<br>DD<br>46+r×8  | r+(HL)<br>r+(IX+d) | -              | -            | X<br>X | -  | X<br>X | -            | - | -              | 2<br>5      | 7<br>19     | 9 999<br>B 000<br>C 001<br>D 010 |
|                 | LD       | r,(IY+d)           | dd<br>11<br>01             | ddd ddd<br>111 101<br>rrr 110            |           | d<br>FD<br>46+r×8       | r+(IY+d)           | -              | -            | x      | -  | x      | -            | - | -              | 5           | 19          | E 011<br>H 100<br>L 101          |
|                 | LD<br>LD | (HL),r<br>(IX+d),r | dd<br>01<br>11<br>01       | ddd ddd<br>110 rrr<br>011 101<br>110 rrr |           | d<br>70+r<br>DD<br>70+r | (HL)←r<br>(IX+d)←r | -              | <u>-</u> .   | X<br>X | -  | X<br>X | -<br>-       | - |                | 2<br>5      | 7<br>19     | <u>A 111</u>                     |
| ٥               | LD       | (IY+d),r           | dd<br>11<br>01             | ddd ddd<br>111 101<br>110 rrr            |           | d<br>FD<br>70+r         | (IY+d)+r           | -              | -            | x      | -  | x      | -            | - | -              | 5           | 19          |                                  |
| L O A           | LD       | (HL),n             | dd (<br>00<br>nn (         | ddd ddd<br>110 110<br>nnn nnn            |           | d<br>36<br>n            | (HL)←n             | -              | -            | X      | -  | X      | -            | - | -              | 3           | 10          |                                  |
| DATA            |          | (1740), "          | 00<br>dd<br>nn             | 110 110<br>ddd ddd<br>nnn nnn            |           | 36<br>d                 | (17+0)+11          | -              | _            | X      | -  | *      | -            | - | -              | 5           | 19          |                                  |
| B - T           | LD       | (IY+d),n           | 11<br>00<br>dd             | 111 101<br>110 110<br>ddd ddd            |           | FD<br>36<br>d           | (IY+d)≁n           | -              | -            | x      | -  | x      | -            | - | -              | 5           | 19          |                                  |
| ø               | LD       | A,(BC)             | 00                         | 001 010                                  |           | 0A                      | A←(BC)             | <del>.</del> . | <del>.</del> | X      |    | . X    | <del>.</del> |   | <del>.</del> . | 2           | . 7         |                                  |
|                 | LD       | A,(mn)             | 00<br>nn 1<br>mm 1         | 111 010<br>nnn nnn<br>mmm mmm            |           | 3A<br>n<br>m            | A+(mn)             | -              | -            | X      | -  | ^<br>X | -            | - | -              | 4           | 13          |                                  |
|                 | LD       | (BC),A             | 00                         | 000 010                                  |           | 02                      | (BC)←A             | -              | -            | X      | -  | X      |              | - |                | 2           | 7           |                                  |
|                 | LD       | (DE),A<br>(mn),A   | 00  <br>00<br>nn  <br>mm   | 010 010<br>110 010<br>nnn nnn<br>mmm mmm | · · · · · | 12<br>32<br>n<br>m      | (DE)←A<br>(mn)←A   | -              | -            | X<br>X | -  | X<br>X | -            | - | -              | 2<br>4      | 7<br>13     |                                  |
|                 | LD       | A,I                | 11<br>01 (                 | 101 101<br>010 111                       |           | ED<br>57                | A←I                | *              | *            | х      | 0  | х      | IFF          | 0 | -              | 2           | 9           |                                  |
|                 | LD .     | A,R                | 11<br>01 (                 | 101 101<br>011 111                       |           | ED<br>5F                | A←R                | •              | *            | x      | 0  | x      | IFF          | 0 | -              | 2           | 9           |                                  |
|                 | LD       | I,A                | 11<br>01 (                 | 101 101<br>000 111                       |           | ED<br>47                | I←A                | -              | -            | х      | -  | х      | -            | - | -              | 2           | 9           |                                  |
|                 | LD       | R,A                | 11<br>01 (                 | 101 101<br>001 111                       |           | ED<br>4F                | R←A                | -              | -            | Х      | -  | X      | -            | - | -              | 2           | 9           |                                  |
| DATA<br>LOAD    | LD       | t,mn               | 00 1<br>nn 1<br>mm 1       | tt0 001<br>nnn nnn<br>nmm mmm            |           | 01+t×10<br>n<br>m       | t≁mn               | -              | -            | X      | -  | X      | -            | - | -              | 3           | 10          | t tt<br>BC 00                    |
| 16-BIT          | LD       | IX,mn              | 11 (<br>00<br>nn i<br>mm r | 011 101<br>100 001<br>nnn nnn<br>nmm mmm |           | DD<br>21<br>m           | IX←mn              | -              | -            | X      | -  | x      | -            | - | -              | 4           | 14          | DE 01<br>HL 10<br>SP 11          |

Note : r,g means any of the registers A, B, C, D, E, H, L.

IFF in "Flag" column indicates that the content of the interrupt enable flip-flop is copied into the P/V flag.

# TMPZ84C013A Instruction Set (2/9)

| ITEM/  | Assembler   | Object                   | code      |                                            |              |              |              | F            | lag |              |                |                  | No.<br>OF  | No.<br>OF |         |
|--------|-------------|--------------------------|-----------|--------------------------------------------|--------------|--------------|--------------|--------------|-----|--------------|----------------|------------------|------------|-----------|---------|
| -FICA- | mnemonic    | Binary                   | Hex       | Function                                   | -            | 7            | :            | н            |     |              | N              |                  | CY.        | STA-      |         |
|        | LD IY,mn    | 11 111 101               | FD        | IY←mn                                      | -            | -            | x            | -            | X   | _            | _              | -                | 4          | 14        |         |
|        | ,           | 00 100 001               | 21        |                                            |              |              |              |              |     |              |                |                  |            | -         |         |
|        |             | nn nnn nnn               | n         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
|        |             | mm mmm mmm               | m         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
|        | LD HL,(mn)  | 00 101 010               | 2A        | H←(mn+1)                                   | -            | -            | х            | -            | х   | -            | -              | -                | 5          | 16        | t tt    |
|        |             |                          | m         | (un)                                       |              |              |              |              |     |              |                |                  |            |           | DE 01   |
|        | LD t,(mn)   | 11 101 101               | ED        | t <sub>H</sub> ←(mn+1)                     |              | _            | Х            | -            | X   |              | -              |                  | 6          | 20        | HL 10   |
|        |             | 01 tt1 011               | 4B+t×10   | tL←(mn)                                    |              |              |              |              |     |              |                |                  |            |           | SP 11   |
|        |             | nn nnn nnn               | n         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
|        |             | mm mmm mmm               | m         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
|        | LD IX,(mn)  | 11 011 101               | 20        | IXH←(mn+1)                                 | -            | -            | Х            | -            | х   | -            | -              | -                | 6          | 20        |         |
|        |             |                          | 2A<br>n   | 11/2 ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( ( | [            |              |              |              |     |              |                |                  |            |           |         |
|        |             |                          | m         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
| □<br>∡ | LD IY,(mn)  | 11 111 101               | FD        | IY <sub>H</sub> ←(mn+1)                    |              | -            | Х            |              | Х   | -            | -              | -                | 6          | 20        |         |
| 0      |             | 00 101 010               | 2A        | IYL←(mn)                                   |              |              |              |              |     |              |                |                  |            |           |         |
| -      |             | nn nnn nnn               | n         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
| ∢      |             | നന നനന നനന               | m         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
| +      | LD (mn),HL  | 00 100 010               | 22        | (mn+1)←H                                   | -            | -            | х            | -            | Х   |              | -              | -                | 5          | 16        |         |
| A      |             | nn nnn nnn<br>mm mmm mmm | m         | (mn) = L                                   |              |              |              |              |     |              |                |                  |            |           |         |
|        | LD (mn).t   | 11 101 101               | ED        | (mn+1)←tµ                                  |              |              | x            |              | x   |              |                |                  | 6          | 20        |         |
| ⊢ ⊢    |             | 01 tt0 011               | 43+t×10   | (mn)+ti                                    |              |              |              |              |     |              |                |                  | ľ          |           |         |
|        |             | nn nnn nnn               | n         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
| 1      |             | mm mmm mmm               | m         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
| 9      | LD (mn),IX  | 11 011 101               | DD        | (mn+1)←IX <sub>H</sub>                     | -            | -            | Х            | -            | Х   | -            | -              | -                | 6          | 20        |         |
| -      |             | 00 100 010               | 22        | (mn)←IXL                                   |              |              |              |              |     |              |                |                  |            |           |         |
|        |             | nn nnn nnn               | n         |                                            |              |              |              |              |     |              |                |                  |            |           |         |
|        | ID (mn). IY | 11 111 101               | .""<br>FD | (mn+1)+TYu                                 |              | •••••        | Y            | ·            |     | ···          | - <u>-</u>     | · · <u>·</u> · · |            | 20        |         |
|        |             | 00 100 010               | 22        | (mn) ←IY                                   |              |              | Ŷ            |              | Â   |              |                |                  | ľ          | 20        |         |
| ļ      |             | nn nnn nnn               | n         |                                            |              |              |              |              | 1   |              |                |                  |            |           |         |
|        |             | mm mmm mmm               | m         |                                            |              |              |              |              |     |              |                |                  | [          |           |         |
|        | LD SP,HL    | 11 111 001               | F9        | SP←HL                                      |              | -            | Х.           |              | . X |              |                |                  | 1.         | 6         |         |
|        | LD SP,IX    | 11 011 101               | DD        | SP+IX                                      | -            | -            | Х            | -            | Х   | -            | -              | -                | 2          | 10        |         |
|        |             | 11 111 001               | F9<br>FD  | SD4TV                                      |              |              | ,.           |              | ·   |              |                |                  | <u>-</u> - |           |         |
|        | 51,11       | 11 111 001               | F9        | 51.11                                      | -            | -            | ^            | -            | ^   | _            |                |                  | 2          | 10        |         |
|        | PUSH q      | 11 qq0 101               | C5+q × 10 | (SP-2)←q;,(SP-1)←qH,                       |              | _            | х            | _            | X   | ·····        | _              | -                | 3          | 11        | 9 9 9 P |
|        |             |                          |           | SP+SP-2                                    |              |              |              |              |     |              |                |                  |            |           | BC 00   |
|        | PUSH IX     | 11 011 101               | DD        | (SP-2)←IXL,(SP-1)←IX <sub>H</sub>          | -            | -            | Х            | -            | Х   | - 1          | -              | -                | 4          | 15        | DE 01   |
|        |             | 11 100 101               | E5        | SP←SP-2                                    |              |              |              |              |     |              |                |                  |            |           | HL 10   |
|        | PUSH IY     | 11 111 101               | FD        | (SP-2)+IYL,(SP-1)+IYH                      | -            | -            | Х            | -            | Х   | -            | -              | -                | 4          | 15        | AF 11   |
|        | DOD #       | 11 100 101               | E5        | SP4SP-2                                    |              |              |              |              | ·   |              |                |                  | <u>.</u> . |           |         |
|        | FUP q       | 11 000 001               | C1+q X 10 | SP+SP+2                                    | -            | -            | X            | -            |     | -            | -              | -                | 3          | 10        |         |
|        | POP IX      | 11 011 101               | DD        | IXH+(SP+1),IXI+(SP)                        | · · · · ·    | ·            | <br>х        | ···_·        | x   | ·            | ÷              | · · · · ·        | 4          | 14        |         |
|        |             | 11 100 001               | E1        | SP←SP+2                                    |              |              | <sup>^</sup> |              | 'n  |              |                |                  |            | · '       |         |
|        | POP IY      | 11 111 101               | FD        | IYH←(SP+1),IYL←(SP)                        | -            | -            | х            | -            | х   | -            | -              | -                | 4          | 14        |         |
|        |             | 11 100 001               | E1        | SP←SP+2                                    |              |              |              |              |     |              |                |                  |            |           |         |
| *1     | EX DE,HL    | 11 101 011               | EB        | DE↔HL                                      |              |              | X            | <del>.</del> | Х.  |              |                |                  | 1          | 4         |         |
| 1      | LX AF, AF'  | 00 001 000               | 08        | At⇔AF'                                     | <del>.</del> | <del>.</del> | X            | <del>.</del> | Х., | <del>.</del> | ļ <del>.</del> |                  | <u>1</u> . | 4         |         |
| L      | 644         | 11 011 001               | 09        | DUADU, DEADE, HEART                        |              | -            | : X :        | : -          | : X |              | : - :          | -                | 1          | 4         |         |

Note : t is any of the register pairs BC, DE, HL, SP.

q is any of the register pairs AF, BC, DE, HL.

 $(PAIR)_{H}$ ,  $(PAIR)_{L}$  refer to high order and low order eight bits of the register pair respectively. (Ex) BC<sub>L</sub> = C, AF<sub>H</sub> = A.

\*1 : EXCHANGE

# TMPZ84C013A Instruction Set (3/9)

| ITEM/<br>CLASSI    | Assembler                  | Object                                 | code           |                                                                                                |               |    |        | FI | ag     |        |        |   | No.<br>OF   | No.<br>OF     |                            |
|--------------------|----------------------------|----------------------------------------|----------------|------------------------------------------------------------------------------------------------|---------------|----|--------|----|--------|--------|--------|---|-------------|---------------|----------------------------|
| -FICA-<br>TION     | mnemonic                   | Binary<br>76 543 210                   | Hex            | Function                                                                                       | s             | z  |        | н  |        | P/V    | N      | с | CY-<br>CLES | STA-<br>TES   |                            |
| NGE                | EX (SP),HL<br>EX (SP),IX   | 11 100 011<br>11 011 101               | E3<br>DD       | $H \leftrightarrow (SP+1), L \leftrightarrow (SP)$<br>IX <sub>H</sub> $\leftrightarrow (SP+1)$ | <u>-</u><br>- |    | X<br>X | -  | X<br>X | -      | -      | - |             | 19<br>23      |                            |
| ХСНА               | EX (SP),IY                 | 11 100 011<br>11 111 101               | E3<br>FD       | IXL↔(SP)<br>IYH↔(SP+1)                                                                         | -             | -  | x      | -  | X      | -      | -      | - | 6           | 23            |                            |
| <u> </u>           | LDI                        | 11 100 011                             | ED             | (DE)←(HL),DE←DE+1                                                                              | -             | -  | x      | 0  | х      | *м     | 0      | - | 4           | 16            |                            |
|                    | LDIR                       | 10 100 000<br>11 101 101<br>10 110 000 | A0<br>ED<br>B0 | HL+HL+1,BC+BC-1<br>(DE)+(HL),DE+DE+1<br>HL+HL+1,BC+BC-1 Repeat until                           | -             | -  | x      | 0  | x      | 0      | 0      | - | 5<br>4      | 21<br>16      | ←[BC< >0]<br>←[BC=0]       |
| S F E R            | LDD                        | 11 101 101<br>10 101 000               | ED<br>A8       | BC=0<br>(DE)+(HL),DE+DE-1<br>HI+HL-1.BC+BC-1                                                   | -             | -  | x      | 0  | x      | *м     | 0      | - | 4           | 16            |                            |
| T R A N<br>S E A R | LDDR                       | 11 101 101<br>10 111 000               | ED<br>B8       | (DE)+(HL),DE+DE-1<br>HL+HL-1,BC+BC-1 Repeatuntil                                               | -             | -  | x      | 0  | X      | 0      | 0      | - | 5           | 21<br>16      | ←[BC< >0]<br>←[BC=0]       |
| X X<br>U U         | CPI                        | 11 101 101<br>10 100 001               | ED<br>A1       | A-(HL)<br>HL←HL+1,BC←BC-1                                                                      | •             | *N | x      | *  | x      | *м     | 1      | - | 4           | 16            |                            |
| BLC                | CPIR                       | 11 101 101<br>10 110 001               | ED<br>B1       | A-(HL),HL←HL+1,BC←BC-1<br>Repeat until A=(HL) or BC=0                                          | •             | *N | x      | *  | X      | *м     | 1      | - | 5<br>4      | 21<br>16      | ←[BC < >0 &<br>A < > (HL)] |
|                    | CPD                        | 11 101 101<br>10 101 001               | ED<br>A9       | A-(HL)<br>HL←HL-1,BC←BC-1                                                                      | *             | *N | X      | *  | X      | *м     | 1      | - | 4           | 16            | A= (HL)]                   |
|                    | CPDR                       | 11 101 101<br>10 111 001               | ED<br>B9       | A-(HL),HL+HL-1,BC+BC-1<br>Repeat until A=(HL)or BC=0                                           | *             | *N | х      | *  | х      | *м     | 1      | - | 5<br>4      | 21<br>16      | ←[BC < >0 &<br>A < > (HL)] |
|                    | ADD A,r<br>ADD A,n         | 10 000 rrr<br>11 000 110               | 80+r<br>C6     | A←A+r<br>A←A+n                                                                                 | *             | *  | X<br>X | *  | X<br>X | v<br>v | 0<br>0 | * | 2           | <u>4</u><br>7 | A= (HL)]                   |
|                    | ADD A,(HL)                 | 10 000 110                             | 86             | A←A+(HL)                                                                                       | •             | •  | x      | •  | x      | v      | 0      | * | 2           | 7             | C                          |
| -                  | ADD A,(IX+d)               | 11 011 101<br>10 000 110               | DD<br>86       | A←A+(IX+d)                                                                                     | *             | *  | x      | ٠  | Х      | V      | 0      | * | 5           | 19            | B 000<br>C 001             |
| GICA               | ADD A,(IY+d)               | 11 111 101<br>10 000 110               | a<br>FD<br>86  | A←A+(IY+d)                                                                                     | *             | *  | x      | ٠  | X      | v      | 0      | ٠ | 5           | 19            | D 010<br>E 011<br>H 100    |
| ΓO                 | ADC A,r                    | dd ddd ddd<br>10 001 rrr               | d<br>88+r      | A+A+r+CY                                                                                       | •             | •  | x      | •  | x      | v      | 0      | * | 1           | 4             | L 101<br>A 111             |
| AND                | ADC A,n                    | 11 001 110<br>nn nnn nnn               | CE<br>n        | A←A+n+CY                                                                                       | *             | *  | х      | ٠  | Х      | V      | 0      | ٠ | 2           | 7             |                            |
| - C                | ADC A,(HL)<br>ADC A,(IX+d) | 10 001 110<br>11 011 101               | 8E<br>DD       | A←A+(HL)+CY<br>A←A+(IX+d)+CY                                                                   | *             | *  | X<br>X | *  | X<br>X | V<br>V | 0<br>0 | * | 2<br>5      | 7<br>19       |                            |
| HMET               |                            | 10 001 110<br>dd ddd ddd               | d<br>G         |                                                                                                |               |    |        |    |        |        |        |   |             |               |                            |
| RIT                | ADC A,(11+4)               | 10 001 110<br>dd ddd ddd               | 8E<br>d        |                                                                                                |               | Ĩ  | ^      | Ī  | *      | v      | U      |   | 5           | 19            |                            |
| ∣∢                 | SUB r                      | 10 010 rrr                             | 90+r           | A+A−r                                                                                          | *             | *  | χ      | *  | X      | v      | 1      | * | 1           | 4             |                            |
| 8 - 1              | SUB n                      | 11 010 110<br>nn nnn nnn               | D6<br>n        | A←A−n                                                                                          | •             | *  | x      | ٠  | х      | ۷      | 1      | * | 2           | 7             |                            |
|                    | SUB (HL)                   | 10 010 110                             | 96             | A←A−(HL)                                                                                       |               | *  | X      |    | Х      | ٧      | 1      | * | 2           | 7             |                            |
| Ĩ                  | SUB (IX+d)                 | 11 011 101<br>10 010 110<br>dd ddd ddd | DD<br>96<br>d  | A←A-(IX+d)                                                                                     | *             | •  | x      | •. | х      | ۷      | 1      | * | 5           | 19            |                            |
|                    | SUB (IY+d)                 | 11 111 101<br>10 010 110<br>dd ddd ddd | FD<br>96       | A←A−(IY+d)                                                                                     | •             | •  | x      | *  | x      | V      | 1      | * | 5           | 19            |                            |

Note : \*M P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1.

\*N Z flag is 1 if A = (HL), otherwise Z = 0.

[ ]indicates the total condition of the number of cycles and states indicated by arrow.

r means any of the registers A, B, C, D, E, H, L.

# TMPZ84C013A Instruction Set (4/9)

| ITEM/    | Assembler     |        |          |       | Object | code                                    |                                     |             |      |              | F            | lag            |             |            |             | No.          | No.        |     |     |
|----------|---------------|--------|----------|-------|--------|-----------------------------------------|-------------------------------------|-------------|------|--------------|--------------|----------------|-------------|------------|-------------|--------------|------------|-----|-----|
| -FICA-   | mnemonic      |        |          | Bina  | ary    | Hex                                     | Function                            | -           |      | :            | <del></del>  | ;              |             |            |             | CY-          | STA-       |     |     |
| TION     |               | /      | 5 :      | 543   | 210    |                                         |                                     | S           | 4    | <u> </u>     | н            | <u>.</u>       | P/V         | N          | C           | CLES         | TES        | I   |     |
|          | SBC A,r       | 10     | 9. J     | 011   | 111    | 98+r                                    | A+A-r-CY                            |             |      | <u> </u>     |              | X              | V           | 1          |             | 1            | 4          | r   | rrr |
|          | SBC A,n       | 1:     | 1 (      | 011   | 110    | DE                                      | A←A−n−CY                            | *           | *    | X            | *            | X              | v           | 1          | *           | 2            | 7          | В   | 000 |
|          | CDC A (111.)  | nı<br> | <u>.</u> | nnn   | nnn    | n                                       |                                     |             |      | <u></u>      |              |                |             |            |             |              |            | C   | 001 |
|          | SBC A, (HL)   | 1.10   |          | 011   | 110    | 95                                      | A+A-(HL)-CY                         |             |      | <u>. Х</u> . | <b>.</b>     | . X.           | v           | .1         |             | 2.           | 7          | D   | 010 |
|          | SBC A, (1X+0) |        |          | 011   | 101    |                                         | A+A-(1X+d)-CY                       |             |      | X            | •            | X              | v           | 1          |             | 5            | 19         | Ŀ   | 011 |
|          |               |        |          | 444   | 110    | 95                                      |                                     | 1           |      |              |              |                |             |            |             |              |            | , n | 100 |
|          | SBC A (TV+d)  | 1.00   | a        | 111   | 101    | а.<br>со                                |                                     | ·           |      | ÷            | <u>.</u>     | ·              |             | ÷          | · · · · ·   |              |            | L   | 101 |
|          | 30C A,(11+0)  | 110    |          | 111   | 110    |                                         | A-A-(11+0)-C1                       | Ţ.          |      | •            | 1            | : ^            | •           | 1          | Ţ           | 5            | 19         |     |     |
|          |               |        |          | 444   | ddd    | 95                                      |                                     |             |      | 1            |              | -              |             |            |             | 1            |            |     |     |
|          | AND C         | 1.1    |          | 100   |        | A0+c                                    | 060.0 0                             | · · · · ·   |      | ÷            |              | ŀ              |             |            |             |              |            | 1   |     |
| 1        |               |        |          | 100   | 110    | E C C C C C C C C C C C C C C C C C C C |                                     |             |      | ÷            | <del>.</del> | į              |             |            |             | ·            | 4          |     |     |
| l u      | AND II        |        |          | 100   | 110    | E0                                      | AFAXII                              | 1           | Ţ.   | : *          | 1            | : ^            | P           |            | U           | 2            | '          |     |     |
| _        |               | 1.     |          | 100   | 110    | ле<br>Л                                 |                                     | · [·        |      | ÷            |              | ŀ              |             |            |             |              | ···-;-     |     |     |
| U        |               |        |          | 100   | 101    |                                         |                                     | · [         |      | ÷.ô.         | <del>.</del> | <u>.</u>       |             |            |             |              |            |     |     |
| 0        |               | 1      | . ·      | 100   | 110    | 100                                     | A. ((1x+0)                          | 1           | Ť    | •            | 1            | : ^            |             |            |             | 5            | 19         |     |     |
| -        |               |        |          | 444   | 444    |                                         |                                     |             |      | 1            |              | ł              |             |            |             |              |            |     |     |
|          | AND (TV+d)    | 1.1    |          | 111   | 101    |                                         |                                     | · [·        |      | ÷            |              |                | <u>.</u>    |            |             | ····         |            |     |     |
| z        | AND (11+0)    |        |          | 100   | 110    | 10                                      | A-A/(11+0)                          | 1           |      | : ^          | . 1          | . ^            |             |            | U           | 0            | 19         |     |     |
| ∢        |               |        |          | 100   | 444    | 4                                       |                                     |             |      | 1            |              | -              |             |            |             |              |            |     |     |
|          | OR r          | 110    |          | 110   |        | B0+c                                    |                                     |             |      |              |              |                | n           |            |             |              |            |     |     |
| 2        |               |        |          | 110   | 110    | FR                                      |                                     |             |      | ÷.           |              |                | <u>P</u>    |            |             | <u>+</u> .   | 4          |     |     |
| F        |               |        |          |       | 110    |                                         | AFAVII                              | T.          |      |              |              | ^              | ۲ P         |            | U           | 2            | '          |     |     |
| ω        | 0.00 (11)     | 1      |          | 110   | 110    |                                         |                                     | · • • • • • |      | ÷            |              |                |             |            | · · · · · · | <u>.</u> .   | ····       |     |     |
| Σ        | OR (TY+d)     |        |          | 011   | 101    | 00                                      | $A + A \vee (\Pi L)$                | -h-[        |      | ·            |              | ·              | P           | 0          |             |              |            |     |     |
| т        | 0 (1          | 110    |          | 110   | 110    | B6                                      | h. ((1,10)                          |             |      | · ^          |              | ^              | P           | 0          | U           | 5            | 19         |     |     |
| -        |               |        |          | 444   | 110    | d                                       |                                     |             |      | 1            |              |                |             |            |             |              |            |     |     |
| ~        | OR (TY+d)     | 11     |          | 111   | 101    | FD                                      | $\Delta + \Delta \times / (TV + d)$ | ·   · · · · |      |              |              |                |             | •          |             |              |            |     |     |
| <        |               | 1      |          | 110   | 110    | RA                                      | A-AV(11+0)                          | 1           |      |              | U            |                | P           | U          | U           | 5            | 19         |     |     |
|          |               |        |          | 444   | 110    | d                                       |                                     |             |      |              |              |                |             |            |             |              |            |     |     |
| <b>⊢</b> | XOR c         | 1.0    |          | 101   |        | 1940                                    | A+0-40                              | · · · · · · |      | :            |              |                |             |            |             |              | ·          |     |     |
| -        | XOR n         |        |          | 101   | 110    | EE                                      |                                     | · []        |      | ÷.ô.         |              | : <del>.</del> | · · · · ·   |            |             | <u>+</u> .   |            |     |     |
| "        | Non II        |        |          |       | 110    |                                         | 1 A AVII                            | 1           | Ť    | : ^          |              | •              | ٢           |            |             | 2            | '          |     |     |
| ∞        |               | 1      |          | 101   |        | AC                                      |                                     | ·           |      | ÷            |              |                |             |            |             | <u>.</u> .   | <u>.</u> . |     |     |
| 1        | YOR (TY+d)    | 1.1    |          | 111   | 101    | DD                                      |                                     |             |      | ÷            |              | ÷              | · · · · ·   |            |             |              |            |     |     |
|          | X011 (1X14)   | 1      |          | 101   | 110    | 00<br>AE                                | N. N. (1.1.0)                       | 1           | Ť    | : ^          | U            | : ^            | P           | U          | 0           | 9            | 19         |     |     |
| 1        |               |        |          | 444   | 110    |                                         |                                     |             |      | 1            |              | 1              |             |            |             |              |            |     |     |
| 1        | XOR (TY+d)    | 11     |          | 111   | 101    | ED.                                     |                                     | · · · · · · |      | ÷            |              |                |             |            |             |              |            |     |     |
| 1        | , (11.4)      | 1      |          | 101   | 110    | AF                                      | A. AV(11.0)                         | 1           |      | : ^          |              | : ^            |             |            | Ů           | 5            | 19         |     |     |
| 1        |               | d      |          | hh    | ddd    | 4                                       |                                     |             |      | 1            |              | 1              |             |            |             |              |            |     |     |
|          | CP r          | 11     |          | 111   |        | 88+r                                    | A-r                                 | ······      |      | ÷            |              |                | · · · · · · | ·          |             |              |            |     |     |
| 1        |               | 11     | <u></u>  | 111   | 110    | FE                                      | A-n                                 |             |      | ÷            |              | į              | · · · · ·   | ÷          |             | <u>+</u> .   |            |     |     |
|          |               | 1.     |          |       | 110    |                                         |                                     | 1           | Ť    | : ^          |              | : ^            | •           | 1          |             | 2            | 1          |     |     |
|          | CP (HL)       | 1      |          | 111   | 110    |                                         | A_(H1)                              | ·  ·····    | •••• | ÷            |              | ŀ              | · ·         | · · · · ·  | ·····       | ····         | ····       |     |     |
|          |               | 1.1    | :<br>1 ( | 111   | 101    |                                         | $A_{-}(TX_{+d})$                    | ·           |      | ÷            | ÷            | į              | · · · · · · | . <u>.</u> |             |              |            |     |     |
|          |               | 110    | <br>     | 111   | 110    | BE                                      | A-(1X+0)                            | 1           |      | : ^          | 1            | : ^            | •           | 1          |             | 5            | 19         |     |     |
|          |               |        | 4 4      | 444   | 444    | 4                                       |                                     |             |      |              |              |                |             |            |             |              |            |     |     |
|          | CP (TV+d)     | 111    | <u>.</u> | 111   | 101    | ED.                                     | A-(TV+d)                            | ··[·····    |      | ÷            |              |                |             |            |             |              | 10         |     |     |
|          | . (11.0)      | 1      | • •      | 111   | 110    | RE                                      |                                     | 1           | Ť    | . ^          |              | . ^            | · ·         | 1          | Ŧ           | °            | 1.9        | l   |     |
| 1        |               |        |          | 444   | 444    |                                         |                                     |             |      |              |              |                |             |            |             |              |            |     |     |
|          |               | 1.00   |          | rrr   | 100    | 04+r × 8                                | r+r+1                               | ·····       |      | v            | ••••         |                | ·····       |            |             | ·····        | ···        |     |     |
|          | INC (HL)      | 100    | !<br>1   | 110   | 100    | 34                                      | (HL)+(HL)+1                         | ··  · ···   |      | ÷            |              | :^<br>: v      | · · · · ·   | <br>       |             | <del>:</del> |            | 1   |     |
|          |               | 1      | 1        | n 1 1 | 101    |                                         | (TX+d)+(TX+d)+1                     | ·   · ] ·   |      | ÷.^.         |              | ·              | : <b>*</b>  | ÷          |             | ···.»        |            | 1   |     |
|          |               | 1      | - ·      | 110   | 100    | 34                                      | (20.0) (20.0) (2                    | 1           | Ċ    | · ^          |              | : ^            | •           | ۲,         |             | 0            | 23         |     |     |
| 1        |               |        |          | ddd   | ddd    | d                                       |                                     |             |      | 1            |              | :              |             |            |             |              |            |     |     |

Note : r means any of the registers A, B, C, D, E, H, L.

# TMPZ84C013A Instruction Set (5/9)

| ITEM/      | Assembler  | Object     | code             |                            |          |    |      | F     | ag            |     |   |       | No.         | No.      |       |
|------------|------------|------------|------------------|----------------------------|----------|----|------|-------|---------------|-----|---|-------|-------------|----------|-------|
| -FICA-     | mnemonic   | Binary     | Hex              | Function                   |          |    |      |       |               |     |   |       | CY-         | STA-     |       |
| TION       |            | 76 543 210 |                  |                            | s        | Z  |      | н     |               | P/V | Ν | с     | CLES        | TES      |       |
| U          | INC (IY+d) | 11 111 101 | FD               | (IY+d)←(IY+d)+1            | ٠        | ٠  | Х    | *     | х             | ٧   | 0 | -     | 6           | 23       |       |
| Ē          |            | 00 110 100 | 34               |                            |          |    |      |       |               |     |   |       |             |          |       |
| Σ          | DEC        |            | d<br>05+py 9     | nt n - 1                   | ·····    |    |      |       | · · · · ·     |     |   |       |             |          |       |
| L L        | DEC (HL)   | 00 110 101 | 35               | $(HI) \leftarrow (HI) = 1$ | ·        |    | Ŷ    |       | <u>^</u><br>¥ |     | 1 |       |             |          | B 000 |
| - J        | DEC (IX+d) | 11 011 101 |                  | (IX+d)+(IX+d)-1            | *        | *  | x    | *     | <u>^</u>      | v   | 1 |       |             | 23       | C 001 |
| A B<br>G R | . ,        | 00 110 101 | 35               |                            |          |    |      |       |               |     |   |       |             |          | D 010 |
| _ °        |            | dd ddd ddd | d                |                            |          |    |      |       |               |     |   |       |             |          | E 011 |
|            | DEC (IY+d) | 11 111 101 | FD               | (IY+d)←(IY+d)-1            | *        | ٠  | Х    | *     | Х             | ٧   | 1 | -     | 6           | 23       | H 100 |
| - Z        |            | 00 110 101 | 35               |                            |          |    |      |       |               |     |   |       |             |          | L 101 |
| ∞∢         |            | dd ddd ddd | d                |                            |          |    |      |       |               |     |   |       |             |          | A 111 |
| 5          | DAA        | 00 100 111 | 27               | Decimal adjust accumulator |          |    | Х.   |       | . <u>X</u>    | P   |   | ••••• | 1           | 4        |       |
| L H        | LPL NEC    | 11 101 101 | 1 2 F            |                            | <u>.</u> |    | . X. | .1    | . <u>X</u>    |     | 1 |       | 1           | 4        |       |
| Z          | NEG        | 01 000 100 | 44               |                            | Ť        | Ţ. |      |       | ^             | v   | 1 |       | 2           | 8        |       |
| Ŭ          | CCF        | 00 111 111 | 3F               | CY+ <del>CY</del>          | ·····    |    | ¥    | ¥     | <br>¥         | _   | 0 |       | 1           | <u>A</u> |       |
| ⊃          | SCF        | 00 110 111 | 37               | CY←1                       |          | -  | x    | 0     | . <u>^</u>    | -   | 0 |       | ···.^.<br>1 | 7.       |       |
| Ξ          | NOP        | 00 000 000 | 00               | no operation               | -        | _  | X    | _     | Х             | -   | - | _     |             | 4        |       |
| sο         | HALT       | 01 110 110 | 76               | MPU Halted                 | -        |    | Х    | -     | X             | -   | - | -     | 1           | 4        |       |
| ΡD         | DI         | 11 110 011 | F3               | IFF←O                      | -        | -  | х    | -     | х             | -   | - | -     | 1           | 4        |       |
| μΩυ        | EI         | 11 111 011 | FB               | IFF+1                      |          | -  | X    | -     | . X           | -   | - | -     | 1           | . 4      |       |
| 4 -        | IM O       | 11 101 101 | ED               | Set interrupt mode 0       | -        | -  | х    | -     | х             | -   | - | -     | 2           | 8        |       |
| ш Ц<br>2 5 |            | 01 000 110 | 46               |                            |          |    | }    |       |               |     |   |       |             |          |       |
| ΞĒ         | IM 1       | 11 101 101 | ED               | Set interrupt mode 1       | -        | -  | X    | -     | X             | -   | - | -     | 2           | 8        |       |
| z          | TM 2       | 11 101 101 | 50               | Sot interrupt mode 2       | ·····    |    |      | ••••• | ·             |     |   |       |             |          |       |
| υĀ         | 1m 2       | 01 011 110 | 56               | Set interrupt mode 2       | -        | _  | ^    | -     | ^             | _   |   |       | ۲           | °        |       |
|            | ADD HL.t   | 00 tt1 001 | 09+t×10          | HL+HL+t                    | -        | _  | x    | X     | Х             | _   | 0 | *     | 3           | 11       | ttt   |
|            | ADC HL,t   | 11 101 101 | ED               | HL←HL+t+CY                 | *        | *  | X    | X     | X             | v   | 0 | *     | 4           | 15       | BC 00 |
|            |            | 01 tt1 010 | 4A+t×10          |                            |          |    |      |       |               |     |   |       |             |          | DE 01 |
| U<br>      | SBC HL,t   | 11 101 101 | ED               | HL←HL-t-CY                 | ٠        | ٠  | Х    | Х     | Х             | ٧   | 1 | *     | 4           | 15       | HL 10 |
| H          |            | 01 tt0 010 | 42+t×10          |                            |          |    |      |       |               |     |   |       |             |          | SP 11 |
| Σ          | ADD IX,p   | 11 011 101 | DD               | IX←IX+p                    | -        | -  | Х    | X     | Х             | -   | 0 | *     | 4           | 15       |       |
| т          |            | 00 pp1 001 | 09+p × 10        |                            |          |    |      |       |               |     |   |       |             |          | p pp  |
| -          | ADU IY,S   | 11 111 101 | FU               | IY+IY+s                    | -        | -  | X    | X     | X             | -   | 0 | •     | 4           | 15       | BC 00 |
| A          | INC +      | 00 551 001 | $03+5 \times 10$ |                            |          |    |      |       | v             |     |   |       | 1           |          |       |
| L          | INC TX     | 11 011 101 |                  | TX+TX+1                    |          |    | Ŷ    |       | ·             |     |   |       | <u>h</u> .  | 10       | SP 11 |
| -          |            | 00 100 011 | 23               |                            |          |    | , î  |       | Ŷ             |     |   |       |             |          |       |
| 8          | INC IY     | 11 111 101 | FD               | IY←IY+1                    | _        | _  | x    | _     | x             | -   | - | -     | 2           | 10       | S SS  |
| 9          |            | 00 100 011 | 23               |                            |          |    |      |       |               |     |   |       |             |          | BC 00 |
|            | DEC t      | 00 tt1 011 | 0B+t×10          | t+t-1                      | -        | -  | Х    | -     | Х             | -   | - | -     | 1           | 6        | DE 01 |
|            | DEC IX     | 11 011 101 | DD               | IX←IX-1                    | -        | -  | Х    | -     | Х             | -   | - | -     | 2           | 10       | IY 10 |
|            |            | 00 101 011 | 2B               |                            |          |    |      |       |               |     |   |       |             |          | SP 11 |
|            | DEC IY     | 11 111 101 | FD               | IY←IY-1                    | -        |    | х    |       | х             | -   |   | -     | 2           | 10       |       |
|            |            | 00 101 011 | 28               |                            |          |    |      |       |               |     |   |       |             |          |       |
| ROTATE     | RLCA       | 00 000 111 | 07               | CY ← 7 ← 0 ←<br>A          | -        | -  | x    | 0     | x             |     | 0 | ٠     | 1           | 4        |       |

Note : ss is any of the register pairs BC, DE, HL, SP. PP is any of the register pairs BC, DE, IX, SP. rr is any of the register pairs BC, DE, IY, SP.

# TMPZ84C013A Instruction Set (6/9)

| ITEM/<br>CLASSI | Assembler   | Object                                                                           | code                | Eurotion                                                                                                                                                 |   |   |          | Fi | lag      |     |   |   | No.<br>OF   | No.<br>OF   |                         |
|-----------------|-------------|----------------------------------------------------------------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|----------|----|----------|-----|---|---|-------------|-------------|-------------------------|
| -FICA-<br>TION  | mnemonic    | Binary<br>76 543 210                                                             | Hex                 | Function                                                                                                                                                 | s | z |          | Н  |          | P/V | N | Ċ | CY.<br>CLES | STA-<br>TES |                         |
|                 | RLA         | 00 010 111                                                                       | 17                  |                                                                                                                                                          | - | - | x        | 0  | x        | -   | 0 | * | 1           | 4           |                         |
|                 | RRCA        | 00 001 111                                                                       | OF                  | $\begin{array}{c} \hline \hline 7 \rightarrow 0 \\ \hline A \end{array} \begin{array}{c} \hline CY \\ \hline \end{array}$                                |   | - | x        | 0  | x        | -   | 0 | * | 1           | 4           |                         |
|                 | RRA         | 00 011 111                                                                       | 1F                  | $ \begin{array}{c} \hline  | - | - | x        | 0  | x        | -   | 0 | * | 1           | 4           |                         |
|                 | RLC r       | 11 001 011                                                                       | CB                  |                                                                                                                                                          | * | * | х        | 0  | х        | Р   | 0 | • | 2           | 8           | 7777 7<br>8 000         |
|                 | RLC (HL)    | 11 001 011                                                                       | CB                  |                                                                                                                                                          | • | * | x        | 0  | x        | Р   | 0 | * | 4           | 15          | C 001                   |
| F               | RLC (IX+d)  | 00 000 110<br>11 011 101<br>11 001 011                                           | DD<br>CB            | $CY \leftarrow 7 \leftarrow 0 \leftarrow$                                                                                                                | * | * | x        | 0  | X        | Р   | 0 | * | 6           | 23          | D 010<br>E 011<br>H 100 |
| ш<br><br>Н      | BLC (IY+d)  |                                                                                  | 06<br>FD            | r,(nc),(18+0),(11+0)                                                                                                                                     |   | • | Y        |    | Y        | D   | 0 | • |             | 22          | A 111                   |
| л<br>П          |             | 11 001 011 Cf<br>dd ddd ddd d<br>00 000 110 00<br>11 001 011 Cf<br>00 010 rrr 10 | CB<br>d<br>06       |                                                                                                                                                          |   |   | ^        | U  | Ŷ        | r   | 0 |   |             | 23          |                         |
| 4               | RL r        | 11 001 011                                                                       | СВ                  |                                                                                                                                                          | * | * | x        | 0  | х        | Р   | 0 | * | 2           | 8           |                         |
| L O H           | <pre></pre> | 11 001 011                                                                       | CB                  |                                                                                                                                                          | * | • | x        | 0  | <br>X    | Р   | 0 | • | 4           | 15          |                         |
|                 |             | 11 011 101<br>11 001 011<br>dd ddd ddd                                           | DD<br>CB<br>d       | $\begin{array}{c} \hline CY \leftarrow 7 \leftarrow 0 \\ \hline r, (HL), (IX+d), (IY+d) \end{array}$                                                     | * | * | x        | 0  | x        | р   | 0 | * | 6           | 23          |                         |
|                 | RL (IY+d)   | 00 010 110<br>11 111 101<br>11 001 011<br>dd ddd ddd                             | 16<br>FD<br>CB<br>d |                                                                                                                                                          | * | * | x        | 0  | x        | Р   | 0 | * | 6           | 23          |                         |
|                 | RRC r       | 00 010 110                                                                       | 16<br>CB            |                                                                                                                                                          |   | * | <br>X    | 0  | <br>X    | P   | 0 | * | 2           | 8           |                         |
|                 | RRC (HL)    | 00 001 rrr                                                                       | 08+r                |                                                                                                                                                          |   |   |          |    |          |     |   |   |             |             |                         |
|                 |             | 00 001 110                                                                       | OE                  |                                                                                                                                                          |   |   | <b>^</b> |    |          | , P |   |   |             |             |                         |
|                 | RRC (IX+d)  | 11 011 101<br>11 001 011<br>dd ddd ddd                                           | DD<br>CB<br>d       | $ \begin{array}{c} \Gamma_{\mathcal{T}} \xrightarrow{\Gamma} O \xrightarrow{\Gamma} CY \\ \Gamma_{\mathcal{T}}(HL), (IX+d), (IY+d) \end{array} $         | * | * | X        | 0  | Х        | р   | 0 | * | 6           | 23          |                         |
|                 | RRC (IY+d)  | 11 111 101<br>11 001 011<br>dd ddd ddd                                           | FD<br>CB<br>d       |                                                                                                                                                          | • | * | x        | 0  | x        | Р   | 0 | * | 6           | 23          |                         |
|                 | ≀R r        | 00 001 110                                                                       | OE<br>CB            |                                                                                                                                                          | • | * | x        |    | <br>X    | Р   | 0 | • | 2           | 8           |                         |
|                 | BR (HI)     | 00 011 rrr                                                                       | 18+r                |                                                                                                                                                          |   |   |          |    | <u>.</u> |     |   |   | ļ,          | 15          |                         |
|                 | RR (HL)     | 00 011 110                                                                       | 1E                  | $\rightarrow$ 7 $\rightarrow$ 0 $\rightarrow$ CY                                                                                                         |   |   |          |    |          | . Р | U |   | 4           | 15          |                         |
|                 | RR (IX+d)   | 11 011 101<br>11 001 011<br>dd ddd ddd<br>00 011 110                             | DD<br>CB<br>d<br>1E | r,(HL),(IX+d)                                                                                                                                            | * | * | x        | 0  | x        | Р   | 0 | * | 6           | 23          |                         |

Note : r means any of the registers A, B, C, D, E, H, L.

# TMPZ84C013A Instruction Set (7/9)

| ITEM/<br>CLASSI      | Assembler      | Object                                               | code                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |   |   |   | F | ag |     |   |   | No.<br>OF   | No.<br>Of   |                         |
|----------------------|----------------|------------------------------------------------------|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|---|----|-----|---|---|-------------|-------------|-------------------------|
| -FICA-<br>TION       | mnemonic       | 76 543 210                                           | nex                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | S | z |   | н |    | P/V | N | с | CY-<br>CLES | S1A-<br>TES |                         |
|                      | RR (IY+d)      | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d       | $\begin{array}{c} \hline \begin{array}{c} & & \\ \hline \end{array} \\ \hline \\ \\ \hline \end{array} \\ \\ \hline \end{array} \\ \\ \hline \end{array} \\ \hline \end{array} \\ \hline \end{array} \\ \hline \\ \\ \hline \end{array} \\ \\ \hline \end{array} \\ \hline \\ \\ \hline \end{array} \\ \\ \\ \hline \end{array} \\ \\ \hline \end{array} \\ \\ \\ \\$ | ٠ | ٠ | х | 0 | x  | Р   | 0 | * | 6           | 23          |                         |
| ļ                    | SLA r          | 00 011 110<br>11 001 011<br>00 100 rrr               | 1E<br>CB<br>20+r    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | X | 0 | x  | Р   | 0 | * | 2           | 8           | r rrr<br>B 000          |
|                      | SLA (HL)       | 11 001 011                                           | CB<br>26            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | Х | 0 | х  | Р   | 0 | ٠ | 4           | 15          | C 001                   |
|                      | SLA (IX+d)     | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d       | $\begin{array}{c c} CY \leftarrow 7 \leftarrow 0 \\ \hline r, (HL), (IX+d), (IY+d) \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | Х | 0 | X  | Ρ   | 0 | * | 6           | 23          | E 011<br>H 100<br>L 101 |
|                      | SLA (IY+d)     | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | X | 0 | x  | р   | 0 | * | 6           | 23          | <u> </u>                |
| н<br>Н               | SRA r          | 00 100 110<br>11 001 011                             | 26<br>CB<br>28+c    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | x | 0 | x  | Р   | 0 | * | 2           | 8           |                         |
| н                    | SRA (HL)       | 11 001 011<br>00 101 110                             | CB                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | X | 0 | x  | Р   | 0 | * | 4           | 15          |                         |
| ATE                  | SRA (IX+d)     | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d       | $7 \rightarrow 0 \rightarrow CY$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | * | * | x | 0 | x  | P   | 0 | * | 6           | 23          |                         |
| ROT                  | SRA (IY+d)     | 00 101 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 2E<br>FD<br>CB<br>d | r,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | * | * | x | 0 | x  | Р   | 0 | * | 6           | 23          |                         |
|                      | SRL r          | 00 101 110<br>11 001 011                             | 2E<br>CB            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | x | 0 | x  | Р   | 0 | * | 2           | 8           |                         |
|                      | SRL (HL)       | 11 001 011<br>11 001 011                             | CB                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | * | * | x | 0 | x  | Р   | 0 | * | 4           | 15          |                         |
|                      | SRL (IX+d)     | 00 111 110<br>11 011 101<br>11 001 011<br>dd ddd ddd | DD<br>CB<br>d       | $0 \longrightarrow 7 \rightarrow 0 \longrightarrow CY$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | * | * | X | 0 | x  | Р   | 0 | * | 6           | 23          |                         |
|                      | SRL (IY+d)     | 00 111 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 3E<br>FD<br>CB<br>d | г,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | * | * | x | 0 | Х  | Ρ   | 0 | * | 6           | 23          |                         |
|                      | RLD            | 11 101 101<br>01 101 111                             | ED<br>6F            | A 7 43 0 7 43 0 (HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | * | * | x | 0 | X  | Р   | 0 | - | 5           | 18          | *1                      |
|                      | RRD            | 11 101 101<br>01 100 111                             | ED<br>67            | A 7 43 0 7 43 0 (HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | * | ٠ | X | 0 | x  | Р   | 0 | - | 5           | 18          | *1                      |
| EST                  | BIT b,r        | 11 001 011<br>01 bbb see                             | CB                  | 74-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Х | * | х | 1 | x  | X   | 0 | - | 2           | 8           | 0 000                   |
| IT SET<br>ESET AND T | BIT b,(HL)     | 11 001 011<br>01 bbb 110                             | CB<br>46+b×8        | Z+(HL)b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | x | * | x | 1 | x  | x   | 0 | 1 | 3           | 12          | 2 010<br>3 011<br>4 100 |
| 8 2                  | Note : *1: Rot | ate digit left and                                   | right between t     | the accmulator and location (HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |   |   |    |     |   |   |             |             | 6 110<br>7 111          |

Note : \*1: Rotate digit left and right between the accmulator and location (HL). The content of the upper half of the accumulator is unaffected.

The notation (HL)<sub>b</sub> indicates bit  $_b$  (0 to 7) within the contents of the HL register pair. The notation  $r_b$  indicates bit  $_b$  (0 to 7) within the r register.

### TMPZ84C013A Instruction Set (8/9)

| ITEM/<br>CLASSI                                                                                                                                                                                                    | Assembler                                    | Object                                               | code                         | Function                                            |       |       |        | F | ag     |     |   |   | No.<br>OF   | Nò.<br>OF        |                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|------------------------------------------------------|------------------------------|-----------------------------------------------------|-------|-------|--------|---|--------|-----|---|---|-------------|------------------|--------------------------------------------|
| -FICA-<br>TION                                                                                                                                                                                                     | mnemonic                                     | 76 543 210                                           | nex                          | , unction                                           | s     | z     |        | н |        | P/V | N | с | CY-<br>CLES | STA-<br>TES      |                                            |
|                                                                                                                                                                                                                    | BI⊤ b,(IX+d)                                 | 11 011 101<br>11 001 011                             | DD<br>CB                     | Z←(IX+d)b                                           | x     | *     | x      | 1 | х      | x   | 0 | - | 5           | 20               |                                            |
|                                                                                                                                                                                                                    | BIT b,(IY+d)                                 | dd ddd ddd<br>01 bbb 110<br>11 111 101               | d<br>46+b×8<br>FD            | 7, ( TV, J).                                        | <br>X | *     | x      | 1 | <br>X  | x   | 0 | - | 5           | 20               |                                            |
| E S T                                                                                                                                                                                                              |                                              | dd ddd ddd<br>01 bbb 110                             | d<br>46+b×8                  | 2~(11+0)b                                           |       |       |        |   |        |     |   |   |             |                  |                                            |
|                                                                                                                                                                                                                    | SET b,r                                      | 11 001 011<br>11 bbb rrr                             | CB<br>CO+b×8+r               | rb←1                                                | -     | -     | х      | - | х      | -   | - | - | 2           | 8                | <u>r rrr</u><br>B 000                      |
| A N                                                                                                                                                                                                                | SET b,(HL)                                   | 11 001 011<br>11 bbb 110                             | CB<br>C6+b×8                 | (HL) <sub>b</sub> ←1                                | ~     | -     | х      | - | Х      | -   | - | - | 4           | 15               | C 001<br>D 010                             |
| SET                                                                                                                                                                                                                | SET b,(IX+d)                                 | 11 011 101<br>11 001 011<br>dd ddd ddd<br>11 bbb 110 | DD<br>CB<br>d                | (IX+d) <u>b</u> +1                                  | -     | -     | Х      | - | Х      | -   | - | - | 6           | 23               | E 011<br>H 100<br>L 101<br>A 111           |
| ET RE                                                                                                                                                                                                              | SET b,(IY+d)                                 | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d                | (IY+d)b←1                                           | -     | -     | x      | - | x      | -   | - | - | 6           | 23               | b bbb<br>0 000                             |
| S                                                                                                                                                                                                                  | RES b,r                                      | 11 001 011                                           | CB                           | rb←0                                                | -     | -     | x      | - | x      | -   | - | - | 2           | 8                | 2 010                                      |
| - 8                                                                                                                                                                                                                | RES b,(HL)                                   | 11 001 011<br>10 bbb 110                             | CB<br>86+5 x 8               | (HL) <b>b</b> ←0                                    | -     | -     | x      | - | x      | -   | - | - | 4           | 15               | 4 100                                      |
|                                                                                                                                                                                                                    | RES b,(IX+d)                                 | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d                | (IX+d)b←0                                           | -     | -     | x      | - | x      | -   | - | - | 6           | 23               | 6 110<br>7 111                             |
|                                                                                                                                                                                                                    | RES b,(IY+d)                                 | 10 bbb 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 86+b × 8<br>FD<br>CB<br>d    | (IY+d)b+0                                           | -     | -     | x      | - | x      | -   | - | - | 6           | 23               |                                            |
| <br>                                                                                                                                                                                                               | JP mn                                        | 10 000 011<br>11 000 011<br>nn nnn nnn               | C3<br>n                      | PC←mn                                               | -     | -     | x      | - | x      | -   | - | - | 3           | 10               |                                            |
|                                                                                                                                                                                                                    | JP c,mn                                      | nn nnn nnn<br>nn nnn nnn<br>mm mmm mmm               | n<br>m                       | PC←mn<br>(Only when condition is met)               | -     | -     | x      | - | X      | -   | - | - | 3           | 10               | extension in the<br>relative<br>addressing |
|                                                                                                                                                                                                                    | JR \$+e                                      | 00 011 000<br>aa aaa aaa                             | 18<br>a                      | PC←\$+e                                             | -     | -     | х      | - | x      | -   | - | - | 3           | 12               | mode, a = e – 2.<br>e is a signed          |
| ×<br>∩                                                                                                                                                                                                             | JR C,\$+e                                    | 00 111 000<br>aa aaa aaa                             | 38<br>a                      | If C=0, continue<br>If C=1, PC+\$+e                 | -     | -     | X<br>X | - | X<br>X | -   | - | - | 2           | 7                | two's<br>complement                        |
|                                                                                                                                                                                                                    | JR NC,\$+e                                   | 00 110 000<br>aa aaa aaa                             | 30<br>a                      | If C=0, PC+\$+e<br>If C≈1, continue                 |       | -     | X      | - | X      | -   | - | - | 3           | 12               | number in the                              |
|                                                                                                                                                                                                                    | JR Z,\$+e                                    | 00 101 000                                           | 28<br>a                      | If Z=0, continue                                    |       |       | X      | - | X      | -   |   | - | . 2         | 7                | - 126≦ e ≦ 129                             |
|                                                                                                                                                                                                                    | JR NZ,\$+e                                   | 00 100 000                                           | 20<br>a                      | If Z=0, PC+\$+e                                     |       |       | X      |   | X      | -   | - | - | 3           | 12               |                                            |
|                                                                                                                                                                                                                    | DJNZ \$+e                                    | 00 010 000<br>aa aaa aaa                             | 10<br>a                      | B←B−1, If B=0, continue<br>B←B−1, If B<>0, continue |       |       | X      |   | X      | -   | - | - | 2           | 8<br>13          |                                            |
|                                                                                                                                                                                                                    | JP (HL)                                      | 11_101_001                                           | E9                           | PC←HL                                               | -     | -     | X      | - | X      | _   | - | - | 1           | 4                | 1                                          |
| Note : • $a = e - 2$ in the Opcode provides an effective address of PC + e as PC is incremented by 2 before the addition of e.<br>• Sindicates the reference to the location counter value of the current company. |                                              |                                                      |                              |                                                     |       |       |        |   |        |     |   |   | Z 00        | 00 Non-Zero      |                                            |
|                                                                                                                                                                                                                    | <ul> <li>The not</li> <li>The not</li> </ul> | ation (HL) <sub>b</sub> , (IX + d                    | ) <sub>b</sub> indicates bit | , (0 to 7) within the contents of the r             | egist | ter p | air.   |   |        |     |   |   | N           | 2   00<br>C   01 | 1 Zero<br>10 No-carry                      |
|                                                                                                                                                                                                                    |                                              |                                                      |                              |                                                     |       |       |        |   |        |     |   |   |             | ւլսյ             | LI Carry                                   |

• a = e-2 in the op-code provides effective address of PC + e as PC is incremented by 2 prior to the addition of e.

PO 100 Odd Parity PE 101 Even Parity P 110 Sign Positive

M 111 Sign Negative

270489

# TMPZ84C013A Instruction Set (9/9)

| ITEM/       | Assembler | Object                   | code     |                                     |          |                 |          | F        | ag           |          |           |          | No.<br>OF | No.<br>Of |                |                |    |
|-------------|-----------|--------------------------|----------|-------------------------------------|----------|-----------------|----------|----------|--------------|----------|-----------|----------|-----------|-----------|----------------|----------------|----|
| -FICA-      | mnemonic  | Binary                   | Hex      | Function                            | ļ        |                 |          |          |              |          |           |          | CY-       | STA-      |                |                |    |
| TION        |           | 76 543 210               |          |                                     | s        | z               |          | н        |              | P/V      | N         | с        | CLES      | TES       |                |                |    |
| ۹<br>۲      | JP (IX)   | 11 011 101<br>11 101 001 | DD<br>E9 | PC+(IX)                             | -        | -               | Х        | -        | х            | -        | -         | -        | 2         | 8         |                |                |    |
| ⇒           | JP (IY)   | 11 111 101               | FD       | PC←(IY)                             |          | -               | x        | -        | х            | -        | -         | -        | 2         | 8         |                |                |    |
| ~           |           | 11 101 001               | E9       |                                     |          |                 |          |          |              | -        |           |          |           |           |                |                |    |
|             | CALL mn   | 11 001 101               | CD       | (SP-1)+PCH,(SP-2)+PCL               | -        | -               | X        | -        | Х            | -        | -         | -        | 5         | 17        | j              | kkk            |    |
| z           |           | nn nnn nnn               | n        | PC←mn                               |          | -               |          |          |              | 1        | 1         |          |           |           | 001            | 1 000          |    |
| ∝           |           |                          | m        | SP+SP-2                             |          | i               | <u>.</u> | <u>.</u> |              | <u>.</u> | <u>.</u>  | <u>.</u> |           |           | 08H            | 1 001          |    |
|             | CALL c,mn | 11 ccc 100               | C4+cX8   | If condition c is met, same as      | -        | -               | Х        | -        | Х            | -        | -         | -        | 5         | 17        | 10             | 1 010          |    |
| ш           |           | որ որը որը               | n        | CALL mn.                            |          |                 |          | <u>.</u> |              | <u>.</u> | <u>.</u>  | <u>.</u> |           |           | 18             | 1 011          |    |
| ~           |           | mm mmm mmm               | m        | If condition c is not met, continue |          | i. <del>.</del> | X        |          | X            | <u>.</u> | <u>i.</u> | <u> </u> | 3         | 10        | 201            | 1 100          |    |
| 0           | RET       | 11 001 001               | C9       | PCL←(SP), PCH←(SP+1)<br>SP←SP+2     | -        | -               | х        | -        | х            | -        | -         | -        | 3         | 10        | 28H<br>30H     | + 101<br>+ 110 |    |
| z           | RET C     | 11 ccc 000               | C0+c×8   | If condition c is met, same as RET. | -        | - 1             | x        |          | х            | -        |           | -        | 3         | 11        | 381            | 1 111          |    |
| < <         |           |                          |          | If condition c is not met.continue  |          |                 | x        |          | x            | ····-    | 1         |          | 1         |           |                |                |    |
|             | RETI      | 11 101 101               | ED       | Return from interrupt Processing    |          |                 | x        | _        | x            |          | <u> </u>  | _        | 4         | 14        | r              | 111            |    |
|             |           | 01 001 101               | 4D       | routine                             |          | 1               | , î      |          | ñ            | 1        | 1         |          | [ `       |           | В              | 000            |    |
| ∢           | RETN      | 11 101 101               | ED       | Return from non-maskable            | -        | !·              | x        | -        | x            | -        | - T       | -        | 4         | 14        | с              | 001            |    |
| U           |           | 01 000 101               | 45       | interrupt Processing routine        |          | 1               |          |          | <sup>°</sup> | 1        | 1         | -        | [ ·       |           | D              | 010            |    |
|             | RST i     | 11 kkk 111               | C7+k × 8 | (SP-1)+PCµ.(SP-2)+PCI               |          | 1.2             | x        | -        | x            | <u>.</u> | ÷         |          | 3         | 11        | E              | 011            |    |
| 1           |           |                          |          | PCH+0,PCI+1,SP+SP-2                 |          | 1               |          |          |              | :        | 1         | -        | ſ         |           | н              | 100            |    |
|             | IN A,(n)  | 11 011 011               | DB       | A+(n)                               | -        | -               | X        | -        | Х            | -        | -         | -        | 3         | 11        | L              | 101            |    |
|             |           | nn nnn nnn               | n        | n→A0~A7,A→A8~A15                    |          | 1               |          |          |              | 1        | 1         |          |           |           | A              | 111            |    |
| 1           | IN r,(C)  | 11 101 101               | ED       | r←(C) If r=110, only the flags      | *        | *               | x        | *        | x            | Р        | 0         | -        | 3         | 12        |                |                | 1  |
|             |           | 01 rrr 000               | 40+rx8   | will be affected.                   | ĺ        |                 |          |          |              |          |           |          |           |           |                |                |    |
|             | INI       | 11 101 101               | ED       | (HL)←(C),B←B-1,HL←HL+1              | X        | *M              | x        | х        | Х            | X        | 1         | X        | 4         | 16        |                |                |    |
| 1           |           | 10 100 010               | A2       |                                     |          |                 |          |          |              |          |           |          | í í       |           |                |                |    |
| 12          | INIR      | 11 101 101               | ED       | (HL)+(C),B+B-1,HL+HL+1              | X        | 1               | X        | х        | Х            | X        | 1         | X        | 5         | 21        | ÷ГВ            | <>01           |    |
| <b>&gt;</b> |           | 10 110 010               | B2       | Repeat until B=0                    |          | 1               |          |          |              | 1        | 1         |          | 4         | 16        | ÷ГВ            | =01            | +1 |
| 0           | IND       | 11 101 101               | ED       | (HL)←(C),B←B-1,HL←HL-1              | X        | *м              | X        | Х        | Х            | X        | 1         | X        | 4         | 16        |                | -              |    |
|             |           | 10 101 010               | AA       |                                     |          |                 |          |          |              |          |           |          |           |           |                |                | 1  |
|             | INDR      | 11 101 101               | ED       | (HL)+(C),B+B-1,HL+HL-1              | X        | 1               | x        | х        | Х            | X        | 1         | X        | 5         | 21        | +[B            | <>0]           |    |
| _ <         |           | 10 111 010               | ВА       | Repeat until B=0                    |          | 1               |          |          |              | -        | 1         | -        | 4         | 16        | ←[B            | =0]            |    |
|             | OUT (n),A | 11 010 011               | D3       | (n)←A                               |          | -               | x        | -        | Х            | -        | - 1       | -        | 3         | 11        | _              |                | 1  |
| ⊢ ⊢         |           | nn nnn nnn               | n        | n→A0~A7,A→A8~A15                    |          |                 |          |          |              |          |           |          |           |           |                |                |    |
| 2           | OUT (C),r | 11 101 101               | ED       | (C)←r                               | -        |                 | X        | -        | x            | -        | - 1       | -        | 3         | 12        |                |                | 1  |
|             |           | 01 rrr 001               | 41+rX8   |                                     |          | 1               |          |          |              |          | 1         | -        |           |           |                |                |    |
| -           | OUTI      | 11 101 101               | ED       | (C)←(HL),B←B-1,HL←HL+1              | X        | *M              | x        | х        | X            | X        | 1         | x        | 4         | 16        |                |                |    |
| [           |           | 10 100 011               | A3       |                                     |          | : "             |          |          |              |          | 1         |          |           |           |                |                |    |
|             | OTIR      | 11 101 101               | ED       | (C)←(HL),B+B-1,HL+HL+1              | x        | 1               | X        | х        | x            | X        | 1         | x        | 5         | 21        | +B[            | <>0]           |    |
|             |           | 10 110 011               | B3       | Repeat until B=0                    |          | -               |          |          |              |          |           |          | 4         | 16        | +[B            | =0]            | *1 |
|             | OUTD      | 11 101 101               | ED       | (C)+(HL),B+B-1,HL+HL-1              | x        | *               | x        | x        | x            | x        | 1         | x        | 4         | 16        | 1 <sup>-</sup> | -              |    |
| I           |           | 10 101 011               | AB       |                                     |          | . 11            |          | 'n       | ~            |          | 1         | , î      | · ·       | 1.        |                |                |    |
|             | OTDR      | 11 101 101               | ED       | (C)←(HL),B←B-1,HL←HL-1              | x        | 1               | x        | х        | х            | x        | 1         | x        | 5         | 21        | ¢ГВ            | <>01           |    |
|             |           | 10 111 010               | вв       | Repeat until B=0                    | <u> </u> | 1               |          |          |              | 1        | -         |          | 4         | 16        | ÷ΓΒ            | =01            |    |
|             |           |                          |          |                                     |          |                 |          |          |              |          |           |          |           | <u> </u>  |                |                | ,  |

Note : • \*M If the result of B - 1 is zero, the Z flag is set, otherwise it is reset.

A0 through A15 indicate the address bus.

• [ ] indicates the total condition of the number of cycles and states indicated by arrow.



P 110 Sign Positive

M 111 Sign negative

# TMPZ84C013A Instruction Map (1/7)

|     |               |               |               |               |                |               |                |               |             | · · · ·      |               |              |                |             |                |             |
|-----|---------------|---------------|---------------|---------------|----------------|---------------|----------------|---------------|-------------|--------------|---------------|--------------|----------------|-------------|----------------|-------------|
| н L | 0             | 1             | 2             | 3             | 4              | 5             | 6              | 7             | 8           | 9            | A             | В            | с              | D           | E              | F           |
| 0   | NOP           | LD<br>BC, mn  | LD<br>(BC), A | INC<br>BC     | INC<br>B       | DEC<br>B      | LD<br>B, n     | RLCA          | EX<br>AF,AF | ADD<br>HC,BC | LD<br>A, (BC) | DEC<br>BC    | INC<br>C       | DEC<br>C    | LD<br>C, n     | RRCA        |
| 1   | DJNZ<br>e     | LD<br>DE, mn  | LD<br>(DE), A | INC<br>DE     | INC<br>D       | DEC<br>D      | LD<br>D,N      | RLA           | JE<br>e     | ADD<br>HL,DE | LD<br>A, (DE) | DEC<br>DE    | INC<br>E       | DEC<br>E    | LD<br>E, n     | RRA         |
| 2   | JR NZ,<br>e   | LD<br>HL, mn  | LD<br>(mn),HL | INC<br>HL     | INC<br>D       | DEC<br>H      | LD<br>H, n     | DAA           | JR Z<br>e   | ADD<br>HL,HL | LD<br>HL,(mn) | DEC<br>HL    | INC<br>L       | DEC<br>L    | LD<br>L, n     | CPL         |
| 3   | JR NC,<br>e   | LD<br>SP, mn  | LD<br>(mn),A  | INC<br>SP     | INC<br>(HL)    | DEC<br>(HL)   | LD<br>(HL), n  | SCF           | JR C<br>e   | ADD<br>HL,SP | LD<br>A,(mn)  | DEC<br>SP    | INC<br>A       | DEC<br>A    | LD<br>A, n     | CCF         |
| 4   | LD<br>B, B    | LD<br>B, C    | LD<br>B, D    | LD<br>B, E    | LD<br>B, H     | LD<br>B, L    | LD<br>B, (HL)  | LD<br>B, A    | LD<br>C, B  | LD<br>C, C   | LD<br>C, D    | LD<br>C, E   | LD<br>C, H     | LD<br>C, L  | LD<br>C, (HL)  | LD<br>C, A  |
| 5   | LD<br>D, B    | LD<br>D, C    | LD<br>D, D    | LD<br>D, E    | LD<br>D, H     | LD<br>D, L    | LD<br>D, (HL)  | LD<br>D, A    | LD<br>E, B  | LD<br>E, C   | LD<br>E, D    | LD<br>E, E   | LD<br>E, H     | LD<br>E, L  | LD<br>E, (HL)  | LD<br>E, A  |
| 6   | LD<br>H, B    | LD<br>H, C    | LD<br>H, D    | LD<br>H, E    | LD<br>H, H     | LD<br>H, L    | LD<br>H, (HL)  | LD<br>H, A    | LD<br>L, B  | LD<br>L, C   | LD<br>L, D    | LD<br>L, E   | LD<br>L, H     | LD<br>L, L  | LD<br>L, (HL)  | LD<br>L, A  |
| 7   | LD<br>(HL), B | LD<br>(HL), C | LD<br>(HL), D | LD<br>(HL), E | LD<br>(HL), H  | LD<br>(HL), L | HALT           | LD<br>(HL), A | LD<br>A, B  | LD<br>A, C   | LD<br>A, D    | LD<br>A, E   | LD<br>A, H     | LD<br>A, L  | LD<br>A, (HL)  | LD<br>A, A  |
| 8   | ADD<br>A, B   | ADD<br>A, C   | ADD<br>A, D   | ADD<br>A, E   | ADD<br>A, H    | ADD<br>A, L   | ADD<br>A, (HL) | ADD<br>A, A   | ADC<br>A, B | ADC<br>A, C  | ADC<br>A, D   | ADC<br>A, E  | ADC<br>A, H    | ADC<br>A, L | ADC<br>A, (HL) | ADC<br>A, A |
| 9   | S∪B<br>B      | SUB<br>C      | S∪B<br>D      | SUB<br>E      | S∪B<br>H       | SUB<br>L      | SUB<br>(HL)    | SUB<br>A      | SBC<br>A, B | SBC<br>A, C  | SBC<br>A, D   | SBC<br>A, E  | SBC<br>A, H    | SBC<br>A, L | SBC<br>A, (HL) | SBC<br>A, A |
| A   | AND<br>B      | AND<br>C      | AND<br>D      | AND<br>E      | AND<br>H       | AND<br>L      | AND<br>(HL)    | AND<br>A      | XOR<br>B    | XOR<br>C     | XOR<br>D      | XOR<br>E     | XOR<br>H       | XOR<br>L    | XOR<br>(HL)    | XOR<br>A    |
| В   | OR<br>B       | OR<br>C       | OR<br>D       | OR<br>E       | OR<br>H        | OR<br>L       | OR<br>(HL)     | OR<br>A       | CP<br>B     | CP<br>C      | CP<br>D       | CP<br>E      | СР<br>Н        | CP<br>L     | CP<br>(HL)     | XOR<br>A    |
| с   | RET<br>NZ     | POP<br>BC     | JP NZ,<br>mn  | JP<br>mn      | CALL<br>NZ, mn | PUSH<br>BC    | ADD<br>A, n    | RST<br>00H    | RET<br>C    | RET          | JP Z,<br>mn   | 1            | CALL<br>Z, mn  | CALL<br>mn  | ADC<br>A, n    | RST<br>08H  |
| D   | RET<br>NC     | POP<br>DE     | JP NC,<br>mn  | OUT<br>(n), A | CALL<br>NC, mn | PUSH<br>DE    | SUB<br>n       | RST<br>10H    | RET<br>C    | EXX          | JP C,<br>mn   | IN<br>A, (n) | CALL<br>C, mn  | 3           | SBC<br>A, n    | RST<br>18H  |
| E   | RET<br>PO     | POP<br>HL     | JP PO,<br>mn  | EX<br>(SP),HL | CALL<br>PO, mn | PUSH<br>HL    | AND<br>n       | RST<br>20H    | RET<br>PE   | JP<br>(HL)   | JP PE,<br>mn  | EX<br>DE,HL  | CALL<br>Pi, mn | 2           | XOR<br>n       | RST<br>28H  |
| F   | RET<br>P      | POP<br>AF     | JP P,<br>mn   | DI            | CALL<br>P, mn  | PUSH<br>AF    | OR<br>n        | RST<br>30H    | RET<br>M    | LD<br>SP, HL | JP M,<br>mn   | EI           | CALL<br>M, mn  | 4           | CP<br>n        | RST<br>38H  |

MPU Instruction Table (I)

Note ①~④: Multi-Opcode Instructions (ref. Table (II )~(VII))

# TMPZ84C013A Instruction Map (2/7)

# ① Byte 1 "CB"

### Instruction Table ( II ) (Byte 2 of 2-byte Opcode)

| L<br>H | 0    | 1    | 2    | 3    | 4    | 5    | 6       | 7    | 8        | 9        | A        | В        | с        | D        | E           | F        |
|--------|------|------|------|------|------|------|---------|------|----------|----------|----------|----------|----------|----------|-------------|----------|
| 0      | RLC     | RLC  | RRC         | RRC      |
|        | B    | C    | D    | E    | H    | L    | (HL)    | A    | B        | C        | D        | E        | H        | L        | (HL)        | A        |
| 1      | RL      | RL   | RR          | RR       |
|        | B    | C    | D    | E    | H    | L    | (HL)    | A    | B        | C        | D        | E        | H        | L        | (HL)        | A        |
| 2      | SLA     | SLA  | SRA         | SRA      |
|        | B    | C    | D    | E    | H    | L    | (HL)    | A    | B        | C        | D        | E        | H        | L        | (HL)        | A        |
| 3      |      |      |      |      |      |      |         |      | SRL<br>B | SRL<br>C | SRL<br>D | SRL<br>E | SRL<br>H | SRL<br>L | SRL<br>(HL) | SRL<br>A |
| 4      | ВІТ  | ВІТ  | BIT  | BIT  | ВІТ  | BIT  | BIT     | BIT  | BIT      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 0, В | 0, С | 0, D | O, E | 0, Н | O, L | 0,(HL)  | 0, A | 1, B     | 1, C     | 1, D     | 1, E     | 1, Н     | 1, L     | 1, (HL)     | 1, A     |
| 5      | BIT  | BIT  | BIT  | BIT  | ВІТТ | BIT  | BIT     | BIT  | ВІТ      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 2, B | 2, C | 2, D | 2, E | 2, Н | 2, L | 2, (HL) | 2, A | 3, В     | 3, C     | 3, D     | 3, E     | 3, Н     | 3, L     | 3, (HL)     | 3, A     |
| 6      | BIT  | BIT  | BIT  | BIT  | ВІТ  | BIT  | BIT     | BIT  | BIT      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 4, B | 4, C | 4, D | 4, E | 4, Н | 4, L | 4, (HL) | 4, A | 5, B     | 5, C     | 5, D     | 5, E     | 5, Н     | 5, L     | 5, (HL)     | 5, A     |
| 7      | BIT  | BIT  | BIT  | BIT  | ВІТ  | BIT  | BIT     | BIT  | ВІТ      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | ВІТ      |
|        | 6, B | 6, C | 6, D | 6, E | 6, Н | 6, L | 6, (HL) | 6, A | 7, В     | 7, C     | 7, D     | 7, E     | 7, Н     | 7, L     | 7, (HL)     | 7, А     |
| 8      | RES     | RES  | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 0, B | 0, C | 0, D | 0, E | 0, H | 0, L | 0, (HL) | 0, A | 1, B     | 1, C     | 1, D     | 1, E     | 1, H     | 1, L     | 1, (HL)     | 1, A     |
| 9      | RES     | RES  | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 2, B | 2, C | 2, D | 2, E | 2, H | 2, L | 2, (HL) | 2, A | 3, B     | 3, C     | 3, D     | 3, E     | 3, H     | 3, L     | 3, (HL)     | 3, A     |
| А      | RES     | RES  | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 4, B | 4, C | 4, D | 4, E | 4, H | 4, L | 4, (HL) | 4, A | 5, B     | 5, C     | 5, D     | 5, E     | 5, H     | 5, L     | 5, (HL)     | 5, A     |
| В      | RES     | RES  | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 6, B | 6, C | 6, D | 6, E | 6, H | 6, L | 6, (HL) | 6, A | 7, B     | 7, C     | 7, D     | 7, E     | 7, H     | 7, L     | 7, (HL)     | 7, A     |
| с      | SET     | SET  | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | O, B | 0, C | 0, D | 0, E | 0, H | 0, L | 0, (HL) | 0, A | 1, B     | 1, C     | 1, D     | 1, E     | 1, H     | 1, L     | 1, (HL)     | 1, A     |
| D      | SET     | SET  | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | 2, B | 2, C | 2, D | 2, E | 2, H | 2, L | 2, (HL) | 2, A | 3, B     | 3, C     | 3, D     | 3, E     | 3, Н     | 3, L     | 3, (HL)     | 3, A     |
| E      | SET     | SET  | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | 4, B | 4, C | 4, D | 4, E | 4, H | 4, L | 4, (HL) | 4, A | 5, B     | 5, C     | 5, D     | 5, E     | 5, Н     | 5, L     | 5, (HL)     | 5, A     |
| F      | SET     | SET  | SEТ      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | 6, B | 6, C | 6, D | 6, E | 6, H | 6, L | 6, (HL) | 6, A | 7, В     | 7, C     | 7, D     | 7, E     | 7, Н     | 7, L     | 7, (HL)     | 7, A     |

# TMPZ84C013A Instruction Map (3/7)

# 2 Byte 1 "ED"

# Instruction Table ( III ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0            | 1             | 2             | 3             | 4   | 5    | 6   | 7          | 8            | 9             | A            | в             | с | D    | E   | F          |
|--------|--------------|---------------|---------------|---------------|-----|------|-----|------------|--------------|---------------|--------------|---------------|---|------|-----|------------|
| 0      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 1      | I            |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 2      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 3      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 4      | IN<br>B, (C) | ОUТ<br>(С), В | SBC<br>HL,BC  | LD<br>(mn),BC | NEG | RETN | IM0 | LD<br>I, A | IN<br>C, (C) | OUT<br>(C), C | ADC<br>HL,BC | LD<br>BC,(mn) |   | RETI |     | LD<br>R, A |
| 5      | IN<br>D, (C) | OUT<br>(C), D | SBC<br>HL,DE  | LD<br>(mn),DE |     |      | IM1 | LD<br>A, I | IN<br>E, (C) | OUT<br>(C), E | ADC<br>HL,DE | LD<br>DE,(mn) |   |      | IM2 | LD<br>A, R |
| 6      | IN<br>H, (C) | ОUТ<br>(С), Н | \$BC<br>HL,HL | LD<br>(mn),HL |     |      |     | RRD        | IN<br>L, (C) | OUT<br>(C), L | ADC<br>HL,HL | LD<br>HL,(mn) |   |      |     | RLD        |
| 7      |              |               | SBC<br>HL,SP  | LD<br>(mn),SP |     |      |     |            | IN<br>A, (C) | OUT<br>(C), A | ADC<br>HL,SP | LD<br>SP,(mn) |   |      |     |            |
| 8      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 9      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| A      | LDI          | СРІ           | INI           | ουτι          |     |      |     |            | LDD          | CPD           | IND          | OUTD          |   |      |     |            |
| В      | LDIR         | CPIR          | INIR          | OTIR          |     |      | ×   |            | LDDR         | CPDR          | INDR         | OTDR          |   |      |     |            |
| с      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| D      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| E      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |
| F      |              |               |               |               |     |      |     |            |              |               |              |               |   |      |     |            |

# TMPZ84C013A Instruction Map (4/7)

③ Byte 1 "DD"

# Instruction Table ( IV ) (Byte 2 of 2-byte Opcode )

| ь<br>Н | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | А             | В         | с | D | E                  | F      |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|---------------|-----------|---|---|--------------------|--------|
| 0      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,BC  |               |           |   |   |                    |        |
| 1      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,DE  |               |           |   |   |                    |        |
| 2      |                       | LD<br>IX, mn          | LD<br>(mn), IX        | INC<br>IX             |                       |                       |                       |                       |   | ADD<br>IX, IX | LD<br>IX,(mn) | DEC<br>IX |   |   |                    |        |
| 3      |                       |                       |                       |                       | INC<br>(IX + d)       | DEC<br>(IX + d)       | LD<br>(IX + d)<br>, n |                       |   | ADD<br>IX, SP |               |           |   |   |                    |        |
| 4      |                       |                       |                       |                       |                       |                       | LD B,<br>(IX + d)     |                       |   |               |               |           |   |   | LD C,<br>(IX + d)  |        |
| 5      |                       |                       |                       |                       |                       |                       | LD D,<br>(IX + d)     |                       |   |               |               |           |   |   | LD E,<br>(IX + d)  |        |
| 6      |                       |                       |                       |                       |                       |                       | LD H,<br>(IX + d)     |                       |   |               |               |           |   |   | LD L,<br>(IX + d)  |        |
| 7      | LD<br>(IX + d)<br>, B | LD<br>(IX + d)<br>, C | LD<br>(IX + d)<br>, D | LD<br>(IX + d)<br>, E | LD<br>(IX + d)<br>, H | LD<br>(IX + d)<br>, L |                       | LD<br>(IX + d)<br>, A |   |               |               |           |   |   | LD A,<br>(IX + d)  |        |
| 8      |                       |                       |                       |                       |                       |                       | ADD<br>(IX + d)       |                       |   |               |               |           |   |   | ADC 1,<br>(IX + d) |        |
| 9      |                       |                       |                       |                       |                       |                       | S∪B<br>(IX + d)       |                       |   |               |               |           |   |   | SBC A,<br>(IX + d) |        |
| 8      |                       |                       |                       |                       |                       |                       | AND<br>(IX + d)       |                       |   |               |               |           |   |   | XOR<br>(IX + d)    |        |
| 9      |                       |                       |                       |                       |                       |                       | OR<br>(IX + d)        |                       |   |               |               |           |   |   | CP<br>(IX + d)     |        |
| С      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               | 5         |   |   |                    |        |
| D      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               |           |   |   |                    |        |
| E      |                       | POP<br>IX             |                       | EX<br>(SP), IX        |                       | PUSH<br>IX            |                       |                       |   | JP<br>(IX)    |               |           |   |   |                    |        |
| F      |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IX  |               |           |   |   |                    |        |
|        |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               |           |   |   |                    | 120489 |

Note  $\ensuremath{\mathfrak{S}}$  : Special 2 byte Opcode Instructions (ref. Table (  $\ensuremath{\mathbb{V}}$  ))

# TMPZ84C013A Instruction Map (5/7)

# ④ Byte 1 "FD"

### Instruction Table ( $\mathbb V$ ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | A              | В         | с | D | E                      | F      |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|----------------|-----------|---|---|------------------------|--------|
| 0      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,BC  |                |           |   |   |                        |        |
| 1      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,DE  |                |           |   |   |                        |        |
| 2      |                       | LD<br>IY, nn          | ID<br>(mn), IY        | INC<br>IY             |                       |                       |                       |                       |   | ADD<br>IY, IY | LD<br>IY, (mn) | DEC<br>IY |   |   |                        |        |
| 3      |                       |                       |                       |                       | INC<br>(IY + d)       | DEC<br>(IY + d)       | LD<br>(IY + d)<br>, n |                       |   | ADD<br>IY, SP |                |           |   |   |                        |        |
| 4      |                       | -                     |                       |                       |                       |                       | LD B,<br>(IY + d)     |                       |   |               |                |           |   |   | LD C,<br>(IY + d)      |        |
| 5      |                       |                       |                       |                       |                       |                       | LD D,<br>(IY + d)     |                       |   |               |                |           |   |   | LD E,<br>(IY + d)      |        |
| 6      |                       |                       |                       |                       |                       |                       | LD H,<br>(IY + d)     |                       | - |               |                |           |   |   | LD L,<br>(IY + d)      |        |
| 7      | LD<br>(IY + d)<br>, B | LD<br>(IY + d)<br>, C | LD<br>(IY + d)<br>, D | LD<br>(IY + d)<br>, E | LD<br>(IY + d)<br>, H | LD<br>(IY + d)<br>, L |                       | LD<br>(IY + d)<br>, A |   |               |                |           |   |   | LD A,<br>(IY + d)      |        |
| 8      |                       |                       |                       |                       |                       |                       | ADD<br>(IY + d)       |                       |   | •             |                |           |   |   | ADDC<br>A,<br>(IY + d) |        |
| 9      |                       |                       |                       |                       |                       |                       | SUB<br>(IY + d)       |                       |   |               |                |           |   |   | SUBC<br>A,<br>(IY + d) |        |
| 8      |                       |                       |                       |                       |                       |                       | AND<br>(IY + d)       |                       |   |               |                |           |   |   | XOR<br>(IY + d)        |        |
| 9      |                       |                       |                       |                       |                       |                       | OR<br>(IY + d)        |                       |   |               |                |           |   |   | CP<br>(IY + d)         |        |
| с      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                | 6         |   |   |                        |        |
| D      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                |           |   |   |                        |        |
| E      |                       | POP<br>IY             |                       | EX<br>(SP), IY        |                       | PUSH<br>IY            |                       |                       |   | JP<br>(IY)    |                |           |   |   |                        |        |
| F      |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IY  |                |           |   |   |                        |        |
|        |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                |           |   |   |                        | 120489 |

Note ©: Special 2 byte Opcode Instructions (ref. Table (VII))

# TMPZ84C013A Instruction Map (6/7)

⑤ Byte 1 "DD"

Byte 2 "CB"

# Instruction Table (VI) (Special case of 2-byte Opcode : Byte 3)

| L<br>H | 0 | 1 | 2 | 3 | 4 | 5 | 6                  | 7 | 8 | 9 | А | в | с | D | E                  | F |
|--------|---|---|---|---|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0      |   |   |   |   |   |   | RLC<br>(IX + d)    |   |   |   |   |   |   |   | RRC<br>(IX + d)    |   |
| 1      |   |   |   |   |   |   | RL<br>(IX + d)     |   |   |   |   |   |   |   | RR<br>(IX + d)     |   |
| 2      |   |   |   |   |   |   | SLA<br>(IX + d)    |   |   |   |   |   |   |   | SRA<br>(IX + d)    |   |
| 3      |   |   |   |   |   |   |                    |   |   |   |   |   |   |   | SRL<br>(IX + d)    |   |
| 4      |   |   |   |   |   |   | BIT 0,<br>(IX + d) |   |   |   |   |   |   |   | BIT 1,<br>(IX + d) |   |
| 5      |   |   |   |   |   |   | BIT 2,<br>(IX + d) |   |   |   |   |   |   |   | BIT 3,<br>(IX + d) |   |
| 6      |   |   |   |   |   |   | BIT 4,<br>(IX + d) |   |   |   |   |   |   |   | BIT 5,<br>(IX + d) |   |
| 7      |   |   |   |   |   |   | BIT 6,<br>(IX + d) |   |   |   |   |   |   |   | BIT 7,<br>(IX + d) |   |
| 8      |   |   |   |   |   |   | RES 0,<br>(IX + d) |   |   |   |   |   |   |   | RES 1,<br>(IX + d) |   |
| 9      |   |   |   |   |   |   | RES 2,<br>(IX + d) |   |   |   |   |   |   |   | RES 3,<br>(IX + d) |   |
| A      |   |   |   |   |   |   | RES 4,<br>(IX + d) |   |   |   |   |   |   |   | RES 5,<br>(IX + d) |   |
| В      |   |   |   |   |   |   | RES 6,<br>(IX + d) |   |   |   |   |   |   |   | RES 7,<br>(IX + d) |   |
| с      |   |   |   |   |   |   | SET 0,<br>(IX + d) |   |   |   |   |   |   |   | SET 1,<br>(IX + d) |   |
| D      |   |   |   |   |   |   | SET 2,<br>(IX + d) |   |   |   |   |   |   |   | SET 3,<br>(IX + d) |   |
| E      |   |   |   |   |   |   | SET 4,<br>(IX + d) |   |   |   |   |   |   |   | SET 5,<br>(IX + d) |   |
| F      |   |   |   |   |   |   | SET 6,<br>(IX + d) |   |   |   |   |   |   |   | SET 7,<br>(IX + d) |   |

# TOSHIBA

# TMPZ84C013A Instruction Map (7/7)

⑥ Byte 1 "FD"

Byte 2 "CB"

# Instruction Table (VII) (Special case of 2-byte Opcode : Byte 3)

| L<br>H | 0 | 1 | 2 | . 3 | 4 | 5 | 6                  | 7 | 8 | 9 | А | В | с | D | E                  | F |
|--------|---|---|---|-----|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0      |   |   |   |     |   |   | RLC<br>(IY + d)    |   |   |   |   |   |   |   | RRC<br>(IY + d)    |   |
| 1      |   |   |   |     |   |   | RL<br>(IY + d)     |   |   |   |   |   |   |   | RR<br>(IY + d)     |   |
| 2      |   |   |   |     |   |   | SLA<br>(IY + d)    |   |   |   |   |   |   |   | SRA<br>(IY + d)    |   |
| 3      |   |   |   |     |   |   |                    |   |   |   |   |   |   |   | SRL<br>(IY + d)    |   |
| 4      |   |   |   |     |   |   | BIT 0,<br>(IY + d) |   |   |   |   |   |   |   | BIT 1,<br>(IY + d) |   |
| 5      |   |   |   |     |   |   | BIT 2,<br>(IY + d) |   |   |   |   |   |   |   | BIT 3,<br>(IY + d) |   |
| 6      |   |   |   |     |   |   | BIT 4,<br>(IY + d) |   |   |   |   |   |   |   | BIT 5,<br>(IY + d) |   |
| 7      |   |   |   |     |   |   | BIT 6,<br>(IY + d) |   |   |   |   |   |   |   | BIT 7,<br>(IY + d) |   |
| 8      |   |   |   |     |   |   | RES 0,<br>(IY + d) |   |   |   |   |   |   |   | RES 1,<br>(IY + d) |   |
| 9      |   |   |   |     |   |   | RES 2,<br>(IY + d) |   |   |   |   |   | • |   | RES 3,<br>(IY + d) |   |
| A      |   |   |   |     |   |   | RES 4,<br>(IY + d) |   |   |   |   |   |   |   | RES 5,<br>(IY + d) |   |
| В      |   |   |   |     |   |   | RES 6,<br>(IY + d) |   |   |   |   |   |   |   | RES 7,<br>(IY + d) |   |
| с      |   |   |   |     |   |   | SET 0,<br>(IY + d) |   |   |   |   |   |   |   | SET 1,<br>(IY + d) |   |
| , D    |   |   |   |     |   |   | SET 2,<br>(IY + d) |   |   |   |   |   |   |   | SET 3,<br>(IY + d) |   |
| E      |   |   |   |     |   |   | SET 4,<br>(IY + d) |   |   |   |   |   |   |   | SET 5,<br>(IY + d) |   |
| F      |   |   |   |     |   |   | SET 6,<br>(IY + d) |   |   |   |   |   |   |   | SET 7,<br>(IY + d) |   |

### 3.3. CGC OPERATIONS

This subsection describes the system configuration, functions, and basic operations of the clock generator/controller (CGC).

#### 3.3.1 Block Diagram

Figure 3.3.1 shows the block diagram of CGC.



Figure 3.3.1 Block Diagram

### 3.3.2 CGC System Configuration

The internal configuration of the CGC is shown in Figure 3.3.1. The waveform from the external oscillator oscillated by the internal oscillator and divided by the divider is converted into the square wave for clock. The clock is controlled by the control circuit and the counter to be sent to the outside the CGC. The following describes the CGC's main components and their functions.

- (1) Clock Generation
- (2) Operation Modes

### [1] Clock Generation

The CGC contains an oscillation circuit. By connecting oscillator to external pins (XTAL1 and XTAL2), the required clock can be generated easily. The CGC provides the clock whose frequency is 1/2 of the oscillation frequency. Figure 3.3.2 shows an example of oscillator connection.



Figure 3.3.2 (a) Example of Crystal Connection

Figure 3.3.2 (b) Oscillator Equivalent Circuit

 For the quartz crystal oscillator, use the MR8000-C20 (oscillation frequency 8 MHz) or MR12000-C20 (oscillation frequency 12 MHz) manufactured by Tokyo Denpa Company Ltd., or the equivalent;

| Product No. | Holder  | Frequency Cin |      | Cout | Quai<br>Para        | rtz Crysta<br>meter (1 | al<br>Typ.)        | Drive Level | Condition<br>Load   |  |
|-------------|---------|---------------|------|------|---------------------|------------------------|--------------------|-------------|---------------------|--|
|             | Туре    | (IVIHz)       | (pF) | (pF) | C <sub>1</sub> (pF) | C <sub>0</sub> (pF)    | R <sub>1</sub> (Ω) | (mvv)       | Capacitance<br>(pF) |  |
| MR8000-C20  |         | 8             | 22   | 33   | _                   | 4.00                   | 30.0               |             |                     |  |
| MR8000-C14  | HC-49   | 8             | 20   | 20   | 0.0189              | 3.87                   | 6.0                | 0.5         | 12.67               |  |
| MR12000-C20 | -0      | 12            | 33   | 33   |                     | 4.00                   | 25.0               | _           | —                   |  |
| MR12000-C14 | (TR-49) | 12            | 20   | 20   | 0.0190              | 3.81                   | 6.9                | 0.5         | 12.55               |  |
| MR16000-C14 |         | 16            | 20   | 20   | 0.0197              | 4.00                   | 5.7                | 0.5         | 12.20               |  |
|             |         |               |      |      |                     |                        |                    |             | 190589              |  |

Note: The load capacitance in the condition does not include any stray capacitance.

(2) For the ceramic resonater, use the CSA8.00MT, CST8.00MT (oscillation frequency 8 MHz) or CSA12.00MT, CST12.00MT (oscillation frequency 12 MHz) manufactured by Murata MFG Co., Ltd.

| Product No. | Frequency (MHz) | Cin (pF) | Cout (pF) |
|-------------|-----------------|----------|-----------|
| CSA8.00MT   | 8               | 30       | 30        |
| CST8.00MT   | 8               |          |           |
| CSA12.0MT   | 12              | 30       | 30        |
| CST12.0MT   | 12              |          |           |
|             |                 |          | 190589    |

Note: The CST8.00MT and CST12.0MT need no outer capacitance.

### [2] Operation Modes

The CGC has the capability to control 4 operation modes; Run, Idle 1, Idle 2, and Stop. Any one of them can be selected through the mode setting register (#F0:bit4, bit3:HALTMR). These modes become valid when the MPU executes a HALT instruction. Fetching a HALT instruction, the MPU sets the HALT signal to "0", indicating that it has been put in the halt state. After the execution of the HALT instruction, the CGC performs the operation in the specified mode. Table 3.3.1 shows the operations in each mode.

| Halt mode se<br>(#F0:H/ | tting register<br>ALTMR) | Operational | Description                                                                                                                                                                                                    |  |  |  |  |  |  |
|-------------------------|--------------------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| Bit 4                   | Bit 3                    | iviode      |                                                                                                                                                                                                                |  |  |  |  |  |  |
| 0                       | 0                        | ldle 1 Mode | Only the internal oscillator operates, stopping the supply of clock outside. The clock output (CLKOUT) is held at "0".                                                                                         |  |  |  |  |  |  |
| 0                       | 1                        | ldle 2 Mode | The internal oscillator continues operating with the<br>supply of clock outside (CLKOUT) continued. When<br>pins CLKOUT and CLKIN are connected, only the<br>supply of clock (CLKOUT) to the CTC is continued. |  |  |  |  |  |  |
| 1                       | 0                        | Stop Mode   | All internal operations are stopped. The clock output (CLKOUT) is held at "0".                                                                                                                                 |  |  |  |  |  |  |
| 1                       | 1                        | Run Mode    | The supply of clock outside is continued.                                                                                                                                                                      |  |  |  |  |  |  |

| Table 3.3.1 CGC Operation N | Modes |
|-----------------------------|-------|
|-----------------------------|-------|

140489

The restart from the clock stop state in Idle 1, Idle 2 (these two modes are referred to as Idle mode hereafter), or Stop mode is performed by reset ( $\overline{\text{RESET}}$  signal) or acknowledge of maskable interrupt ( $\overline{\text{INT}}$  signal) or non-maskable interrupt ( $\overline{\text{NMI}}$  signal).

### TOSHIBA

#### [3] Warm-up Time for Restart (from Stop mode)

Releasing the halt state by interrupt acknowledge, the MPU begins executing interrupt processing. Therefore, when restarting the clock by the  $\overline{\rm NMI}$  or  $\overline{\rm INT}$  restart signal in the Stop mode, the oscillation must be fully stabilized before supplied outside. The CGC provides, by means of the internal counter, the warm-up time enough for the clock to stabilize frequency. The warm-up ends on the rising edge of the internal counter output dividing the oscillation frequency to start clock output. The warm-up time is equal to the time derived by dividing the frequency of the externally attached oscillator by  $2^{14}$ .

Figure 3.3.3 shows the block diagram of the internal counter. Table 3.3.2 shows the relationship between the oscillation frequency and the warm-up time.

In the restart by the  $\overline{\text{RESET}}$  signal, no warm-up is performed for the quick operation at power-on. Therefore, expand the width of the  $\overline{\text{RESET}}$  signal adequately to provide the warm-up time.



Figure 3.3.3 Block Diagram of Internal Counter

\* fc = fxTAL/2

Table 3.3.2 Warm-up Time

| Counter output | Warm-up Time |               |              |  |  |  |  |  |
|----------------|--------------|---------------|--------------|--|--|--|--|--|
| 215            | 214/5-       | fXTAL = 12MHz | fXTAL = 8MHz |  |  |  |  |  |
| 215            | 214/TC       | 2.7 ms        | 4 ms         |  |  |  |  |  |
|                |              |               | 140400       |  |  |  |  |  |

### 3.3.3 CGC Status Transition Diagram and Basic Timing

The following describes the status transition and basic timing to be provided when the CGC operates.

[1] Status Transition Diagram







### TOSHIBA

#### [2] Basic Timing

The following describes the CGC basic timing when the CGC clock output pin (CLKOUT) and clock input pin (CLKIN) are connected.

(1) Operation at execution of HALT instruction

The following describes the basic timing in each mode to be provided when the MPU executes a HALT instruction. The MPU sets the HALT signal to "0" synchronized with the falling edge of clock state T4 of the HALT instruction Opcode fetch cycle (M1). This signal indicates to the CGC that the MPU is going to enter into the halt states.

#### (a) Run mode (#F0:bit 4 = 1, bit 3 = 1:HALTMR)

Figure 3.3.5 shows the basic timing in the Run mode. In the Run mode, the CGC continues supplying the clock to the outside even when the MPU is in the halt state. Therefore, the MPU continues executing NOPs during the halt state. The systems which need memory address refresh use this mode.



Figure 3.3.5 Basic Timing in Ruin Mode

(b) Idle 1 mode (#F0:bit 4=0, bit 3=0:HALTMR), idle 2 mode (#F0:bit 4=0, bit 3=0:HALTMR), and Stop mode (#F0:bit 4=1, bit 3=0)

Figure 3.3.6 shows the basic timing in the Idle modes and Stop mode. In these modes, the clock output is stopped with clock state T4 being "0" by the  $\overline{\text{HALT}}$  signal and the  $\overline{\text{MT}}$  signal which follows the HALT instruction.

However, in the Stop mode, the CGC's internal oscillator also stops.

# TOSHIBA



Figure 3.3.6 Basic Timing in Idle and Stop Modes

(2) Clock output restart from each mode

The clock stopped state in the Idle or Stop mode is cleared by setting any of the following signals to "0" (for the system restart operation, see Subsection 3.3.4):

- INT (level trigger input)
- <u>NMI</u> (edge trigger input)
- RESET (level trigger input)
- (a) Clock output restart from Idle mode

Figure 3.3.7 (a) shows the basic timing for the sequence of the output restart from the clock stopped state in the Idle 1 mode. In the restart in the Idle 1 mode, the clock output is restarted in a relatively short delay time because the internal oscillator operates even in the clock stopped state.



### (b) Clock output restart from Stop mode

Figure 3.3.8 shows the basic timing for the sequence of the restart from the clock stopped state in the Stop mode. When restarting by setting the  $\overline{\text{INT}}$  or  $\overline{\text{NMI}}$  signal to "0", the warm-up time is automatically created by the internal counter. In the restart by the  $\overline{\text{RESET}}$  signal, oscillation restarts without warm-up.



Figre 3.3.8 Basic Timing for Sequence of Restart from Clock stopped State (Stop Mode)

### 3.3.4 Relationship with MPU

The following describes the relationship between the CGC and the MPU mainly in terms of the halt clear operation.

### [1] RESET Signal

Figure 3.3.9 shows an example of the timing for the restart from the Stop mode on the TMPZ84C013A using  $\overline{\text{RESET}}$  signal for both the MPU and CGC. To reset the MPU, the  $\overline{\text{RESET}}$  signal must be set to "0" for at least 3 stable clocks. When the  $\overline{\text{RESET}}$  signal goes "1", the MPU releases the halt state after a dummy cycle of 2T clock states to start executing instructions from address 0000H.

To restart the clock output by the RESET signal in the Stop mode, the internal counter to determine the warm-up time does not operate.

Therefore, if the MPU does not restart correctly due to the unstable clock output immediately after the restart of the internal oscillator, or the unstability of the crystal at power-on, the  $\overline{\text{RESET}}$  signal must be held at "0" for a time long enough for the MPU to be reset securely.



Figure 3.3.9 Example of clock Restart Timing by RESET Signal

### [2] Releasing Halt State by Interrupt Signal

The CGC restarts the clock output from the Idle or Stop mode by the input of  $\overline{INT}$  or  $\overline{NMI}$  signal. By this clock, the MPU starts operating. However, when the CGC restarts the clock output, the MPU is still in the halt state executing NOPs. To clear the halt state, the interrupt signal must be entered into the MPU (in the case of the  $\overline{INT}$  signal) for at least one instruction. The MPU interrupt is detected on the rising edge of the last clock of each instruction (NOP for the halt state).

(1) When using non-maskable interrupt (NMI)

MPU's non-maskable interrupt is edge trigger input. The MPU contains the flip-flop to detect an interrupt. The state of this internal NMI flip-flop is sampled on the rising edge of the last clock of each instruction. Therefore, when a short active low ("0") pulse has been inserted before the interrupt detection timing, the interrupt is acknowledged. The  $\overline{\rm NMI}$  input of the TMPZ84C013A is connected to the  $\overline{\rm NMI}$  input of the MPU via the CGC, performing the same operations as above. (See Figure 3.3.11)

(2) When using maskable interrupt (INT)

With a maskable interrupt, the maskable interrupt enable flip-flop (IFF) must be set to "1" by program before the INT input signal is detected "0". Even if the CGC accepts the INT signal to restart supply of the clock, no interrupt is acknowledged unless the INT signal is kept inserted until one instruction (NOP) has been executed. Figure 3.3.10 shows the timing for clearing the halt state by the interrupt signal.



Figure 3.3.10 Timing for Clearing Halt State by Interrupt Signal

### [3] Connecting CGC to MPU on TMPZ84C013A

Figure 3.3.11 shows the connection between the CGC and the MPU on the TMPZ84C013A.



Figure 3.3.11 Connection Between CGC and MPU

# TOSHIBA

### 3.4 CTC OPERATIONAL DESCRIPTION

The CTC has 4 independent channels. To these channels, addresses are allocated on the TMPZ84C013A's I/O map, permitting the read/write of the channels in the MPU's I/O cycle. (See Figure 3.4.1) This subsection mainly describes the CTC operation to be performed after accessed.

### 3.4.1 CTC Block Diagram

Figure 3.4.1 shows the block diagram of the CTC.



Figure 3.4.1 Block Diagram of CTC

3.4.2 CTC System Configuration

The CTC system consists of the following 4 logic circuits:

- (1) MPU bus I/O logic circuit
- (2) Internal control logic circuit
- (3) Interrupt control logic circuit
- (4) Four independent counter/timer channel logic circuits
- [1] MPU Bus I/O Logic Circuit

This circuit transfers data between the MPU and the CTC.

[2] Internal Control Logic Circuit

This circuit controls the CTC operational functions such as the CTC selecting chip enable, reset, and read/write circuits.

[3] Interrupt Control Logic Circuit

This circuit performs the MPU interrupt related processing such as priority determination. The order of priority with other LSIs is determined according to the physical location in daisy chain connection.

[4] Counter/Timer Channel Logic Circuit

This circuit consists of the following 2 registers and 2 counters. Figure 3.4.2 shows the configuration of this circuit.

- Time-constant register (8 bits)
- Channel control register (8 bits)
- Down-counter (8 bits)
- Prescaler (8 bits)



Figure 3.4.2 Configuration of Counter/Timer Channel Logic Circuit

(1) Time-constant register

This register holds the time constant to be written in the down counter. When the CTC is initialized or the down-counter has reached zero, the time constant is loaded into down-counter. The time constant is set immediately after the MPU has written the channel control word in the channel control register. For a time constant, an integer from 1 to 256 can be used.

(2) Channel control register

This register is used to choose the channel mode or condition according to the channel control word sent from the MPU.

#### (3) Down-counter

The contents of the time-constant register are loaded into the down counter. In the counter mode, these contents are decremented at each edge of the external clock; in the timer mode, they are decremented for each prescaler clock output. The contents of the time-constant register are loaded at initialization or when the down-counter has reached zero.

The contents of the down-counter can be read any time. Also, the system can be programmed so that an interrupt request is generated each time the down-counter has reached zero.

#### (4) Prescaler

The prescaler, used only in the timer mode, divides the system clock by 16 or 256. The dividing number is programmed by channel control word. The output of the prescaler becomes the clock input to the down-counter.

#### 3.4.3 CTC Basic Operations

[1] Reset

The state of the CTC is unstable after it is powered on. To stabilize the CTC, the low level signal needs to be applied to the  $\overline{\text{RESET}}$  pin. On any channel, the channel control word and time-constant data must be written to be started before it is started in the counter or timer mode. To program the system to enable interrupts, the interrupt vector word must be written in the interrupt controller. When these data have been written in the CTC, it is ready to start.

### [2] Interrupt

The CTC can cause an interrupt when the MPU is operating in the mode 2. The CTC interrupt can be programmed for each channel. Each time the channel's down-counter has reached zero, the CTC outputs the interrupt request signal ( $\overline{INT}$ ). When the MPU accepts the CTC's interrupt request, the CTC outputs the interrupt vector. Based on this interrupt vector, the MPU specifies the start address of the interrupt processing routine and calls it to start interrupt processing.

The MPU specifies the start address of the interrupt processing routine by the interrupt vector output from the CTC, so that the user can change the vector value to call any desired address.

The interrupt processing is terminated when the MPU executes an RETI instruction. The CTC has the circuit which decodes the RETI instruction. By constantly monitoring the data bus the CTC can detect the termination of the interrupt processing. The order of interrupt priority with the Z80 peripheral LSIs is determined by the daisy chain connection. That is, the peripheral LSIs are connected one after another and the one physically near the MPU is given a higher priority. The priority of the Z80 peripheral LSIs (CTC, PIO, and SIO) contained in the TMPZ84C013A is determined by the contents of the interrupt priority register (#F4:bits 2 through 0). Inside the CTC, channel 0 is given the highest priority, followed by channels 1, 2 and 3 in this order.

The CTC and other peripheral LSIs on the TMPZ84C013A have the signal lines IEO and IEI. Connect the IEO of a higher peripheral LSI to the IEI of a lower perpheral LSI. Connect the IEI of the highest peripheral LSI to VCC. Leave the IEO of the peripheral LSI unused. In this connection, the CTC interrupt is caused under the following conditions:

- When both IEI and IEO are high, no interrupt is caused. At this time, the INT signal is high. An interrupt can be requested in this state.
- When the CTC outputs the interrupt request signal (INT), the IEO of the CTC becomes low. When the MPU accepts the interrupt, the INT goes high again.
- When the IEI goes low, the IEO also goes low.
- While the IEI is low, no interrupt can be requested.
- When the IEI goes low while an interrupt is being serviced, the interrupt processing is aborted.
- [3] Operation Modes

The CTC operates in either the counter mode or the timer mode. Mode is selected by writing the channel control word.

(1) Counter mode

In the counter mode, the number of edge of the pulses applied to the channel's CLK/TRG pin is counted. When pulses have been input, the contents of the down-counter are decremented synchronizing with the rising edge of the next system clock. The pulse's rising edge or falling edge to be counted can be specified by the channel control word.

When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin. When the interrupt is enabled by the channel control word, the INT pin goes low and an interrupt is requested. When the contents of the down-counter has reached zero, the time constant data written in the time constant register is automatically loaded into the down-counter. To load a new time constant value into the down-counter, write the data to the time constant register, and it is loaded into the down-counter after the current count operation is terminated.

#### (2) Timer mode

In the timer mode, the time intervals which are integral multiples of the system clock period. A timer interval is measured according to the system clock. The system clock is supplied to the prescaler which divides it by a factor of 16 or 256. The output of the prescaler provides the clock to decrement the down-counter by 1. The time constant data is automatically loaded into the down-counter each time it has reached zero as in the counter mode. When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin.

This pulse period is given by the following expression:

tc\*P\*TC

Where, tc = System clock period P = Prescaler value (16 or 256) TC = Time constant data (256 for 00H)

The user can select, by means of the channel control word, to start the timer automatically or to start the timer on the edge of the pulse at CLK/TRG pin. In case the user select the CLK/TRG pin, the user can also select the rising edge or falling edge of the pulse.

# TOSHIBA

### 3.4.4 CTC Status Transition Diagram and Basic Timing

### [1] Transition Diagram

Figure 3.4.3 shows the CTC status transition diagram.



140489





140489

Figure 3.4.3 (b) CTC Transition Diagram (b)

### [2] Basic Timing

(1) Write cycle

The write cycle is used to write a channel control word, an interrupt vector, or a time constant. The MPU drives the  $\overline{IORQ}$  pin of the CTC low in the subsequent system clock cycle T2 to start the write cycle.

It is required to make the  $\overline{\text{M1}}$  pin of the CTC high to indicate that the write cycle is on.

At the start of the cycle, the channel is specified by CS1 (A1) or CSO (A0) of the CTC. Thus, the CTC's internal registers are ready to accept data in system clock T3. Tw is the state to be automatically inserted by the MPU.



### (2) Read cycle

The read cycle is used to read the contents of the down-counter. During clock cycle T2, the MPU initiates a read cycle by driving the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins low. It is required to make the  $\overline{\text{MI}}$  pin high to indicate that the read cycle is on. At the start of the read cycle, the channel is specified by CS1 (A1) or CS0 (A0) of the CTC.

On the rising edge of system clock TW, the contents of the down-counter at the time of the rising edge of T2 are put on the data bus. TW is the wait state to be automatially inserted by the MPU.



#### [3] Counter mode

In the counter mode, the down-counter is decremented synchronizing with the system clock, at the edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the down-counter is decremented one system clock later. When the down-counter has reached zero, a high level pulse is output from the ZC/TO pin.


#### [4] Timer mode

The timer starts operating at the second rising edge of the system clock from the rising edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the timer starts one system clock cycle later.



Figure 3.4.7 Timer Mode Timing

### [5] Interrupt acknowledge cycle

Having received the interrupt request signal ( $\overline{INT}$ ) from the CTC, the MPU drives the CTC's  $\overline{MI}$  pin and  $\overline{IORQ}$  pin low to provide the acknowledge signal. The  $\overline{IORQ}$  pin goes low 2.5 system clocks later than the  $\overline{M1}$  pin. To stabilize the signal lines (IEI and IEO) in daisy chain connection, the interrupt request cannot be changed on each channel while the  $\overline{M1}$  pin is low. The  $\overline{RD}$  pin is held high to make distinction between the instruction fetch cycle and the interrupt acknowledge cycle. While the  $\overline{RD}$  pin is high, the CTC's interrupt control circuit determines the interrupt-requesting channel of highest priority. When the CTC's IEI is high and the  $\overline{M1}$  pin and  $\overline{IORQ}$  pin go low, the interrupt vector is output from the interrupt requesting channel of highest priority on the data bus. At this time, 2 system clock cycles are automatically inserted by the MPU as a wait state to maintain the stabilization of the daisy chain connection.



#### MPUZ80-482

## [6] Return from interrupt processing

Return from the interrupt processing is performed when the MPU executes the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When this instruction is executed by the MPU, the CTC's IEI and IEO return to the state active before the interrupt has been serviced.

The RETI instruction is a 2-byte instruction. Its code is EDH 4DH. The CTC decodes this instruction to check if there is the next interrupt request channel.

In the daisy chain structure, the interrupting LSI's IEI and IEO are held high and low respectively at the time the instruction code EDH has been decoded.

The code following EDH is 4DH, only the peripheral LSI which has sent the last interrupt vector (that is, the LSI whose IEI is high and IEO is low) returns from the interrupt processing. This restarts the processing of the suspended interrupt of the peripheral LSI of the next higher priority.



Figure 3.4.9 Interrupt Return Timing

## 3.4.5 CTC Operational Procedure

To operate the CTC in the counter mode or the timer mode, the channel control word and time-constant data must be written in the CTC. To enable interrupts by the channel control word, the interrupt vector must be written in the CTC.

## [1] I/O Address and Channel Control Word

To write the channel control word in the CTC, the channel must be specified by the corresponding channel I/O address. Table 3.4.1 shows the channel I/O addresses.

| Channel | I/O address |
|---------|-------------|
| 0       | #10         |
| 1       | #11         |
| 2       | #12         |
| 3       | #13         |
|         | 140489      |

Table 3.4.1 Channel I/O Addresses

The channel control word to be written in the CTC consists of 8 bits. The system data bus D0 through D7 correspond to bit 0 through 7 respectively. Figure 3.4.10 shows the meaning of each bit. Table 3.4.2 shows the function of each bit.

| D7        | D6                | D5        | D4   | D3      | D2               | D1    | D0 |
|-----------|-------------------|-----------|------|---------|------------------|-------|----|
| Interrupt | Counter/<br>timer | Prescaler | Edge | Trigger | Time<br>constant | Reset | 1  |

### Figure 3.4.10 Channel Control Word

For the channel control word, D0 must be always 1.

Table 3.4.2 Meanings and Function of Channel Control Words (1/3)

| Di+           | Pit Meaning and function   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
|---------------|----------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0             |                            | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
| Bit 7<br>(D7) | Disables channel interrupt | Enables channel interrupt. In either<br>counter or timer mode, the interrupt is<br>requested every time the down-counter<br>has reached zero.When this bit is set to<br>"1", the interrupt vector must be written<br>in the CTC before the down-counter<br>starts. When the channel control word<br>whose D7 bit is "1" is written in an already<br>operating channel, the interrupt occurs<br>only when the down-counter has reached<br>zero for the first time after the writing of<br>the new channel control word. |  |  |

140489

|                       |                                                                                                                                                                                                                                                                                                                                               | (2/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D:+                   | Meaning ar                                                                                                                                                                                                                                                                                                                                    | nd function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ы                     | 0                                                                                                                                                                                                                                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Bit 6<br>(D6 <b>)</b> | Puts the channel in the timer mode. Puts<br>the system clock into the prescaler and<br>outputs the divided signal to the down-<br>counter.                                                                                                                                                                                                    | Puts the channel in the counter mode.<br>The down-counter is decremented for<br>each edge trigger applied to the CLK/TRG<br>pin. In the counter mode, the prescaler is<br>not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Bit 5<br>(D5)         | Used only in the timer mode. The prescaler is set to divide the system clock by 16.                                                                                                                                                                                                                                                           | Used only in the timer mode. The prescaler is set to divide the system clock by 256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Bit 4<br>(D4)         | In the timer mode, the timer operation starts on the falling edge of the trigger PULSE (CLK/TRG) . In the counter mode, the down-counter is decremented on the falling edge of the external clock pulse (CLK/TRG)                                                                                                                             | In the timer mode, the timer operation<br>starts on the rising edge of the trigger<br>pulse (CLK/TRG). In the counter mode, the<br>down-counter is decremented on the<br>rising edge of the trigger pulse (CLK/<br>TRG).                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Bit 3<br>(D3)         | Used only in the timer mode.<br>The timer oparation starts on the rising<br>edge following 2 system clocks after the<br>time constant has been loaded into the<br>down-counter.                                                                                                                                                               | Used only in the timer mode. The timer<br>operation is started by the external<br>trigger pulse. That is, the timer starts<br>operating at the trigger pulse entered<br>after the rising edge following 2 system<br>clocks after the time constant has been<br>loaded into the down-counter. If the<br>interval between the system clock and the<br>trigger pulse satisfies the setup time, the<br>prescaler starts operating on the second<br>rising edge. Otherwise, the prescaler<br>starts operating on the rising edge<br>following 3 system clocks. If the trigger<br>pulse is entered before the time constant<br>is loaded the same effect as when bit 3 =<br>"0" takes place. |
| Bit 2<br>(D2)         | Indicates that the channel control word is<br>not followed by the writing of time<br>constant. When the channel is in the reset<br>state, this bit cannot be set to "0" in the<br>first channel control word . To change<br>states with the time constant unchanged,<br>the channel control word with this bit set<br>to "0" must be entered. | Indicates that the channel control word is<br>followed by the writing of time constant.<br>If the time constant is written during<br>down-counter operation, the new time<br>constant is set to the time constant<br>register with proceeding the current<br>counting. When the down-counter has<br>reached zero, the new time constant is<br>loaded into the down-counter.                                                                                                                                                                                                                                                                                                            |

1

(2/2)

|               |                                         | (3/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-----------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D:+           | Meaning a                               | nd function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Bit           | 0                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| Bit 1<br>(D1) | Continues the current channel operation | Stops the down-counter operation.<br>When this bit is set to "1", the channel<br>operation stops but all the channel<br>control register bits remain unchanged.<br>When bit $2 = "1"$ and bit $1 = "1"$ , the<br>channel operation remains stopped until<br>a new time constant is written. Channel<br>restart is set up after the new time<br>constant is programmed. The channel is<br>restarted according to the state of bit 3.<br>When bit $2 = "0"$ and bit $1 = "1"$ , the<br>channel operation does not start until a<br>new channel control word is written. |

140489

#### [2] Time-Constant Data

In either the time mode or the counter mode, the time-constant data must be loaded into the time constant register. When bit 2 (D2) of the channel control word is "1", the time constant is loaded into the time constant register immediately after the channel control word is written. A time-constant value must be an integer in a range of 1 to 256. When the 8 bits of a time constant are all "0"s, such a time constant is assumed to be 256. Figure 3.4.11 shows the bit configuration of time-constant data.

| D7  | D6  | D5  | D4  | D3  | D2  | D1  | D0  |       |
|-----|-----|-----|-----|-----|-----|-----|-----|-------|
| TC7 | TC6 | TC5 | TC4 | TC3 | TC2 | TC1 | тс0 | 14048 |

Figure 3.4.11 Time-Constant Data

#### [3] Interrupt Vector

In interrupt in the MPU mode-2, the interrupting channel must give an interrupt vector to the MPU. An interrupt vector is written in the channel-0 interrupt vector register with bit 0 (D0) = "0". The vector is written in the same way as the channel control word is written on channel 0. However, bit 0 (D0) of the vector should always be "0". Bit 7 (D7) through bit 3 (D3) are user-defined values. Bit 2 (D2) and bit 1 (D1) are automatically given and contain the code of the interrupt-requesting channel having the highest priority. Table 3.4.3 shows the channel codes. Figure 3.4.12 shows the interrupt vector bit configuration.

| Bit 2 (D2) | Bit 1 (D1) | Channel number |               |
|------------|------------|----------------|---------------|
| 0          | 0          | 0              | (high)        |
| 0          | 1          | 1              | ↑             |
| 1          | 0          | 2              | Priority<br>↓ |
| 1          | 1          | 3              | (low)         |

Table 3.4.3 Channel Codes

140489



Figure 3.4.12 Interrupt Vector

### 3.4.6 Using CTC

[1] Counter Mode

The following describes how to use the CTC by referring to a program using channel 0 with interrupt disabled.

(a) The counter programming procedure is shown in Figure 3.4.13.



Figure 3.4.13 Counter Programming Procedure

(b) The block diagram for converting the 100 kHz system clock into the 10 kHz equivalent is shown in Figure 3.4.14.





(c) The channel control word configuration is shown in Figure 3.4.15.



Figure 3.4.15 Channel Control Word Configuration

- [2] Timer Mode
  - (a) The timer programming procedure with interrupt disabled is shown in Figure 3.4.16.



Figure 3.4.16 Timer Programming Procedure

(b) The block diagram for converting the 4 MHz system clock into the 1 kHz equivalent is shown in Figure 3.4.17.





(c) The channel control word is shown in Figure 3.4.18.





## 3.5 SIO OPERATIONAL DESCRIPTION

The SIO has two independent, programmable full-duplex serial ports. These ports are assigned addresses on the TMPZ84C013A's I/O map. This subsection mainly describes the operations that take place after accessing the SIO.

## 3.5.1 SIO Block Diagram



Figure 3.5.1 SIO Block Diagram

## 3.5.2 SIO System Configuration

As shown in Figure 3.5.1, the SIO consists of the MPU bus interface, the internal controller, the interrupt controller, and two independently operating full-duplex channels. Each channel has the read register, the write register, and the external controller which controls the connection with peripheral LSIs or external devices.

The TMPZ84C013A contains all the functions and pins of the 40-pin, DIP-type TMPZ84C40A (SIO/0), TMPZ84C41A (SIO/1), and TMPZ84C42A (SIO/2). However, when using the SIO of the TMPZ84C013A, the SIO/0, SIO/1, or SIO/2 must be used alone. The pin assignments are as shown in Figure 3.5.2.



MPUZ80-492

Table 3.5.1 shows the types and functions of the SIO registers. Each channel has 8 write registers and 3 read registers.

(1) Communication data path

Figure 3.5.3 shows the communication path of each channel's transfer data.

1 Receive operation

The receiver has an 8-bit receive register and a 3-stage 8-bit buffer register in FIFO configuration. This saves time in high-speed data block transfers. The receivers also have the receive error FIFO which holds the status information such as parity and framing errors. The receive data follow different paths according to the operation mode and character length as shown in Figure 3.5.3.

| Register                  | Function                                                         |
|---------------------------|------------------------------------------------------------------|
| Write<br>register 0 (WR0) | Resets CRC. Sets pointers of registers, and commands.            |
| Write<br>register 1 (WR1) | Sets the interrupt mode.                                         |
| Write<br>register 2 (WR2) | Sets the vector to be transmitted at interrupt. (Channel B only) |
| Write<br>register 3 (WR3) | Provides the parameters to control the receiver.                 |
| Write<br>register 4 (WR4) | Provides the parameters to control the receiver and transmitter. |
| Write<br>register 5 (WR5) | Controls the transmitter.                                        |
| Write<br>register 6 (WR6) | Sets the sync character or the SDLC address field.               |
| Write<br>register 7 (WR7) | Sets the sync character or the SDLC flag.                        |

| Table 3.5.1 ( | (a) | Write | Registers |
|---------------|-----|-------|-----------|
|---------------|-----|-------|-----------|

140489

| Table 3.5.1 | (b) | Read | Registers |
|-------------|-----|------|-----------|
|-------------|-----|------|-----------|

| Register                 | Function                                                       |
|--------------------------|----------------------------------------------------------------|
| Read<br>register 0 (RR0) | Indicates the receive/transmit buffer state and the pin state. |
| Read<br>register 1 (RR1) | Indicates the error status and the end-of-frame code.          |
| Read<br>register 2 (RR2) | Indicates the interrupt vector contents. (Channel B only)      |



Figure 3.5.3 Transfer Data Path (Channel A)

Asynchronous mode

In the asynchronous mode, the receive data enters the 3-bit buffer if the character length is 7 or 8 bits or the 8-bit receive shift register if the character length is 5 or 6 bits.

• Synchronous mode

In the synchronous mode, the data path depends on the receive processing phase at the time. The receiver operation starts from the hunt phase. In this mode, the receiver searches the receiver data for the bit pattern which matches the specified sync character. If the SIO is set in the monosync mode, the receiver searches for the bit pattern which matches the sync character set in WR7; if the SIO is set in the bisync mode, the receiver searches for the bit pattern which matches two consecutive sync characters set in WR6 and WR7. When synchronization has been established, the subsequent data enter the 3-bit buffer by bypassing the sync register.

SDLC mode

In the SDLC mode, the sync register constantly monitors the receive data perform-ing zero deletion as required. When the sync register detects 5 "1"s consecutively in the receive data, the following bit is deleted if it is "0". If it is "1", the bit that follows is checked. If it is "0", it is assumed as a flag, if it is "1", it is assumed an abort sequence (7 consecutive "1"s).

The reformatted data are put in the receive shift register via the 3-bit buffer. When synchronization has been established, the subsequent data follow the same path regardless of the character length.

2 Transmission

The transmitter has an 8-bit transmit data register and a 20-bit transmit shift register. The 20-bit transmit shift register holds the data from the WR6, WR7, and transmit data register.

Asynchronous mode

In the asynchronous mode, the data in the 20-bit transmit shift register are added with the start and stop bits to be sent to the transmit multiplexer.

• Synchronous mode

In the synchronous mode, the WR6 and WR7 hold the sync character. The contents of these registers are sent to the 20-bit transmit register as the sync character at the transmission of data blocks or as the idle sync character if a transmitter underrun occurs in data block transmission.

#### • SDLC mode

In the SDLC mode, the WR6 holds the station address and the WR7 holds the flag. The flag (WR7) is sent to the 20-bit transmit register at the start and end of each frame. For each of the other data fields, one "0" follows five consecutive "1"s.

#### (2) I/O functions

To transfer data from/to the MPU, the SIO must be set in the polling, interrupt, or block transfer mode.

Polling

To operate the SIO in the polling mode, all interrupts mode must be disabled. In the polling mode, the MPU reads the status bits D0 and D2 in each channel's RR0 to check for reception or transmission.

• Interrupts

There are 3 types of SIO interrupt: transmit interrupt, receive interrupt, and external/status interrupt. These interrupts can be enabled by program. The receive interrupt is further divided into the following three:

- Interrupt on the first received character
- Interrupt on all received characters
- Interrupt on special receive conditions

Higher priority is given to channel A than channel B. On the same channel, higher priority is given to reception, transmission, and external/status in this order.

The SIO provides the daisy-chained interrupt priority control feature and the interrupt vector generating feature. Further, it provides the "status affected vector" feature. This feature outputs 4 interrupts depending on the interrupt source.

Block transfer

The SIO has the block transfer mode to adapt to the MPU"s block transfer and the DMA controller. For block transfer, the  $\overline{W/RDY}$  line is used. For the MPU's block transfer, this line is used as the wait line; for the DMA block transfer, it is used as the ready line. The SIO's ready output indicates to the DMA controller that the data is ready to transfer. The SIO's wait output indicates to the MPU that the SIO is not ready for data transfer and therefore requesting the extension of the output cycle.

#### 3.5.3 SIO Basic Operations

(1)Asynchronous mode

> For data transfer in the asynchronous mode, the character length, clock rate, and interrupt mode must be set. These parameters are written in the write registers. Note that WR4 must be set before the other registers are set.

> Data transfer does not start until the transmit enable bit is set. When the auto enable bit is set, the SIO starts transmission upon the CTS pin's going "0", allowing the programmer to send a message to the SIO without waiting for the CTS signal. Figure 3.5.4 shows the data format of the asynchronous mode.



140489

Figure 3.5.4 Data Format of Asynchoronous Mode

1 Transmission

> Serial data are output from the TxD pin. Its transfer clock rate can be set to one of 1, 1/16, 1/32, and 1/64 times the clock rate to be supplied to the transmit clock input ( $\overline{\text{TxC}}$ ). The serial data are output on the falling edge of  $\overline{\text{TxC}}$ .

2 Reception

> The receive operation in the asynchronous mode starts when the receive enable bit (D0 of WR3) is set. When the receive data input RxD is set to "0" for the duration of at least 1/2 bit time, the SIO interprets it as the start bit, sampling the input data at the middle of the bit time. The sampling is performed on the rising edge of the  $\overline{RxC}$  signal.

> When the receiver receives the data whose character length is not 8 bits, it converts the data into the one composed of the necessary bits, the parity bit and the unused bit set to "1".

Example: a 6-bit character



When the external/status interrupt is enabled and a break state is detected in the receive data, the interrupt is generated and the break/abort status bit (D7 of RR0) is set and the SIO monitors the transmit data until the break state is cleared. The interrupt is also generated when the  $\overline{\text{DCD}}$  signal is in the inactive state for more than the specified pulse width. The DCD status bit is set to "1".

In the polling mode, the MPU must refer the receive character valid bit (D0 of RR0) to read the data. This bit is automatically reset when the receive buffer is read. In the polling mode, the transmit buffer status must be checked before writing data in the transmitter to avoid overwrite.

(2) Synchronous mode

There are 3 kinds of character synchronization : monosync, bisync, and external sync. In each of these synchronous modes, the times 1 clock rate is used for both transmission and reception. The receive data is sampled on the rising edge of the receive clock input ( $\overline{RxC}$ ). The transmit data changes on the falling edge of the transmit clock input.



Monosynchronous mode



**Bisynchronous mode** 



140489

Figure 3.5.5 Data Format of Synchronous Mode

## 1 Monosync

In this mode, synchronization is established when a match with the sync character (8 bits) set to WR7 is found, enabling data transfer.

2 Bisync

In this mode, synchronization is established when a match with 2 consecutive sync characters set to WR6 and WR7 is found, enabling data transfer. In this mode as well as the monosync mode <u>SYNC</u> is active during the receive clock period in which the sync character is being detected.

### 3 External sync

In this mode, synchronization is performed externally. When synchronization is established, it is indicated by the  $\overline{\text{SYNC}}$  pin. The  $\overline{\text{SYNC}}$  input must be kept to "0" until the character synchronization is lost. Character assembly starts from the rising edge of the  $\overline{\text{RxC}}$  after the falling of the  $\overline{\text{SYNC}}$ .

After reset, the SIO enters the hunt phase to search for the sync character. If synchronization is lost, the SIO sets the enter-hunt-phase-bit (D4 of WR3) to reenter the hunt phase.

- Transmission
- (a) Data transfer using interrupt

When the transmit interrupt is enabled, the interrupt is caused upon the transmit buffer's being emptied. For the interrupt processing, other data are written in the transmitter. If these data are not ready for some reason, the transmit underrun condition occurs.

(b) Bisync mode

In the bisync mode, if the transmitter runs out of data during transmission, supply characters are inserted. This is done in two methods. In one method, sync characters are inserted. In the other, characters generated so far are transmitted followed by sync characters. Either of these methods can be selected by the reset transmit underrun/EOM command in WR0.

(c) End of transmission

Break can be performed by setting bit D4 of WR5. When break is performed, the data in the transmit buffer and the shift register are lost. When the external/status interrupt is enabled, the SIO generates the interrupt depending on the transmitter state and outputs the vector. This mode can be used for block transfer.

- Reception
- (a) Interrupt on the first received character

This mode is used for ordinary block transfer. In this mode, the SIO generates the interrupt only for the first character;subsequently, it does not generate the interrupt unless special receive conditions are satisfied.

To initialize these settings, command 4 of WR0 (to be enabled by the next receive interrupt) must be set in advance.

(b) Interrupt on all received characters

In this mode, the SIO generates the interrupt for all characters coming into the receive buffer. When the status affect vector has been set, a special vector is generated on a special receive condition.

(c) Special receive condition interrupt

This interrupt occurs when any of the above interrupts is selected. The special receive conditions include parity error, receive overrun error, framing error, and end-of-frame (SDLC). These error status bits are latched, so that they must be reset after they are read. They can be reset by command 6 of WR0 (error reset).

(3) SDLC mode

The SIO supports both the SDLC and HDLC protocols. They resemble each other, so that only the SDLC mode is explained here.

Figure 3.5.6 shows the data format in the SDLC mode. In the SDLC mode, one data block is called a frame and the message in it is put between the open flag and the close flag. The address field in the frame contains the address of a secondary station. Checking this address, the SIO receives or ignores the frame.



Message direction

140489

Figure 3.5.6 Data Format in SDLC Mode

- Transmission
- (a) Data transfer using interrupt

When the transmit interrupt has been set, the interrupt occurs each time the transmit buffer becomes empty. In the SDLC mode, data are sent to the SIO by this interrupt.

(b) Data transfer using wait/ready

The wait function in the wait/ready capability is used to make the MPU extend the output cycle when the SIO's transmit buffer is not empty. The ready function indicates to the DMA that the SIO's transmit buffer is empty and therefore ready to receive data. If no data has been written in the transmit shift register before transmission, the SIO goes in the underrun state. This capability permits data transfer to the SIO.

### (c) Transmit underrun/EOM

The SIO automatically ends the SDLC frame if there is no data to be transmitted to the transmit data buffer. To implement this, the SIO sends a 2-byte CRC when there is no data to send, then the SIO transmits one or more flags. After reset, the transmit underrun/EOM status bit is set to prevent the CRC character from being inserted when there is no data to be sent. Using this function, the SIO starts frame transmission. Here, the transmit underrun/EOM reset command must be set in advance between the transmission of the first data and the data end. Thus, the SIO goes in the reset state at the end of each message with the CRC character being sent automatically.

(d) CRC generation

For CRC calculation, the CRC generator must be reset before transmission (bits D6 and D7 of WR0). CRC calculation starts when the address field is written in the SIO (WR6). The transmit CRC enable bit (D0 of WR5) must be set before the address field is written.

(e) End of transmission

When the transmitter is disabled during transmission, the data currently transmitted is all transmitted to its end. The subsequent data is put in the marking state. When the transmitter is disabled, characters remain in the buffer. However, the abort sequence is made active when the abort command is written in the command register, deleting all data.

Reception

As in the transmit mode, several parameters must be preset in the receive mode. The address field is written in WR7 and the flag character in WR7. Receiving the open flag, the receiver compares the contents of the following address field with the address set in WR6 or the global address ("1111 1111"). If the contents of the address field in frame matches either of these address, the SIO starts reception.

(a) Interrupt on the first received character

This mode is generally used for the block transfer using the wait/ready capability. In this mode, the SIO generates the interrupt only on the first character. The status flag of this interrupt is latched, so that command 4 (to be enabled by the next received character) of WR0 must be preset for re-initialization. When the external/status interrupt is set, an interrupt occurs every time the  $\overline{DCD}$  changes. This interrupt also occurs when the special receive condition is satisfied.

(b) Interrupt on all received characters

In this mode, the SIO generates an interrupt on all received characters. When the status affect vector has been set, the SIO generates a special vector on the special receive condition interrupt.

(c) Special receive condition interrupt

Using the special receive condition, the interrupt on the first received character or the interrupt on all received characters must be selected in advance. The receive overrun status of the special receive condition interrupt is latched. The status bit can be reset by the error reset command (WR0 command).

(d) CRC check

The receive CRC check is reset when the open flag at the head of a frame is received. CRC calculation is performed on the subsequent characters up to the close flag. In the SDLC mode, the transmit CRC is inverted, so that a special check sequence is used. The check must end with "0001 1101 0000 1111." Since SIO handles the CRC character as a data, the MPU must discard it after reading it.

(e) End of transmission

When the SIO receives the close flag, the end-of-frame-bit is set to indicate that the close flag has been received. When the status affect vector has been set, the special receive condition interrupt occurs and the interrupt vector is output. Any frame can be aborted by abort transmission. When the external/status interrupt has been set, the interrupt occurs and the break/abort bit in RR0 is set.

## 3.5.4 SIO Status Transition Diagram and Basic Timing

[1] Status Transition Diagram

Figure 3.5.7 shows the SIO status transition diagram.



Figure 3.5.7 (a) SIO Status Transition Diagram











MPUZ80-506

## [2] Basic Timing

Figure 3.5.8 shows the timing in which data or a command is written from the MPU to the SIO. Figure 3.5.9 shows the timing in which data is read from the SIO to the MPU. Figure 3.5.10 shows the interrupt acknowledge timing in which the MPU gives an interrupt response to the SIO's interrupt request to set the  $\overline{IORQ}$  pin to "0" several clocks after setting the  $\overline{M1}$  pin to "0" as the acknowledge signal. To maintain the interrupt serviced state in daisy chain structure, the interrupt request state cannot be changed while  $\overline{M1}$  is active.

Figure 3.5.11 shows the timing in which the return from interrupt is performed.

Figure 3.5.12 shows how the daisy chain structure works. First, suppose that the SIO is servicing interrupt. When the PIO issues an interrupt request immediately before the first byte "EDH" of the RETI instruction is decoded with  $\overline{\text{M1}}$  being active, "IEO" of the PIO goes "0". However, when "EDH" is decoded, the PIO's interrupt request is not acknowledged. Therefore, the PIO's "IEO" returns to "1". When the second byte "4DH" is decoded, the SIO's "IEO" of each peripheral LSI at this point of time all go "1", or out of the interrupt serviced state. The PIO keeps the  $\overline{\text{INT}}$  pin at "0" until this state is set. Then, the interrupt is serviced starting with the peripheral device of the higher priority.





TMPZ84C013A





MPUZ80-508

1 The SIO has made an interrupt request



2 The SIO is servicing the interrupt.



3 The PIO has made an interrupt request immediately before "EDH" is decoded by the SIO. By the PIO's interrupt request, PIO's IEO is set to "0".



4 Because "EDH" has been decoded, the PIO's interrupt request is not acknowledged. Therefore, PIO's IEO returns to "1".



5 Because "4DH" has been decoded, the SIO's IEO is set to "1".



6 The PIO's interrupt request is acknowledged and the PIO's IEO is set to "0".





## 3.5.5 SIO Operational Procedure

The following mainly describes the meaning of each bit of the write and read registers. Special attention should be directed to the fact that the parameters of the write register (WR4) should be set before the others.

Some registers can use only a signal channel. The I/O addresses listed in Table 3.5.2 must be specified to write the control word and read/write data on the SIO.

| I/O function                                                               | I/O address              |
|----------------------------------------------------------------------------|--------------------------|
| Channel A data<br>Channel A command<br>Channel B data<br>Channel B command | #18<br>#19<br>#1A<br>#1B |
|                                                                            |                          |

## Table 3.5.2 I/O Addresses

140489

### [1] Write Registers

1 WR 0; Write register 0

Table 3.5.3 Configuration of Write Register 0

| D7             | D6 | D5                  | D4 | D3 | D2                   | D1 | D0 |  |
|----------------|----|---------------------|----|----|----------------------|----|----|--|
| CRC reset code |    | Primary command bit |    |    | Register pointer bit |    |    |  |
|                | L  |                     |    |    |                      |    |    |  |

140489

## Bits D0 through D2: Register pointer bits

These bits specify the register on which read/write is performed by the next byte. When read/write is completed, the register pointer points to WR0.

## Bits D3 through D5: Basic command bits

• Command 0 (=000): No operation

This command only sets the register pointer without making the SIO operate. It is used to invalidate the command in the command chain for the SIO or hold the location at which a command is inserted in the command chain if required.

• Command 1 (=001): Abort sequence generation

This command is used to generate the abort sequence (7 or more consecutive "1"s). Note that command 1 is used only in the SDLC.

• Command 2 (=010): External/status interrupt reset

Once an external interrupt or a status interrupt has occurred, the status bit of RRO is latched. This command is issued to enable the RRO's status bit in order to enable the interrupt again.

• Command 3 (=011): Channel reset

This command performs generally the same operation as when the RESET pin is set. The difference is that reset is performed only on a single channel. The command for channel A resets the interrupt priority circuit as well.

• Command 4 (=100): Enable the interrupt at the next character reception.

This command is used to enable an interrupt when the end of data block has been detected followed by the reception of the next block.

• Command 5 (=101): Reset transmit interrupt pending

If the transmit buffer becomes empty in the transmit interrupt enable mode, an interrupt occurs. This command is used to disable the transmit interrupt when there is no data in the transmit buffer.

• Command 6 (=110): Error reset

The error (parity or overrun error) caused in block transfer is latched in bits D4 and D5 of RR1. This commands is used to clear these bits.

• Command 7 (=111): Return from interrupt

This command performs the same operation as the operation required to execute the RETI instruction on the SIO's data bus. Therefore, non-Z80 MPUs (that is, systems using no RETI instruction) can use the daisy chain in the SIO. This command is available only on channel A.

#### Bits D6 and D7: CRC reset code

These 2 bits allow the programmer to select between the receive CRC checker reset, the transmit CRC generator reset, and the transmit underrun/EOM reset.

| Rest command                     | D7 | D6     |
|----------------------------------|----|--------|
| No operation                     | 0  | 0      |
| Reset the receive CRC checker    | 0  | 1      |
| Reset the transmit CRC generator | 1  | 0      |
| Reset the transmit underrun/EOM  | 1  | 1      |
|                                  |    | 140490 |

|  | Fable 3.5.4 | List of Reset | Command Codes |
|--|-------------|---------------|---------------|
|--|-------------|---------------|---------------|

## 2 WR 1; Write register 1

## Table 3.5.5 Configuration of Write Register 1

| D7                                                          | D6         | D5   | D4           | D3                | D2        | D1                     | D0                  |
|-------------------------------------------------------------|------------|------|--------------|-------------------|-----------|------------------------|---------------------|
|                                                             | Wait/ready |      | Rece         | iving             | Status    | Enable<br>transmission | Enable<br>external/ |
| Select<br>Select receiving/<br>Enable function transmission |            | inte | rrupt<br>ode | -affect<br>vector | interrupt | status<br>interrupt    |                     |

140489

#### Bit D0: External/status interrupt enable

When this bit is set, an interrupt is generated at the start of sync character transmission even if the execution is terminated upon detection of break/abort, the  $\overline{\text{DCD}}$ ,  $\overline{\text{CTS}}$  or  $\overline{\text{SYNC}}$  signal has changed, or the transmit underrun/EOM latch is set.

#### Bit D1: Transmit interrupt enable

When this bit is set, a transmit interrupt is generated upon the transmit buffer becoming empty.

## Bit D2: Status affect vector

When this bit is set, bits D1 through D3 (V1 through V3) of WR2 is changed. When this bit is not set, the same interrupt vector as the contents of WR2 issued. Note that this bit is available only on channel B.

### Bits D3 and D4: Receive interrupt mode

These bits are used to select a receive interrupt mode.

### Bits D5 through D7: Selection wait/ready functions

These 3 bits are used to select a  $\overline{W/RDY}$  pin function. The wait or the ready function is selected by program and they are not used simultaneously. The meaning of these bits are:

- When D5 is set to "1", it indicates that the W/RDY pin responds to the receive buffer; when D5 is reset to "0", it indicates that the pin responds to the transmit buffer.
- When D6 is set to "1", the W/RDY pin functions as the READY pin; when D6 is reset to "0", the pin functions as the WAIT pin.
- When D7 is set to "1", the wait/ready function is enabled; when D7 is reset to "0", the function is disabled.

For example, when D7, D6, and D5 are "1", "1", and "0" respectively, and the transmit buffer is full, the  $\overline{\text{READY}}$  pin goes "1"; when the transmit buffer is empty, the pin goes "0".

Table 3.5.6 shows the summary of the above description of bits D3 and D4 and D5 through D7.

| Receive interrupt mode                                                                  | D4 | D3     |
|-----------------------------------------------------------------------------------------|----|--------|
| Receive interrupt disable                                                               | 0  | 0      |
| Interrupt on first received character or special receive condition*                     | 0  | 1      |
| Interrupt on received character or special receive condition*                           | 1  | 0      |
| Interrupt on received character or special receive condition* (except for parity error) | 1  | 1      |
|                                                                                         |    | 140489 |

| Table 3.5.6 | List of Receive | Interrupt | Mode | Codes |
|-------------|-----------------|-----------|------|-------|
|-------------|-----------------|-----------|------|-------|

Special receive conditions: • End of frame (in SDLC mode only)

- Receive overrun error
- Parity error
- Framing error

|             |                                                                    | Tuble 3.5.7 | Walancady Sciect i anetion (BS tinoagh B                       | • , |    |    |
|-------------|--------------------------------------------------------------------|-------------|----------------------------------------------------------------|-----|----|----|
| Pin state   |                                                                    | 2           | ñ (f. ).                                                       |     | DC |    |
| Pin (Fu     | nction)                                                            | Pin output  | Butter state                                                   | D7  | D6 | D2 |
| DISABLE     | WAIT                                                               | Floating    | _                                                              |     | 0  |    |
|             | READY High —                                                       |             | U                                                              | 1   | -  |    |
| ENABLE      | WAIT                                                               | Low         | The transmit buffer is full and the SIO data port is selected. |     | 0  |    |
|             | Floating The transmit buffer is empty.                             |             |                                                                |     | 0  |    |
|             | READY High The transmit buffer is full.                            |             |                                                                |     |    |    |
|             |                                                                    | Low         | The transmit buffer is empty.                                  | 1   | 1  |    |
| WAIT Floati |                                                                    | Floating    | The receive buffer is full.                                    |     |    |    |
|             | Low The receive buffer is empty and the SIO data port is selected. |             |                                                                | 0   |    |    |
|             | READY Low The receive buffer is full.                              |             |                                                                | 1   | 1  |    |
|             | High T                                                             |             | The receive buffer is empty.                                   |     | 1  |    |

# Table 3.5.7 Wait/Ready Select Function (D5 through D7)



This write register is the interrupt vector register. When bit D2 of WR1 (B channel) is not set, the interrupt vector is issued. When bit D2 of WR1 (B channel) is set, bits D1 through D3 (V1 through V3) are changed depending on the interrupt generation condition. This time, the contents of WR2 remain unchanged. Because WR2 is available only on channel B, WR2 must be programmed even if only channel A of the SIO is used.

Table 3.5.9 shows the WR2 bit states in the interrupt condition with the status affect vector being set.

| Channel | Interrupt condition          | V3 | V2 | V1     |
|---------|------------------------------|----|----|--------|
|         | Transmit buffer empty        | 0  | 0  | 0      |
| р       | Change of external/status    | 0  | 0  | 1      |
| В       | Received character available | 0  | 1  | 0      |
|         | Special receive condition*   | 0  | 1  | 1      |
|         | Transmit buffer empty        | 1  | 0  | 0      |
| ۸       | Change of external/status    | 1  | 0  | 1      |
| А       | Received character available | 1  | 1  | 0      |
|         | Special receive condition*   | 1  | 1  | 1      |
|         |                              |    |    | 140489 |

| Table 3.5.9 | Channel Inte | errupt Condition | Codes |
|-------------|--------------|------------------|-------|
|             |              |                  |       |

\* Special receive conditions:

• End of frame (in SDLC mode only)

• Receive overrun error

Parity error

Framing error

## 4 WR 3; Write register 3

## Table 3.5.10 Configuration of Write Register 3

| D7              | D6               | D5             | D4                     | D3                                      | D2                        | D1                                           | D0                  |
|-----------------|------------------|----------------|------------------------|-----------------------------------------|---------------------------|----------------------------------------------|---------------------|
| Receiv<br>/char | ing bit<br>acter | Auto<br>enable | Enter<br>hunt<br>phase | Enable<br>receiving<br>CRC              | Address<br>search<br>mode | Prohibit<br>synchronous<br>character<br>load | Enable<br>receiving |
| <b>.</b>        |                  |                |                        | ••••••••••••••••••••••••••••••••••••••• |                           |                                              | 140489              |

### Bit D0: Receive enable

When this bit is set, the receive operation starts. Because this bit is used to start the receive operation, it must be set after the receive-associated programming has been all completed.

### Bit D1: Sync character load inhibit

When this bit is set in the sync mode, the sync character is not loaded into the receive buffer. This bit is used to remove the sync character and idle sync from the received characters.

### Bit D2: Address search mode

When this bit is set in the SDLC mode, any message having a programmed address or an address other than the global address (FFH) is not received by WR6. Therefore, the receive interrupt does not occur unless an address match occurs.

### Bit D3: Receive CRC enable

When this bit is set, CRC calculation starts at the start of the last data transfer from the receive shift register to the receiver buffer.

### Bit D4: Enter hunt Phase

When the establishment of synchronization is required, set this bit to enter the SIO into the hunt phase. The hunt phase is automatically cleared upon establishment of synchronization.

### Bit D5: Auto enable

When this bit is set, the transmitter is enabled at the time the  $\overline{\text{CTS}}$  pin is "0". When the  $\overline{\text{DCD}}$  pin is "0", the receiver is enabled.

## Bits D6 and D7: Receive character length

These bits are used to specify the number of receive bits which make up one character (character length). Table 3.5.11 shows the number of bits per character.

| Bits/character | D7 | D6 |
|----------------|----|----|
| 5              | 0  | 0  |
| 7              | 0  | 1  |
| 6              | 1  | 0  |
| 8              | 1  | 1  |

Table 3.5.11 Receive Character Length Codes

140489

## 5 WR 4; Write register 4

Table 3.5.12 Configuration of Write Register 4

|            | D7 | D6               | D5 | D4       | D3 | D2     | D1       | D0     |
|------------|----|------------------|----|----------|----|--------|----------|--------|
| Clock mode |    | Synchronous mode |    | Stop bit |    | Parity |          |        |
|            |    |                  |    |          |    |        | Even/Odd | Enable |

140489

### Bit D0: Parity enable

When this bit is set, 1-bit transmit data is added to the number of bits specified by D6 and D7 of WR3 and the data is received in the resulting number of bits. If a character length other than 8 bits is selected, the added parity bit is set to the MSB side to be transferred to the receive data FIFO. When the 8-bit character length is selected, the parity bit is not transferred to the receive data FIFO.

#### Bit D1: Parity even/odd

This bit is used to determine whether to perform transfer and check in even or odd parity. (Even parity = "1", odd parity = "0")

#### Bit D2 and D3: Stop bit length

These bits are used to select the stop bit length in the asynchronous mode. In the synchronous mode, both D2 and D3 must be set to "0".

| top bit                 | D3 | D2     |
|-------------------------|----|--------|
| Sync mode               | 0  | 0      |
| 1 stop bit/character    | 0  | 1      |
| 1.5 stop bits/character | 1  | 0      |
| 2 stop bits/character   | 1  | 1      |
|                         |    | 140489 |

Table 3.5.13 Stop Bit Length Codes

### Bits D4 and D5: Sync mode

These bits are used to select the sync mode.

| Sync mode                       | D5  | D4     |
|---------------------------------|-----|--------|
| 8-bit sync mode                 | 0   | 0      |
| 16-bit sync mode (bisync mode)  | / 0 | 1      |
| SDLC mode (flag character; 7EH) | 1   | 0      |
| External sync mode              | 1   | 1      |
|                                 |     | 140489 |

Table 3.5.14 Sync Mode Codes

### Bits D6 and D7: Clock mode

These bits are used to select the factor between the transmit/receive clock and the data transfer rate. In the synchronous mode, the  $\times 1$  clock mode must be set. In the asynchronous mode, the transmit side and the receive side must have the same factor.

| Clock mode<br>(data transfer rate) | D7 | D6 |
|------------------------------------|----|----|
| × 1 data transfer rate             | 0  | 0  |
| × 16 data transfer rate            | 0  | 1  |
| × 32 data transfer rate            | 1  | 0  |
| × 64 data transfer rate            | 1  | 1  |

Table 3.5.15 Clock Mode Codes
### 6 WR 5; Write register 5

Table 3.5.16 Configuration of Write Register 5

| D7  | D6              | D5               | D4                    | D3                     | D2              | D1  | D0                         |
|-----|-----------------|------------------|-----------------------|------------------------|-----------------|-----|----------------------------|
| DTR | Transn<br>/char | nit bit<br>acter | Break<br>transmission | Enable<br>transmission | CRC-16<br>/SDLC | RTS | Enable CRC<br>transmission |

140489

#### Bit D0: Transmit CRC enable

When this bit is set at the time the transmit data is loaded from the transmit data buffer into the transmit shift register, the CRC calculation is performed on that data. If this bit is not set, the CRC calculation and transmission are not performed in the transmit underrun state in the synchronous or SDLC mode.

#### Bit D1: Request to send

When this bit is set, the RTS pin goes "0". When this bit is not set, the RTS pin goes "1". In the asynchronous mode, the RTS pin goes "1" when the transmit buffer becomes empty. In the synchronous or SDLC mode, this bit state is followed by the RTS pin state.

#### Bit D2: CRC-16/SDLC

When this bit is set, the CRC-16 polynomial  $(X^{16} + X^{15} + X^2 + 1)$  is selected. When this bit is reset to "0", the CRC-CCITT polynomial  $(X^{16} + X^{12} + X^5 + 1)$  is selected.

#### Bit D3: Transmit enable

When this bit is set, the transmitter is enabled. Even if this bit is reset to "0" after the start of transmission, the sync character and the data being transmitted are transmitted to the last.

#### Bit D4: Transmit break

When this bit is set, transmitting any data forcibly puts the transmit data line (TxD pin) in the space state. When this bit is reset to "0", the TxD pin is put in the marking state.

### Bits D5 and D6: Transmit character length

These bits indicate the character length of transmit data.

|                  |    | -      |
|------------------|----|--------|
| Bits/character   | D6 | D5     |
| Less than 5 bits | 0  | 0      |
| 7 bits           | 0  | 1      |
| 6 bits           | 1  | 0      |
| 8 bits           | 1  | 1      |
|                  |    | 140489 |

| Table 3.5.17 | <b>Transmit Character</b> | Length | Codes |
|--------------|---------------------------|--------|-------|
|              |                           |        |       |

As shown in Table 3.5.17, for the transmission of less than 5 bits (4 bits or 3 bits) per character, D6 and D5 are "0" and "0", which do not indicate how many bits the transmit data consists of. To solve this problem, the data characters must be processed by the format shown in Table 3.5.18. Note that D indicates data.

| Table 3.5.18 | Data | Transfer F | ormat | with 1 | [ransmit] | Data | Consisting | of Less than | ו 5 bits |
|--------------|------|------------|-------|--------|-----------|------|------------|--------------|----------|
|              |      |            |       |        |           |      |            |              |          |

| Transmit bits/character | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|-------------------------|----|----|----|----|----|----|----|----|
| 1                       | 1  | 1  | 1  | 1  | 0  | 0  | 0  | D  |
| 2                       | 1  | 1  | 1  | 0  | 0  | 0  | D  | D  |
| 3                       | 1  | 1  | 0  | 0  | 0  | D  | D  | D  |
| 4                       | 1  | 0  | 0  | 0  | D  | D  | D  | D  |
| 5                       | 0  | 0  | 0  | D  | D  | D  | D  | D  |

140489

#### Bit D7: Data terminal ready

This bit indicates the  $\overline{\text{DTR}}$  pin state. When this bit is set, the  $\overline{\text{DTR}}$  pin goes "0", when it is reset, the  $\overline{\text{DTR}}$  pin goes "1".

## 7 WR 6; Write register 6

| D7 | D6 | D5 | D4  | D3 | D2 | D1 | D0     |
|----|----|----|-----|----|----|----|--------|
|    |    |    | SYI | NC |    |    |        |
| 7  | 6  | 5  | 4   | 3  | 2  | 1  | 0      |
|    | L  |    |     | L  | [] |    | 140489 |

### Table 3.5.19 Configuration of Write Register 6

This register is programmed as follows:

- In the external sync mode : Transmit sync character
- In the monosync mode : Transmit sync character
- In the bisync mode : First sync character
- In the SDLC mode : Slave station address

### 8 WR 7; Write register 7

#### Table 3.5.20 Configuration of Write Register 7

| D7        | D6        | D5        | D4        | D3        | D2        | D1       | D0       |  |  |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|--|--|
| SYNC      |           |           |           |           |           |          |          |  |  |
| 15<br>(7) | 14<br>(6) | 13<br>(5) | 12<br>(4) | 11<br>(3) | 10<br>(2) | 9<br>(1) | 8<br>(0) |  |  |

This register is programmed as follows:

- In the monosync mode : Receive sync character
- In the bisync mode : Second sync character
- In the SDLC mode : Flag character (7EH)

This register is not used in the external sync mode.

#### [2] Read Registers

1 RR 0; Read register 0

#### Table 3.5.21 Configuration of Read Register 0

| D7              | D6                              | D5  | D4                   | D3  | D2                          | D1                   | D0                                  |
|-----------------|---------------------------------|-----|----------------------|-----|-----------------------------|----------------------|-------------------------------------|
| Break/<br>Abort | Trasmission<br>underrun/<br>EOM | CTS | Synchronize<br>/Hunt | DCD | Trasmission<br>buffer empty | Interrupt<br>pending | Receiving<br>character<br>effective |
|                 |                                 |     |                      |     |                             |                      | 140489                              |

Used with the external/status interrupt

#### Bit D0: Receive character available

This bit is set when the receive buffer holds characters of 1 byte or more. This bit is reset when the buffer becomes empty.

### Bit D1: Interrupt pending

This bit is set when an interrupt occurs in the SIO regardless of the interrupt condition type. This bit is available only on channel A.

#### Bit D2: Transmit buffer empty

This bit is set when the transmit data buffer becomes empty or the SIO is reset. However, in the sync and SDLC modes where the CRC character is being transmitted, bit D2 is reset.

### Bit D3: Data carrier detect

This bit indicates the  $\overline{\text{DCD}}$  pin input state. This bit is latched when the external/status interrupt occurs.

### Bit D4: Sync/hunt

The meaning of this bit depends on the operation mode:

(i) Asynchronous mode

Bit D4 indicates the SIO's <u>SYNC</u> pin state. When the <u>SYNC</u> pin state changes, the external/status interrupt occurs.

(ii) External sync mode

When synchronization has been established by the detection of external synchronization, the last bit of the sync character must be set to "0" at the second  $\overline{RxC}$  falling edge from the rising edge of the received  $\overline{RxC}$ . That is, to set the  $\overline{SYNC}$  input to "0" by the external circuit after the detection of synchronization, full 2 receive cycle clocks must be awaited.

When the <u>SYNC</u> input goes "0", the sync hunt bit is set. When synchronization is lost or the end of message is detected, the enter hunt phase bit is set.

(iii) Internal sync mode

In the monosync and bisync modes, bit D4 is initialized to "1" by the enter hunt phase command (D4 of WR3). This bit is reset when the SIO detects the sync character.

(iv) SDLC mode

Bit D4 is set when the receiver is disabled or the enter hunt phase command is issued. Then, when the frame open flag is detected, this bit is reset.

### Bit D5: Clear to send

This bit indicates the opposite of the  $\overline{\text{CTS}}$  pin input state.

### Bit D6: Transmit underrun/EOM

This bit is set when the SIO is reset (including channel reset). Only the reset transmitter underrun/EOM latch command (WR0 bits D7, D6 = "1", "1") can reset this bit. When the transmit underrun state occurs, the external/status interrupt is generated. Bit D5 is also used to control transmission in the sync or SDLC mode.

# TOSHIBA

### Bit D7: Break/abort

In the asynchronous mode in reception, this bit indicates the break state detection. When the break state is detected, this bit is set, generating the external/status interrupt. This bit is reset by the external/status interrupt reset command.

After break, the external/status interrupt is generated again. In the SDLC mode, bit D7 is set when the abort sequence is detected, generating the external/status interrupt.

2 RR 1; Read register 1

| D7              | D6               | D5                            | D4              | D3 | D2       | D1 | D0                        |
|-----------------|------------------|-------------------------------|-----------------|----|----------|----|---------------------------|
| End of<br>frame | framing<br>error | Receiving<br>overrun<br>error | Parity<br>error |    | Fraction |    | Feed<br>all<br>characters |
|                 |                  |                               |                 |    |          |    | 140489                    |

Table 3.5.22 Configuration of Read Register 1

### Bit D0: All sent

In the asynchronous mode, this bit is set when all characters are sent from the transmitter or there is no transmit data in the SIO. In the synchronous mode, this bit is always set.

### Bits D1 through D3: Fraction codes

Normally, I field is an integral multiple of character length. If it is not, these bits show the number of fraction bits. These codes are effective only for the transmission for which the end of frame bit is set in the SDLC mode.

Example : Figure 3.5.13 shows examples of fractions in which the number of bits/character at the end of I field is 8 bits (1) and 4 bits (2).



Figure 3.5.13 Examples of Fraction Bits in I Field

Table 3.5.23 (a) shows the fraction codes for the receive character whose character length is 8 bits.

| •                  | •                      | ,  |    |        |  |
|--------------------|------------------------|----|----|--------|--|
| Number of fraction | bits at end of I field | 50 | 20 | D1     |  |
| 1 byte before      | 2 bytes before         | 03 | Dz |        |  |
| 0                  | 3                      | 1  | 0  | 0      |  |
| 0                  | 4                      | 0  | 1  | 0      |  |
| 0                  | 5                      | 1  | 1  | 0      |  |
| 0                  | 6                      | 0  | 0  | 1      |  |
| 0                  | 7                      | 1  | 0  | 1      |  |
| 0                  | 8                      | 0  | 1  | 1      |  |
| 1                  | 8                      | 1  | 1  | 1      |  |
| 2                  | 2 8                    |    | 0  | 0      |  |
|                    |                        |    |    | 140489 |  |

Table 3.5.23 (a) Bit Patterns by Fraction Bits at End of I Field

The same table can also be provided for each character length when the receive character length of I field is other than 8 bits.

|                  | ,  | (  | ,      |
|------------------|----|----|--------|
| Bits/character   | D3 | D2 | D1     |
| 5 bits/Character | 0  | 0  | 1      |
| 6 bits/Character | 0  | 1  | 0      |
| 7 bits/Character | 0  | 0  | 0      |
| 8 bits/Character | 0  | 1  | 1      |
|                  |    |    | 140489 |

Table 3.5.23 (b) Bit Patterns by Number of Bits (Character (No Fractions)

#### Bit D4: Parity error

This bit is latched when the parity select bit (D0 of WR4) is set and a parity error is detected in the receive data. Latch can be cleared by the error reset command (WR0 bits D5, D4, D3 = "1", "1", "0").

#### Bit D5: Receive overrun error

The receive data FIFO holds up to 3 characters. When more characters are received without read out by the MPU, the excess character is set to the receive FIFO. When this character is read by the MPU, this receive overrun error is set. Once set, bit D5 latches that state. When the error reset command (command 6 of WR0 bits D3 through D5) is written, this bit is also reset.

#### Bit D6: CRC/framing error

In the asynchronous mode, this bit is set when a framing error is detected in the received character. Because this bit is not latched, it is always updated.

In the synchronous and SDLC modes, this bit indicates the transmitted CRC check result. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written.

#### Bit D7: End of frame

This bit is set when the end flag is detected in the receive data and the CRC check and the fraction code are found normal. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written. This bit is used only in the SDLC mode and is updated when the first character of the next frame is received.



When the status affect vector bit (D2 of WR1 (Channel B)) is set, bits V3 through V1 are changed depending on the interrupt condition at the time. The vector to be read is determined by the interrupt condition having the highest priority at the time of read. When the status affect vector bit is reset, the contents of this register are the same as those of WR2.

### 3.5.6 Using SIO

The following describes some system examples using the SIO. Figure 3.5.14 shows an inter-processor communication system. In this example, the MPU on the left side controls the data transfer with the modules on the right side. Both diagrams shown in Figure 3.5.14 (a) and (b) are communication systems. As shown, the SIO is used to interface with external devices in data communication. The greatest advantage of the SIO is the smaller number of data lines than parallel communication.



Figure 3.5.14 (a) Example of Data Communication Between Processors



Figure 3.5.14 (b) Example of Data Communication Between Processor

#### 3.6 STANDBY CAPABILITY

When a HALT instruction is executed, the TMPZ84C013A is put in one of the Run, Idle-1, Idle-2, or Stop mode depending on the contents of the halt mode setting register (#F0 : bit 4, bit 3 : HALTMR). (However, the TMPZ84C013A is put in the Run mode immediately after the reset operation by the RESET pin.) The halt mode setting register is set as follows. For the description and timing of each mode, see Subsection 3.3 "CGC Operations."

The halt mode setting register is assigned to bits 4 and 3 of address F0 in the I/O address area. The halt mode is released by the interrupt (the nonmaskable interrupt by the  $\overline{\text{NMI}}$  pin or the maskable interrupt by the  $\overline{\text{INT}}$  pin) or by the reset through the RESET pin. A maskable interrupt is accepted when the MPU is in the EI state (in the state after the execution of EI instruction). A nonmaskable interrupt is accepted, the interrupt processing starts.

When the MPU is in the DI state (after the reset operation and the execution of DI instruction) with maskable interrupt, the TMPZ84C013A returns to the halt mode after executing a HALT instruction (actually a NOP instruction).

#### 3.6.1 Setting Halt Mode

Duplicate control is provided to prevent the stop of the watchdog timer operation which may be caused by the halt mode setting error due to program runaway.

The halt mode is set by the halt mode setting register (HALTMR) and the halt mode control register (#F1: bits 7 through 0: HALTMCR). Figure 3.6.1 shows the contents of the halt mode control register (HALTMCR). Figure 3.6.2 shows the contents of the halt mode setting register (HALTMR).



Figure 3.6.2 Halt Mode Setting Register (HALTMR)

Figure 3.6.3 shows the device states in the halt state with the CLKOUT pin connected to the CLKIN pin.

| MODE  | CGC | MPU | стс | SIO | Watchdog<br>Timer (WDT) | CLKOUT<br>PIN |
|-------|-----|-----|-----|-----|-------------------------|---------------|
| IDLE1 | 0   | ×   | ×   | ×   | ×                       | ×             |
| IDLE2 | 0   | ×   | 0   | ×   | ×                       | 0             |
| STOP  | ×   | ×   | ×   | ×   | ×                       | ×             |
| RUN   | 0   | 0   | 0   | 0   | 0                       | 0             |

140489

 $\bigcirc$  ……Operating (CLKOUT and CLKIN must be connected.)  $\times$  ……Stop

Note: CLK OUT and CLK IN must be connected.

Figure 3.6.3 Device States in Halt State

For the halt mode in which the clock is supplied from the CLKIN pin (with the CGC oscillator unused), the Run mode must be used.

### 3.6.2 Halt Mode Setting Procedure

After reset, the halt mode is changed to the Run mode. Figure 3.6.4 shows the procedure to set a new mode.



Figure 3.6.4 Setting Halt Mode

# TOSHIBA

## 3.7 WATCHDOG TIMER

The watchdog timer (WDT) detects an operation error caused by the program runaway to return to the normal operation.

### 3.7.1 Block Diagram of Watchdog Timer

Figure 3.7.1 shows the block diagram of the watchdog timer.



Figure 3.7.1 Block Diagram of Watchdog Timer

# 3.7.2 Setting watchdog Timer

(1) Enabling the watchdog timer

The watchdog timer can be set by the watchdog timer enable register (#F0: bit 7: WDTER) and the watchdog timer periodic register (#F0: bit 6, bit 5: WDTPR).



Figure 3.7.2 Enabling Watching Timer

### (2) Disabling the watchdog timer

The watchdog timer can be disabled by disabling the watchdog timer enable register (WDTER) then writing data "B1" in the watchdog timer control register (#F1 : bit 7 through bit 0 : WDTCR).

This function has a duplicate structure to prevent the watchdog timer setting error, which may lead to the watchdog timer operation stop, caused by program runaway.



Figure 3.7.3 Disabling Watchdog Timer

### (3) Clearing the watchdog timer

The watchdog timer can be cleared by writing data "4E" in the watchdog timer control register (WDTCR).



Figure 3.7.4 Cleaning The Watchdog Timer



Figure 3.7.5 Reading Watchdog Timer Setting Register

3.7.3 Watchdog Timer Output

When the enabled watchdog timer is used, the "0" level signal is output to the  $\overline{\text{WDTOUT}}$  pin after the duration of time specified in the watchdog timer periodic register (WDTPR). The output pulse width is one of the following two types depending on the  $\overline{\text{WDTOUT}}$  pin connection :

- (1) The WDTOUT connected to the RESET pin: The "0" level pulse of 5TcC (system clock) is output.
- (2) The WDTOUT connected to a pin other than RESET pin : The "0" level pulse is kept output until the watchdog timer is cleared by software or reset by the RESET pin.

### 3.8 INTERRUPT PRIORITY

The programmable interrupt priority register (#F4 : bits 2 through 0 : INTPR) is provided to determine the interrupt priority for the CTC, SIO, in the TMPZ84C013A.

## 3.8.1 Setting Interrupt Priority

Figure 3.8.1 shows the register to determine the daisy chain interrupt priority for the CTC, SIO.



Figure 3.8.1 Interrupt Priority Register (INTPR)

## [Example]

When "001" is written in address F4 (INTPR), the daisy chain interrupt priority is given as shown in Figure 3.8.2.

External pull up



Figure 3.8.2 Daisy Chain Interrupt Priority

# TOSHIBA

# 4. ELECTRICAL CHARACTERISTICS

## 4.1 MAXIMUM RATINGS

| SYMBOL       | ITER                                    | VI                   | RATING          |
|--------------|-----------------------------------------|----------------------|-----------------|
| VCC          | Vcc Supply Voltage with resp            | pect to Vss          | – 0.5V to 7V    |
| VIN          | Input Voltage                           | – 0.5V to VCC + 0.5V |                 |
| PD           | Power Dissipation (6MHz VI<br>(8MHz VI  | 250mW                |                 |
| TSOLDER      | Soldering Temperature (Solo             | dering Time 10sec)   | 260°C           |
| TSTG         | Storage Temperature                     |                      | – 55°C to 125°C |
| торр         | TORD Operating Temperature 6MHz VERSION |                      | – 40°C to 85°C  |
| 8MHz VERSION |                                         |                      | – 10°C to 70°C  |

030489

### 4.2 DC ELECTRICAL CHARACTERISTICS

6MHz VERSION : TOPR= $-40^{\circ}$ C to  $+85^{\circ}$ C, VCC= $5V\pm10\%$ , VSS=0V8MHz VERSION : TOPR= $-10^{\circ}$ C to  $+70^{\circ}$ C, VCC= $5V\pm5\%$ , VSS=0V

(1/2)

| SYMBOL | PARAMETER                                | TEST CONDITION        | MIN.    | TYP. | MAX.      | UNIT. |
|--------|------------------------------------------|-----------------------|---------|------|-----------|-------|
| VILC   | Clock Input Low Voltage (CLKIN)          |                       | - 0.3   |      | 0.6       | v     |
| VIHC   | Clock Input High Voltage (CLKIN)         |                       | VCC-0.6 |      | VCC + 0.3 | v     |
| VIL    | Input Low Voltage (except XTAL1, RESET)  |                       | - 0.5   | -    | 0.8       | v     |
| VIH    | Input High Voltage (except XTAL1, RESET) |                       | 2.2     | -    | vcc       | v     |
| VILR   | Input Low Voltage (RESET)                |                       | - 0.5   | -    | 0.45      | v     |
| VIHR   | Input High Voltage (RESET)               |                       | VCC-0.6 | -    | VCC       | v     |
| VOLC   | Output Low Voltage (CLKOUT)              | IOL = 2.0mA           | —       | -    | 0.6       | v     |
| voнc   | Output High Voltage (CLKOUT)             | IOH = - 2.0mA         | VCC-0.6 | -    | —         | v     |
| VOL    | Output Low Voltage (except CLKOUT)       | IOL = 2.0mA           | -       | -    | 0.4       | V     |
| VOH1   | Output High Voltage 1 (except CLKOUT)    | IOH = - 1.6mA         | 2.4     | -    | -         | v     |
| VOH2   | Output High Voltage 2 (except CLKOUT)    | IOH = - 250uA         | VCC-0.8 | -    | -         | v     |
| ILI    | Input Leakage Current                    | $Vss \le VIN \le Vcc$ | -       | -    | ± 10      | μA    |
| ILO    | 3-state Output Leakage Current in Float  | Vss≦Vout≦VCC          |         | -    | ± 10      | μA    |

| (  | 2 | 12 | ) |
|----|---|----|---|
| ۰. | - |    |   |

| SYMBOL | PARAMETER                                 | TEST CONDITION                                                                            |               | MIN. | TYP. | MAX. | UNIT.  |
|--------|-------------------------------------------|-------------------------------------------------------------------------------------------|---------------|------|------|------|--------|
|        | Power Supply Current                      | VCC = 5V,<br>fCLK = (1)                                                                   | AT-6          | -    | 22   | 27   | mΔ     |
|        |                                           | VIHC = VIHR = VIH = VCC-0.2V,<br>VILC = VILR = VIL = 0.2V                                 | AT-8          | -    | 31   | 35   |        |
| ICC2   | Stand-by Supply Current<br>(See Note(2) ) | VCC = 5V,<br>fCLK = Stopped,<br>VIHC = VIH = VIHR = VCC-0.2V,<br>VILC = VIL = VILR = 0.2V | AT-6<br>/AT-8 | _    | 0.5  | 50   | μА     |
| 1003   | Power Supply Current                      | VCC = 5V,<br>fCLK = (1),                                                                  | AT-6          | -    | 1.5  | 3    | mA     |
| 1005   | (IDLE1 Mode)                              | VIHC = VIH = VIHR = VCC-0.2V,<br>VILC = VIL = VILR = 0.2V                                 | AT-8          | 1    | 2    | 4    | mA     |
| 1004   | Power Supply Current                      | VCC = 5V,<br>fCLK = (1),                                                                  | AT-6          | -    | 11   | 15   | mA     |
|        | (IDLE2 Mode)                              | VIHC = VIH = VIHR = VCC-0.2V,<br>VILC = VIL = VILR = 0.2V                                 | AT-8          | -    | 15   | 20   | mA     |
|        |                                           |                                                                                           | , , ,         |      |      |      | 030489 |

Note :

(1) fCLK = 1/TeC (MIN)

(2) ICC2 Stand-by Supply Current is guaranteed only when the supplied clock is stopped at a low level during T4 state of the following machin Cycle (M1) next to OP code fetch Cycle of HALT instruction.

 $Except \overline{SYNCA} = 0 \text{ or } \overline{SYNCB} = 0 \text{ state}$ 

# TOSHIBA

#### TMPZ84C013A

# 4.3 AC ELECTRICAL CHARACTERISTICS (1) (IN ACTIVE STATE)

6MHz VERSION : TA =  $-40^{\circ}$ C~85°C, VCC = 5V ± 10%, VSS = 0V 8MHz VERSION : TA =  $-10^{\circ}$ C~70°C, VCC = 5V ± 5%, VSS = 0V

# 4.3.1 AC Characteristics of CPU (in Active State)

|     |              | . ,                                                    |      |                   |       |      |                   |       | (1/3) |
|-----|--------------|--------------------------------------------------------|------|-------------------|-------|------|-------------------|-------|-------|
| NO. | SYMBOL       | PARAMETER                                              | TMPZ | 284C013<br>(6MHz) | BAT-6 | TMP2 | 284C013<br>(8MHz) | BAF-8 | UNIT  |
|     |              |                                                        | MIN. | TYP.              | MAX.  | MIN. | TYP.              | MAX.  |       |
| 1   | TcC          | Clock Cycle Time                                       | 162  | -                 | DC    | 125  | _                 | DC    | ns    |
| 2   | TwCh         | Clock Pulse Width (High)                               | 65   |                   | DC    | 50   | -                 | DC    | ns    |
| 3   | TwCl         | Clock Pulse Width (Low)                                | 65   |                   | DC    | 50   | -                 | DC    | ns    |
| 4   | TfC          | Clock Fall Time                                        | -    | _                 | 20    | _    | -                 | 15    | ns    |
| 5   | TrC          | Clock Rise Time                                        | -    | -                 | 20    |      | _                 | 15    | ns    |
| 6   | TdCr (A)     | Clock ↑ to Address Valid<br>Delay                      | _    | —                 | 90    | —    | _                 | 85    | ns    |
| 7   | TdA (MREQf)  | Address Valid to MREQ ↓<br>Delay                       | 35   | _                 | _     | 20   | —                 | _     | ns    |
| 8   | TdCf (MREQf) | $Clock \downarrow to \overline{MREQ} \downarrow Delay$ | -    | -                 | 70    | -    | -                 | 60    | ns    |
| 9   | TdCr (MREQr) | Clock ↑ to MREQ ↑ Delay                                | -    | —                 | 70    | -    | —                 | 60    | ns    |
| 10  | TwMREQh      | MREQ pulse Width (High)                                | 65   | —                 | -     | 45   | —                 | -     | ns    |
| 11  | TwMREQ1      | MREQ pulse Width (Low)                                 | 135  | —                 | -     | 100  | -                 | -     | ns    |
| 12  | TdCf (MREQr) | Clock↓to MREQ↑Delay                                    | —    | -                 | 70    | _    | _                 | 60    | ns    |
| 13  | TdCf (RDf)   | $Clock \downarrow to \overline{RD} \downarrow Delay$   |      | —                 | 80    | _    | _                 | 70    | ns    |
| 14  | TdCr (RDr)   | $Clock \uparrow to  \overline{RD} \uparrow Delay$      | -    | —                 | 70    | -    | -                 | 60    | ns    |
| 15  | TsD (Cr)     | Data Setup Time to Clock ↑                             | 30   | -                 | -     | 30   | -                 | -     | ns    |
| 16  | ThD (RDr)    | Data Hold Time to RD ↑                                 | 0    | -                 | -     | 0    | -                 | -     | ns    |
| 17  | TsWAIT (Cf)  | ₩AIT Setup Time to Clock↓                              | 60   | -                 | -     | 50   | -                 | -     | ns    |
| 18  | ThWAIT (Cf)  | WAIT Hold Time after<br>Clock ↓                        | 10   | _                 | -     | 10   | _                 | -     | ns    |
| 19  | TdCr (M1f)   | Clock ↑ to M1 ↓ Delay                                  | -    | -                 | 80    | -    | -                 | 70    | ns    |
| 20  | TdCr (M1r)   | Clock ↑ to M1 ↑ Delay                                  | -    | -                 | 80    | -    | -                 | 70    | ns    |
| 21  | TdCr (RFSHf) | $Clock \uparrow to \overline{RFSH} \downarrow Delay$ . | —    | -                 | 110   | -    |                   | 95    | ns    |
| 22  | TdCr (RFSHr) | Clock ↑ to RFSH ↑ Delay                                | -    |                   | 100   | -    | -                 | 85    | ns    |
| 23  | TdCf (RDr)   | $Clock \downarrow to \overline{RD} \uparrow Delay$     |      | -                 | 70    | -    | -                 | 60    | ns    |
| 24  | TdCr (RDf)   | Clock ↑ to RD ↓ Delay                                  | -    |                   | 70    |      | -                 | 60    | ns    |

|     |                |                                                                                                                                       |      |                   |       |      |                   |       | (2/3)  |
|-----|----------------|---------------------------------------------------------------------------------------------------------------------------------------|------|-------------------|-------|------|-------------------|-------|--------|
| NO. | SYMBOL         | PARAMETER                                                                                                                             | TMP2 | 284C013<br>(6MHz) | 3AT-6 | TMP2 | 284C013<br>(8MHz) | BAF-8 | UNIT   |
|     |                |                                                                                                                                       | MIN. | TYP.              | MAX.  | MIN. | TYP.              | MAX.  |        |
| 25  | TsD (Cf)       | Data Setup to Clock<br>↓ during M2, M3, M4 or M5<br>Cycles                                                                            | 40   | _                 | _     | 30   | _                 | _     | ns     |
| 26  | TdA (IORQf)    | Address Stable prior to<br>IORQ ↓                                                                                                     | 110  | _                 | -     | 75   | -                 | _     | ns     |
| 27  | TdCr (IORQf)   | Clock ↑ to IORQ ↓ Delay                                                                                                               | -    | —                 | 65    | -    |                   | 55    | ns     |
| 28  | TdCf (IORQr)   | Clock↓to IORQ↑Delay                                                                                                                   | -    | -                 | 70    | -    | -                 | 60    | ns     |
| 29  | TdD (WRf)      | Data Stable Prior to ₩R↓                                                                                                              | 25   | -                 | -     | 5    | —                 | -     | ns     |
| 30  | TdCf (WRf)     | $Clock \downarrow to \overline{WR} \downarrow Delay$                                                                                  | -    | _                 | 70    | _    | -                 | 60    | ns     |
| 31  | TwWR           | WR Pulse Width                                                                                                                        | 135  | -                 | -     | 100  | _                 | -     | ns     |
| 32  | TdCf (WRr)     | Clock↓to WR↑Delay                                                                                                                     |      | -                 | 70    | -    | _                 | 60    | ns     |
| 33  | TdD (WRf)      | Data Stable Prior to ₩R↓                                                                                                              | - 55 | -                 | -     | - 55 | -                 | _     | ns     |
| 34  | TdCr (WRf)     | Clock ↑ to WR ↓ Delay                                                                                                                 | _    | —                 | 60    | _    |                   | 55    | ns     |
| 35  | TdWRr (D)      | Data Stable from WR ↑                                                                                                                 | 30   | —                 | -     | 15   | -                 | _     | ns     |
| 36  | TdCf (HALT)    | Clock $\downarrow$ to HALT $\uparrow$ or $\downarrow$                                                                                 | _    | -                 | 260   | _    | -                 | 225   | ns     |
| 37  | TwNMI          | NMI Pulse Width                                                                                                                       | 80   | _                 | -     | 80   | -                 | -     | ns     |
| 38  | TsBUSREQ (Cr)  | BUSREQ Setup Time to<br>Clock ↑                                                                                                       | 50   | _                 | _     | 40   | _                 |       | ns     |
| 39  | ThBUSREQ (Cr)  | BUSREQ Hold Time after<br>Clock ↑                                                                                                     | 10   | —                 | -     | 10   | _                 | _     | ns     |
| 40  | TdCr (BUSACKf) | Clock↑to BUSACK ↓ Delay                                                                                                               | -    | —                 | 90    | _    | _                 | 80    | ns     |
| 41  | TdCf (BUSACKr) | Clockt↓to BUSACK ↑Delay                                                                                                               | -    | -                 | 90    | _    |                   | 80    | ns     |
| 42  | TdCr (Dz)      | Clock ↑ to Data Float Delay                                                                                                           | -    | —                 | 80    | —    | -                 | 70    | ns     |
| 43  | TdCr (CTz)     | Clock ↑ to Control Outputs<br>Float Delay<br>(MREQ, IORQ, RD, and WR)                                                                 | _    | -                 | 70    | _    | _                 | 60    | ns     |
| 44  | TdCr (AZ)      | Clock ↑ to Address Float<br>Delay                                                                                                     | -    | _                 | 80    |      | —                 | 70    | ns     |
| 45  | TdCr (A)       | $\frac{\overline{MREQ} \uparrow, \overline{IORQ} \uparrow, \overline{RD} \uparrow, and}{\overline{WR} \uparrow to Address Hold Time}$ | 35   | _                 | —     | 20   | —                 | —     | ns     |
| 46  | TsRESET (Cr)   | RESET to Clock ↑ Setup Time                                                                                                           | 60   | _                 | _     | 45   | _                 | -     | ns     |
| 47  | ThRESET (Cr)   | RESET to Clock ↑ Hold Time                                                                                                            | 10   | _                 | —     | 10   | —                 | _     | ns     |
| 48  | TsINTf (Cr)    | INT to Clock ↑ Setup Time                                                                                                             | 70   | _                 | _     | 55   | —                 | _     | ns     |
| 49  | TsINTr (Cr)    | INT to Clock ↑ Hold Time                                                                                                              | 10   | -                 | —     | 10   | _                 | —     | ns     |
|     |                |                                                                                                                                       |      |                   |       |      |                   |       | 100580 |

|     |               |                                                                |                          |      |      |      |      |      | (3/3) |
|-----|---------------|----------------------------------------------------------------|--------------------------|------|------|------|------|------|-------|
| NO. | SYMBOL        | PARAMETER                                                      | TMPZ84C013AT-6<br>(6MHz) |      |      | TMPZ | UNIT |      |       |
|     |               |                                                                | MIN.                     | TYP. | MAX. | MIN. | TYP. | MAX. |       |
| 50  | TdM1f (IORQf) | $\overline{M1}\downarrow$ to $\overline{IORQ}\downarrow$ Delay | 365                      | -    | -    | 270  | -    | -    | ns    |
| 51  | TdCf (IORQf)  | Clock↓to <del>IORQ</del> ↓Delay                                | -                        | -    | 70   | -    | —    | 60   | ns    |
| 52  | TdCr (IORQr)  | Clock ↑ to IORQ ↑ Delay                                        | -                        | -    | 70   | -    | -    | 60   | ns    |
| 53  | TdCf (D)      | Clock↓to Data Valid Delay                                      | -                        | -    | 130  |      | _    | 115  | ns    |

# 4.3.2 AC Characteristics of CGC (in Active State)

| NO. | SYMBOL         | PARAMETER                                                | TMP2 | 284C013<br>(6MHz)           | BAT-6 | TMP  | 284C013<br>(8MHz) | BAF-8 | UNIT |
|-----|----------------|----------------------------------------------------------|------|-----------------------------|-------|------|-------------------|-------|------|
|     |                |                                                          | MIN. | TYP.                        | MAX.  | MIN. | TYP.              | MAX.  |      |
| 54  | TcC CLK        | Output clock cycle                                       | -    | 162                         | -     | -    | 125               | -     | ns   |
| 55  | TwCh CLK       | Output clock Width(High)                                 | -    | 70                          | -     | 50   | -                 | -     | ns   |
| 56  | TwCI CLK       | Output clock Width (Low)                                 | -    | 70                          | -     | 50   | -                 | 1     | ns   |
| 57  | TfC CLK        | Output clock fall time                                   | -    | 12                          | -     | -    | -                 | 12    | ns   |
| 58  | TrC CLK        | Output clock rise time                                   | -    | 12                          | —     | -    | -                 | 12    | ns   |
| 59  | TRST (INT) S   | CLK out restart time by INT<br>(STOP Mode)               | -    | 214 +<br>2.5TcC             | _     | -    | 214 +<br>2.5TcC   | -     | ns   |
| 60  | TRST (NMI) S   | CLK out restart time by NMI<br>(STOP Mode)               | -    | 2 <sup>14</sup> +<br>2.5TcC | —     | _    | 214 +<br>2.5TcC   | _     | ns   |
| 61  | TRST (INT) I   | CLK out restart time by INT<br>(IDLE 1/2 Mode)           |      | 2.5<br>*TcC                 | -     | _    | 2.5<br>*TcC       | _     | ns   |
| 62  | TRST (NMI) I   | CLK out restart time by $\overline{NMI}$ (IDLE 1/2 Mode) | -    | 2.5<br>*TcC                 | _     | _    | 2.5<br>*TcC       |       | ns   |
| 63  | TRST (RESET) I | CLK out restart time by<br>RESET<br>(IDLE 1/2 Mode)      |      | TcC                         | _     |      | TcC               |       | ns   |

# 4.3.3 AC Characteristics of CTC (in Active State)

| NO. | SYMBOL       | PARAMETER                                                                                                                      | TMP2                            | 284C013<br>(6MHz) | 3AF-6 | TMP2                            | 284C013<br>(8MHz) | 3AF-8 | UNIT   |
|-----|--------------|--------------------------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------|-------|---------------------------------|-------------------|-------|--------|
|     |              |                                                                                                                                | MIN.                            | TYP.              | MAX.  | MIN.                            | TYP.              | MAX.  |        |
| 64  | TdM1 (IEO)   | Delay from $\overline{\text{M1}}$ fall to IEO<br>fall (in case of generating<br>only interrupt immediately<br>before M1 cycle) |                                 |                   | 160   |                                 |                   | 130   | ns     |
| 65  | TdIEI (IEOf) | Delay from IEI fall to IEO fall                                                                                                | -                               | _                 | 70    | -                               | -                 | 50    | ns     |
| 66  | TdIEI (IEOr) | Delay from IEI rise to IEO<br>rise<br>(after ED decode)                                                                        |                                 |                   | 150   |                                 |                   | 120   | ns     |
| 67  |              | CLK/TRG setup to TL↑ for<br>detection of interrupt<br>tsCTR (c) Satisfied                                                      | TcC<br>+ 120<br>+ T68<br>+ T48  | _                 | _     | TcC<br>+ 100<br>+ T68<br>+ T48  | _                 | _     |        |
| 07  |              | tsCTR (c) not Satisfied                                                                                                        | 2TcC<br>+ 120<br>+ T68<br>+ T48 | _                 | _     | 2TcC<br>+ 100<br>+ T68<br>+ T48 |                   | _     | 115    |
| 68  | TcCTR        | CLK/TRG Frequency<br>(counter mode)                                                                                            | 2TcC                            | —                 | -     | 2TcC                            | _                 | _     | ns     |
| 69  | TrCTR        | CLK/TRG rising time                                                                                                            | -                               | -                 | 40    | -                               | _                 | 30    | ns     |
| 70  | TfCTR        | CLK/TRG falling time                                                                                                           | -                               | -                 | 40    | -                               | -                 | 30    | ns     |
| 71  | TwCTR1       | CLK/TRG Pulse Width (Low)                                                                                                      | 120                             | —                 | -     | 90                              | _                 |       | ns     |
| 72  | TwCTRh       | CLK/TRG Pulse Width (High)                                                                                                     | 120                             | -                 |       | 90                              | -                 |       | ns     |
| 73  | TsCTR (Cs)   | CLK/TRG↑to Clock↑<br>Setup Time for Immediate<br>Count<br>(counter mode)                                                       | 150                             | _                 | _     | 110                             | _                 | _     | ns     |
| 74  | TsCTR (CT)   | CLK/TRG ↑ to Clock ↑ Setup<br>Time for enabling of<br>Prescaler on following<br>clock ↑<br>(timer mode)                        | 150                             | _                 | _     | 110                             |                   | _     | ns     |
| 75  | TdC (ZC/TOr) | Clock ↑ to ZC/TO ↑ Delay                                                                                                       | —                               |                   | 140   |                                 |                   | 110   | ns     |
| 76  | TdC (ZC/TOf) | Clock↓to ZC/TO↓Delay                                                                                                           | -                               |                   | 140   |                                 | -                 | 110   | ns     |
|     |              |                                                                                                                                |                                 |                   |       |                                 |                   |       | 030489 |

### 4.3.4 AC Characteristics of SIO (in Active State)

(1/2)TMP784C013AT-6 TMPZ84C013AF-8 (8MHz) (6MHz) UNIT NO. SYMBOL PARAMETER TYP MIN TYP MAX MIN MAX 75 \_ \_\_\_\_ 50 \_ \_ 92 TsM1(C) M1 ↑ to clock ↑ Setup time ns IEI 🖞 to IORQ 🖞 Setup time 120 100 93 TsIEI (IO) \_ -ns (INTACK cvcle) M1 ↓ to IEO ↓ Delay 94 TdM1 (IEO) 160 \_\_\_\_ \_ 120 ns \_ \_\_\_\_  $(Interrupt before \overline{M1})$ IEI ↓ to IEO ↑ Delay 150 \_\_\_\_ \_\_\_\_\_ 120 95 TdIEI (IEOr) \_ \_\_\_\_ ns (after ED decode) 70 50 96 IEI 🛛 to IEO 🖉 Delay \_ \_ \_\_\_\_ \_ TdIEI (IEOf) ns IORQ | or CE | to W/RDY J Delay 97 175 \_\_\_\_ 130 TdIO (W/RWf) ---------ns (Wait mode) Clock ↑ to W/RDY ↓ Delay 98 TdC (W/RRf) \_ \_\_\_\_ 100 \_\_\_\_ \_\_\_\_ 80 ns (Ready Mode) Clock J to W/RDY float delay TdC (W/RWZ) \_ 110 \_\_\_\_ 90 99 \_ \_ ns (Wait mode) 100 TwPh 200 \_ Pulse Width (High) 200 \_\_\_\_ \_ ---ns 101 TwPI Pulse Width (Low) 200 200 \_\_\_\_ \_ \_\_\_\_ ns 102 TcTxC TxC cycle time 330 \_\_\_\_  $\infty$ 250 \_  $\sim$ ns 103 TwTxCl TxC Width (Low) 100 \_\_\_\_  $\infty$ 80 \_  $\infty$ ns 104 TwTxCh TxC Width (High) 100 \_\_\_\_  $\infty$ 80 \_\_\_\_  $\infty$ ns TxC 1 toTxD Delay 105 TdTxC (TxD) ----\_\_\_\_ 220 -----\_ 180 ns (x1 mode)  $\overline{\mathsf{TxC}} \downarrow \mathsf{toW}/\mathsf{RDY} \downarrow \mathsf{Delay}$ CLK 9 106 TdTxC (W/RRf) 5 \_ 9 5 \_ (Ready mode) Periods 250 107 TcRxC RxC cycle time 330 .  $\infty$ \_  $\infty$ ns TwRxCl RxC Width (Low) 100  $\infty$ 80  $\infty$ 108 -----ns 109 TwRxCh RxC Width (High) 100 \_  $\infty$ 80 \_  $\infty$ ns RxD to  $\overline{RxC} \uparrow$  Setup time TsRxD (Rxc) 0 \_\_\_\_ 10 \_\_\_\_\_ 110 ns (x1 mode) RxC ↑ to RxD Hold time 111 ThRxD (Rxc) 100 \_ \_ 80 \_ \_ ns (x1 mode)  $\overline{RxC} \uparrow to \overline{W/RDY} \downarrow Delay$ CLK 112 TdRxC (W/RRf) 10 \_\_\_\_ 13 10 \_\_\_\_ 13 (Ready mode) Periods RxC ↑ to SYNC ↓ Delay CLK 7 113 TdRxC (SYNC) 4 7 4 \_\_\_\_ (Output mode) Periods

030489

|     |              |                                                    |                          |      |                |                          |      |               | (2/2) |
|-----|--------------|----------------------------------------------------|--------------------------|------|----------------|--------------------------|------|---------------|-------|
| NO. | SYMBOL       | BOL PARAMETER                                      | TMPZ84C013AT-6<br>(6MHz) |      |                | TMPZ84C013AF-8<br>(8MHz) |      |               | UNIT  |
|     |              |                                                    | MIN.                     | TYP. | MAX.           | MIN.                     | TYP. | MAX.          |       |
| 114 | TsSYNC (RxC) | <u>SYNC</u> ↑to RxC↓Setup<br>(External SYNC modes) | - 100                    |      |                | - 100                    | _    |               | ns    |
| 115 | IsTxC        | TxC Setup to TL↑ for<br>detection of interrupt     | 5∗T1<br>+ T48            | _    | 9∗T1<br>+ T48  | 5*T1<br>+T48             | _    | 9*T1<br>+T48  | ns    |
| 116 | IsRxC        | RxC Setup to TL↑ for<br>detection of interrupt     | 10∗T1<br>+ T48           |      | 13∗T1<br>+ T48 | 10*T1<br>+ T48           |      | 13*T1<br>+T48 | ns    |

### 4.3.5 AC Chracteristics of WDT (in Active State)

| NO. | SYMBOL     | PARAMETER                                                                | TMP  | Z84C013<br>(6MHz)                                                                    | BAT-6 | TMP2 | Z84C013<br>(8MHz)                    | BAF-8 | UNIT |
|-----|------------|--------------------------------------------------------------------------|------|--------------------------------------------------------------------------------------|-------|------|--------------------------------------|-------|------|
|     |            |                                                                          | MIN. | TYP.                                                                                 | MAX.  | MIN. | TYP.                                 | MAX.  |      |
| 117 | TdC (WDTf) | $Clock \uparrow to WDTOUT \downarrow Delay$                              | -    | -                                                                                    | 160   | -    | -                                    | 120   | ns   |
| 118 | Tdc (WDTr) | Clock ↑ to WDTOUT ↑ Delay                                                | -    | -                                                                                    | 165   | -    | -                                    | 125   | ns   |
| 119 | TcWDT      | WDTOUT OUTPUT Period<br>WDT Mode0<br>WDT Mode1<br>WDT Mode2<br>WDT Mode3 |      | T1*2 <sup>16</sup><br>T1*2 <sup>18</sup><br>T1*2 <sup>20</sup><br>T1*2 <sup>22</sup> |       |      | T1*216<br>T1*218<br>T1*220<br>T1*222 | -     | ns   |

030489

Note1 : Timing Measurements are made at the following voltage.

Input VIH=2.4V, VIL=0.4V, VIHC=VCC-0.6V, VILC=0.6V Output VOH=2.2V, VOL=0.8V, (Except CLK OUT)

CL = 100 pF

# TOSHIBA

### 4.4 AC TIMING CHARTS (1) (IN ACTIVE STATE)

# 4.4.1 AC Timing Charts of CPU (in Active State)

Figure 4.4.1 through 4.4.8 show the basic timing charts. The circled numbers in these charts correspond to the numbers in the number column of the AC Electrical Characteristics Tables.



Figure 4.4.1 Opcode Fetch Cycle







Note: 1-wait state (TW\*) is inserted automatically by MPU.





1. TL: Last state of instruction

2. 2-wait state (TW\*) is inserted automatically by MPU

Figure 4.4.4 Interrupt Request/Acknowledge Cycle



Note: <u>NMI</u> is asynchronous, but its falling edge signal must occur synchronously with the rising edge of previous TL state for correct response to the subsequent machine cycles.





1. TL: Last state of a given machine cycle

2. TX: Clock used by peripheral LSI that made request.

Figure 4.4.6 Bus Request/Acknowledge Cycle



Note: INT signal is also used for releasing HALT state.

040489





Figure 4.4.8 Reset Cycle

### 4.4.2 AC Timing Charts of CGC (in Active State)

The following Figures show the timings in each operation mode with the CLKOUT pin connected to the CLKIN pin.



Figure 4.4.9 CLKOUT Waveform











# Figure 4.4.15 CTC Interrupt Occurrence Timing



4.4.4 AC Timing Charts of SIO (in Active State)

Figure 4.4.16 (a) SIO Timing Diagram



Figure 4.4.16 (b) SIO Timing Diagram





4.4.5 AC Timing Charts of WDT (in Active State)



Figure 4.4.18 WDT Timing Diagram

### TOSHIBA

# 4.5 AC ELECTRICAL CHARACTERISTICS (2) (IN INACTIVE STATE)

6MHz VERSION :  $TA = -40^{\circ}C \sim +85^{\circ}C$ , VCC = 5V + 10%, VSS = 0V

### 4.5.1 AC Characteristics of CGC (in Inactive State)

| NO. | SYMBOL         | BOL PARAMETER                                          |      | 284C013<br>(6MHz)           | BAT-6 | UNIT   |
|-----|----------------|--------------------------------------------------------|------|-----------------------------|-------|--------|
|     |                |                                                        | MIN. | TYP.                        | MAX.  |        |
| 1   | TcCCLK         | Output Clock Cycle                                     | -    | 162                         | -     | ns     |
| 2   | TwChCLK        | Output Clock Width (High)                              | -    | 70                          | -     | ns     |
| 3   | TwCICLK        | Output Clock Width (Low)                               | -    | 70                          | -     | ns     |
| 4   | TfCCLK         | Output Clock fall Time                                 | —    | 12                          | -     | ns     |
| 5   | TrCCLK         | Output Clock rise Time                                 | 1    | 12                          | -     | ns     |
| 6   | TRST (INT) S   | Clock (CLKOUT) restart Time by INT<br>(STOP mode)      |      | 2 <sup>14</sup> +<br>2.5TcC |       | ns     |
| 7   | TRST (NMI) S   | Clock (CLKOUT) restart Time by NMI<br>(STOP mode)      | _    | 214 +<br>2.5TcC             | _     | ns     |
| 8   | TRST (INT) S   | Clock (CLKOUT) restart Time by INT<br>(IDLE1/2 mode)   | _    | 2.5<br>∗TcC                 |       | ns     |
| 9   | TRST (NMI) I   | Clock (CLKOUT) restart Time by NMI<br>(IDLE1/2 mode)   | _    | 2.5<br>∗TcC                 | _     | ns     |
| 10  | TRST (RESET) I | Clock (CLKOUT) restart Time by RESET<br>(IDLE1/2 mode) |      | 1TcC                        |       | ns     |
| 11  | TsHALT (M1r)   | HALT Setup Time                                        | 10   | -                           | -     | ns     |
|     |                |                                                        |      |                             |       | 040489 |

## 4.5.2 AC Characteristics of CTC (in Inactive State)

|     |          | · ·                              |                          |      |      | (1/2) |
|-----|----------|----------------------------------|--------------------------|------|------|-------|
| NO. | SYMBOL   | PARAMETER                        | TMPZ84C013AT-6<br>(6MHz) |      |      | UNIT  |
|     |          |                                  | MIN.                     | TYP. | MAX. |       |
| 12  | TcC      | Clock Cycle Time                 | 162                      | —    | -    | ns    |
| 13  | Twch     | Clock width (High)               | 65                       | -    | -    | ns    |
| 14  | Twcl     | Clock width (Low)                | 65                       | 1    | —    | ns    |
| 15  | TfC      | Clock falling time               | -                        | -    | 20   | ns    |
| 16  | TrC      | Clock rising time                | -                        | 1    | 20   | ns    |
| 17  | Th       | Hold Time                        | 10                       | I    | -    | ns    |
| 18  | TcCS (C) | CS (A1,A0) Setup time to clock ↑ | 100                      | -    | -    | ns    |
| 19  | TSCE (C) | CE (A7~A2) Setup time to clock ↑ | 150                      | _    | —    | ns    |
| 20  | TsIO (C) | IORQ ↓ Setup time to clock ↑     | 70                       | _    | _    | ns    |

040489

|     |              |                                                                                              |      |                         |              | (2, 2) |
|-----|--------------|----------------------------------------------------------------------------------------------|------|-------------------------|--------------|--------|
| NO. | SYMBOL       | PARAMETER                                                                                    | TM   | UNIT                    |              |        |
|     |              |                                                                                              | MIN. | TYP.                    | MAX.         |        |
| 21  | TsRD (C)     | RD ↓ Setup time to clock ↑                                                                   | 70   |                         | -            | ns     |
| 22  | TdC (DO)     | Clock ↑ to Data Valid Delay                                                                  | -    | -                       | 130          | ns     |
| 23  | Tdc (DOz)    | IORQ, RD ↑ to Data Float Delay                                                               | -    | -                       | 90           | ns     |
| 24  | TsDI (C)     | Data Input Setup time to clock ↑                                                             | 40   | -                       | -            | ns     |
| 25  | TsM1(C)      | M1 Setup time to clock ↑                                                                     | 70   | -                       | —            | ns     |
| 26  | TdM1(IEO)    | M1 ↓ to IEO ↓ Delay<br>(in case of generating only interrupt<br>immediately before M1 cycle) | -    | -                       | 130          | ns     |
| 27  | TdIO (DOI)   | $\overline{IORQ}\downarrow$ to Data out Delay (INTA Cycle)                                   | -    | _                       | 110          | ns     |
| 28  | TdIEI (IEOf) | IEI↓to IEO↓Delay                                                                             | -    | —                       | 70           | ns     |
| 29  | TdIEI (IEOr) | IEI $\uparrow$ to IEO $\uparrow$ Delay (after ED decode)                                     | -    | —                       | 150          | ns     |
| 30  | TdC (INT)    | Clock ↑ to INT ↓ Delay                                                                       | -    | -                       | TcC +<br>120 | ns     |
| 31  | TdA (IORQf)  | CLK/TRG↑to INT↓Delay<br>TsCTR (c) Satisfied                                                  | -    | TcC + 120<br>+ 70 + T37 | -            | ns     |
|     |              |                                                                                              |      | + 70 + T37              |              |        |
| 32  | TcCTR        | CLK/TRG Frequency                                                                            | -    | 2TcC                    | -            | ns     |
| 33  | TrCTR        | CLK/TRG rising time                                                                          | -    | —                       | 40           | ns     |
| 34  | TfCTR        | CLK/TRG falling time                                                                         | -    | —                       | 40           | ns     |
| 35  | TwCTRI       | CLK/TRG pulse width (Low)                                                                    | 120  | —                       |              | ns     |
| 36  | TwCTR        | CLK/TRG pulse width (High)                                                                   | 120  | —                       | -            | ns     |
| 37  | TsCTR (CS)   | CLK/TRG ↑ to clock ↑ Setup Time for<br>Immediate Count (counter mode)                        | 150  | _                       |              | ns     |
| 38  | TsCTR (CT)   | CLK/TRG↑to clock↑ Setup Time for<br>enabling of Prescaler on following<br>clock↑(timer mode) | 150  | _                       |              | ns     |
| 39  | TdC (ZC/TOr) | Clock ↑ to ZC/TO ↑ Delay                                                                     | -    |                         | 140          | ns     |
| 40  | TdC (ZC/TOf) | Clock↓to ZC/TO↓ Delay                                                                        | -    | -                       | 140          | ns     |

(2/2)
### 4.5.3 AC Characteristics of SIO (in Inactive State)

| NO.SYMBOLPARAMETERINP284CU1500065SSCS (C)CE (A7toA2), C/ D (A0),<br>B/A (A1) Setup Time to Clock ↑6065TSRD (C)IORQ, RD Setup Time to Clock ↑6066TSRD (C)Clock ↑ to Data output Delay15067TdC (DO)Clock ↑ to Data output Delay9068TSDI (C)Data input setup time to clock ↑3009169TdRD (DO2)RD ↑ to Data Out Ploat Delay91070TdIO (DO1)IORQ ↓ to Data output Delay<br>(INTACK cycle)12071TSM1 (C)MT Setup time to clock ↑12072TsIEI (IO)IEI Setup time to IORQ ↓ (INTACK cycle)12012073TdM1 (IEO)IEI 1 to IEO ↓ Delay<br>(interrupt before MT)15015074TdIEI (IEOf)IEI 1 to IEO ↓ Delay<br>(interrupt before MT)15075TdIC (INT)Clock ↑ to INT ↓ Delay15076TdC (W/RWf)Clock ↑ to W/RDY ↓ to W/RDY ↓ Delay<br>(Wait Mode)17578TdC (W/RRf)Clock ↑ to W/RDY ↓ Delay (Ready Mode)10079TdC (W/RRf)Clock ↓ to W/RDY ↓ Delay (Ready Mode)11079TdC (W/RWf)Clock ↓ to W/RDY ↓ Delay<br>(Wait Mode)11079TdC (W/RRf)Any unspecified                                                                                                                                                                                                                                                                                                                                         | UNIT<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns     |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Image: Normal systemMIN.TYP.MAX.65TsCS (C) $\overline{CE}(A_7toA_2), C/\overline{D}(A_0), B/A(A_1)$ Setup Time to Clock $\uparrow$ 6066TsRD (C)IORQ, RD Setup Time to clock $\uparrow$ 6067TdC (DO)Clock $\uparrow$ to Data output Delay15068TsDI (C)Data input setup time to clock $\uparrow$ 3069TdRD (DO2)RD $\uparrow$ to Data Out Float Delay9070TdIO (DO1) $\overrightarrow{IORQ}$ to Data output Delay71TsM1 (C)MT Setup time to clock $\uparrow$ 7572TsIEI (IO)IEI Setup time to $\overrightarrow{IORQ}$ (INTACK cycle)12073TdM1 (IEO)MT to IEO $\uparrow$ Delay (INTACK cycle)15074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay15076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, CE (A_7 to A_2) \downarrow to W/RDY \downarrow Delay15078TdC (W/RRf)Clock \uparrow to \overline{W/RDY} Float Delay10079TdC (W/RRf)Clock \uparrow to \overline{W/RDY} Float Delay11080Th,Th (CS)Any unspecified hold when setup isspecified0110$                                                                                                                                                                            | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns       |
| 65TsCS (C) $\overline{CE}$ (A7toA2), C/ D (A0),<br>B/A (A1) Setup Time to Clock $\uparrow$ 6066TsRD (C)IORQ, RD Setup Time to clock $\uparrow$ 6015067TdC (DO)Clock $\uparrow$ to Data output Delay15068TsDI (C)Data input setup time to clock $\uparrow$<br>(write cycle or M1 cycle)3069TdRD (DO2)RD $\uparrow$ to Data Out Float Delay9070TdIO (DO1) $\overline{IORQ} \downarrow$ to Data output Delay<br>(INTACK cycle)9071TsM1 (C)MT Setup time to clock $\uparrow$<br>(INTACK cycle)7572TsIEI (IO)IEI Setup time to clock $\uparrow$<br>(Interrupt before M1)12073TdM1 (IEO)MT $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)15074TdIEI (IEOr)IEI $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)15075TdIEI (IEOr)IEI $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)15076TdC (INT)Clock $\uparrow$ to $\overline{NT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE}$ (A7 to A2) $\downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)10078TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)10079TdC (W/RRf)Clock $\downarrow$ to $\overline{W/RDY} Float Delay(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup isspecified0$ | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns |
| 66 TsRD (C) IORQ, RD Setup Time to clock $\uparrow$ 60    67 TdC (DO) Clock $\uparrow$ to Data output Delay  150   68 TsDI (C) Data input setup time to clock $\uparrow$<br>(write cycle or M1 cycle) 30     69 TdRD (DO2) RD $\uparrow$ to Data Out Float Delay   90   70 TdIO (DO1) IORQ, to Data output Delay<br>(INTACK cycle)   90   71 TsM1 (C) M1 Setup time to clock $\uparrow$ 75     72 TsIEI (IO) IEI Setup time to IORQ $\downarrow$ (INTACK cycle) 120     73 TdM1 (IEO) M1 $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1) 120  150   74 TdIEI (IEOr) IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)   150   75 TdIEI (IEOf) IEI $\uparrow$ to IEO $\downarrow$ Delay   150   75 TdIEI (IEOf) IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)   150   76 TdC (INT) Clock $\uparrow$ to INT $\downarrow$ Delay   150   77                                                                                                                                                                                                                                                                                                                                                                                    | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns       |
| 67TdC (DO)Clock $\uparrow$ to Data output Delay $  150$ 68TsDl (C)Data input setup time to clock $\uparrow$<br>(write cycle or M1 cycle) $30$ $ -$ 69TdRD (DO2)RD $\uparrow$ to Data Out Float Delay $  90$ 70TdIO (DO1) $\overline{IORQ} \downarrow$ to Data output Delay<br>(INTACK cycle) $  -$ 71TsM1 (C)Mī Setup time to clock $\uparrow$ $75$ $ -$ 72TsIEI (IO)IEI Setup time to $\overline{IORQ} \downarrow$ (INTACK cycle) $120$ $ -$ 73TdM1 (IEO)Mī $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1) $   160$ 74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode) $   70$ 76TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay $   150$ 77TdIO (W/RWf) $\overline{IORQ}$ , $\overline{CE}$ ( $A_7$ to $A_2$ ) $\downarrow$ to $\overline{W/RDY} \downarrow$ Delay $  100$ 78TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode) $   100$ 79TdC (W/RWf) $\overline{Clock} \downarrow$ to $\overline{W/RDY} \downarrow$ Delay $   110$ 80Th,Th (CS)Any unspecified hold when setup is<br>specified $0$ $  -$                                                                                                                                                                | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns                         |
| 68TsDI (C)Data input setup time to clock $\uparrow$<br>(write cycle or M1 cycle)3069TdRD (DO2)RD $\uparrow$ to Data Out Float Delay9070TdIO (DO1)IORQ $\downarrow$ to Data output Delay<br>(INTACK cycle)12071TsM1 (C)M1 Setup time to clock $\uparrow$ 7572TsIEI (IO)IEI Setup time to IORQ $\downarrow$ (INTACK cycle)12073TdM1 (IEO)M1 $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)12015074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)15075TdIEI (IEOf)IEI $\uparrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)15076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay<br>(Wait Mode)15077TdIO (W/RWf)IORQ, CE ( $A_7$ to $A_2$ ) $\downarrow$ to $W/RDY \downarrow$ Delay<br>(Wait Mode)10079TdC (W/RRf)Clock $\downarrow$ to $W/RDY \downarrow$ Delay (Ready Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                      | ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns<br>ns                         |
| 69TdRD (DOz) $\overline{RD} \uparrow$ to Data Out Float Delay $ -$ 9070TdIO (DOI) $\overline{IORQ} \downarrow$ to Data output Delay<br>(INTACK cycle) $ -$ 12071TsM1 (C) $\overline{M1}$ Setup time to clock $\uparrow$ 75 $ -$ 72TsIEI (IO)IEI Setup time to $\overline{IORQ} \downarrow$ (INTACK cycle)120 $ -$ 73TdM1 (IEO) $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1) $ -$ 16074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode) $ -$ 15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1) $ -$ 15076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay $ -$ 17577TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode) $ -$ 10079TdC (W/RRf)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode) $ -$ 11080Th,Th (CS)Any unspecified hold when setup is<br>specified0 $  -$                                                                                                                                                                                                                                                                                     | ns<br>ns<br>ns<br>ns<br>ns<br>ns                                     |
| 70TdIO (DOI) $\overline{IORQ} \downarrow$ to Data output Delay<br>(INTACK cycle)12071TsM1 (C)M1 Setup time to clock $\uparrow$ 7572TsIEI (IO)IEI Setup time to $\overline{IORQ} \downarrow$ (INTACK cycle)12073TdM1 (IEO) $\overline{M1} \downarrow$ to $IEO \downarrow$ Delay<br>(interrupt before M1)16074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay7076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)10078TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY}$ Delay (Ready Mode)11079TdC (W/RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                     | ns<br>ns<br>ns<br>ns<br>ns                                           |
| 71TsM1 (C) $\overline{M1}$ Setup time to clock $\uparrow$ 75 $-$ 72TsIE1 (IO)IEI Setup time to $\overline{IORQ} \downarrow$ (INTACK cycle)120 $-$ 73TdM1 (IEO) $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before $\overline{M1}$ ) $ -$ 16074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode) $ -$ 15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\uparrow$ Delay<br>(interrupt before $\overline{M1}$ ) $ -$ 7076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay $ -$ 15077TdIO (W/RWf) $\overline{IORQ}, CE (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode) $ -$ 10078TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode) $ -$ 10079TdC (W/RWz) $Clock \downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode) $ -$ 11080Th,Th (CS)Any unspecified hold when setup is<br>specified $0$ $ -$                                                                                                                                                                                                                                                                                                                                          | ns<br>ns<br>ns<br>ns                                                 |
| 72TsIEI (IO)IEI Setup time to $\overline{IORQ} \downarrow$ (INTACK cycle)120 $ -$ 73TdM1 (IEO) $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1) $   160$ 74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode) $   150$ 75TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode) $   70$ 76TdC (INT)Clock $\uparrow$ to INT $\downarrow$ Delay $   150$ 77TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode) $  100$ 78TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode) $  100$ 79TdC (W/RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode) $  110$ 80Th,Th (CS)Any unspecified hold when setup is<br>specified $0$ $ -$                                                                                                                                                                                                                                                                                                                                                                                                                                            | ns<br>ns<br>ns                                                       |
| 73TdM1 (IEO) $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)16074TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay7076TdC (INT)Clock $\uparrow$ to INT $\downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)17578TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)10079TdC (W/RWz) $\overline{Clock \downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ns<br>ns                                                             |
| 74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)15075TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay7076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)17578TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)10079TdC (W/RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ns                                                                   |
| 75TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay7076TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)17578TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)10079TdC (W/RWz) $\overline{Clock} \downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                      |
| 76TdC (INT)Clock $\uparrow$ to $\overline{INT} \downarrow$ Delay15077TdIO (W/RWf) $\overline{IORQ}, \overline{CE} (A_7 to A_2) \downarrow$ to $\overline{W/RDY} \downarrow$ Delay<br>(Wait Mode)17578TdC (W/RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)10079TdC (W/RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | ns                                                                   |
| 77 TdIO (W/RWf) IORQ, CE (A7 to A2) ↓ to W/RDY ↓ Delay<br>(Wait Mode) - - 175   78 TdC (W/RRf) Clock ↑ to W/RDY ↓ Delay (Ready Mode) - - 100   79 TdC (W/RWz) Clock ↓ to W/RDY Float Delay<br>(Wait Mode) - - 110   80 Th,Th (CS) Any unspecified hold when setup is<br>specified 0 - -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                   |
| 78 TdC (W/RRf) Clock ↑ to W/RDY ↓ Delay (Ready Mode) - - 100   79 TdC (W/RWz) Clock ↓ to W/RDY Float Delay<br>(Wait Mode) - - 110   80 Th,Th (CS) Any unspecified hold when setup is<br>specified 0 - -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                   |
| 79TdC (W/RWz)Clock ↓ to W/RDY Float Delay<br>(Wait Mode)11080Th,Th (CS)Any unspecified hold when setup is<br>specified0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                   |
| 80 Th,Th (CS) Any unspecified hold when setup is 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | ns                                                                   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | ns                                                                   |
| 81 TwPh Pulse width (High) 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ns                                                                   |
| 82 TwPl Pulse width (Low) 200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ns                                                                   |
| 83 TcTxC $\overline{\text{TxC}}$ Cycle time 330 $-\infty$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | ns                                                                   |
| 84 TwTxCl TxC width (Low) 100 $-\infty$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ns                                                                   |
| 85 TwTxCh $\overline{\text{TxC}}$ width (High) 100 - $\infty$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ns                                                                   |
| 86 TdTxC (TxD) $\overline{TxC} \downarrow$ to TxD Delay (x1 Mode) 220                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ns                                                                   |
| 87 TdTxC (W/RRf) TxC ↓ to W/RDY ↓ Delay (Ready mode) 5 - 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | CLK<br>Periods                                                       |
| 88 TdTxC (INT) $\overline{\text{TxC}} \downarrow \text{to } \overline{\text{INT}} \downarrow \text{Delay}$ 5 – 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CLK<br>Periods                                                       |
| 89 TcRxC $\overline{RxC}$ Cycle time $330 - \infty$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1                                                                    |

MPUZ80-554

|            |               |                                                                                                          |       |      |                                         | (2/2)          |
|------------|---------------|----------------------------------------------------------------------------------------------------------|-------|------|-----------------------------------------|----------------|
| NO. SYMBOL |               | PARAMETER                                                                                                | TMP2  | UNIT |                                         |                |
|            |               |                                                                                                          | MIN.  | TYP. | TYP. MAX.                               |                |
| 90         | TwRxCl        | RxC width (Low)                                                                                          | 100   | -    | 8                                       | ns             |
| 91         | TwRxCh        | RxC width (High)                                                                                         | 100   | -    | ~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~ | ns             |
| 92         | TsRxD (RxC)   | RxD to $\overline{RxC} \uparrow$ Setup time (x1 mode)                                                    | 0     | -    | _                                       | ns             |
| 93         | ThRxD (RxC)   | RxC↑ to RxD hold time (x1 mode)                                                                          | 100   | -    | -                                       | ns             |
| 94         | TdRxC(W/RRf)  | $\overline{\text{RxC}} \uparrow \text{to } \overline{\text{W/RDY}} \downarrow \text{Delay (Ready Mode)}$ | 10    | _    | 13                                      | CLK<br>Periods |
| 95         | TdRxC (INT)   | RxC↑to INT↓Delay                                                                                         | 10    | _    | 13                                      | CLK<br>Periods |
| 96         | TdRxC (SYNC)  | $\overline{RxC} \downarrow to \overline{SYNC} \uparrow Delay (Output modes)$                             | 4     | -    | 7                                       | CLK<br>Periods |
| 97         | TsSYNC (RxC)  | SYNC ↓ to RxC ↑ Setup Time<br>(External syncmodes)                                                       | - 100 | -    | -                                       | ns             |
| 98         | TsAdd (Cr)    | Address Setup time to clock $\uparrow$                                                                   | 150   |      | -                                       | ns             |
| 99         | TsIO (Cr)     | IORQ ↓ Setup time to clock ↑                                                                             | 70    | -    | -                                       | ns             |
| 100        | TdRD (Cr)     | RD ↓ Setup time to clock ↑                                                                               | 70    | -    | -                                       | ns             |
| 101        | TdCr (Do)     | Data out Delay to clock ↑                                                                                | -     |      | 130                                     | ns             |
| 102        | TdIORDr (DoZ) | Data Float Delay to $\overline{\text{IORQ}} \uparrow \overline{\text{RD}} \uparrow$                      | -     | -    | 90                                      | ns             |
| 103        | TsWR (Cr)     | $\overline{WR}\downarrowSetup$ time to clock $\uparrow$                                                  | 70    | -    | -                                       | ns             |
| 104        | TsDI (Cr)     | Data Input Setup time to clock ↑                                                                         | 0     | -    | -                                       | ns             |
| 105        | TdIOWRf (D)   | Data Hold time to IORQ, WR↑                                                                              | 20    | -    | -                                       | ns             |

(2/2)

040489

### 4.5.4 AC Characteristics of WDT (in Inactive State)

| NO. | SYMBOL     | PARAMETER                                                                     | TMF  | UNIT                                                                                     |      |                      |
|-----|------------|-------------------------------------------------------------------------------|------|------------------------------------------------------------------------------------------|------|----------------------|
|     |            |                                                                               | MIN. | TYP.                                                                                     | MAX. |                      |
| 106 | TdC (WDTf) | Clock ↑ to WDTOUT ↓ Delay                                                     | -    | -                                                                                        | 160  | ns                   |
| 107 | TdC (WDTr) | Clock ↑ to WDTOUT ↑ Delay                                                     | -    |                                                                                          | 165  | ns                   |
| 108 | TCWDTZ     | WDTOUT out put period<br>WDT Mode 0<br>WDT Mode 1<br>WDT Mode 2<br>WDT Mode 3 |      | T12*2 <sup>16</sup><br>T12*2 <sup>18</sup><br>T12*2 <sup>20</sup><br>T12*2 <sup>22</sup> |      | ns<br>ns<br>ns<br>ns |

Note1 : Timing Measurements are made at the following voltage.

#### MPUZ80-555

### 4.6 AC TIMING CHARTS (2) (IN INACTIVE STATE)

4.6.1 AC Timing Charts of CGC (in Inactive State)

The following Figures show the timing charts in each operation mode with the CLKOUT pin connected to the CLKIN pin.



Figure 4.6.1 CLKOUT Waveform







Figure 4.6.3 Clock Restart Timing (IDLE1 mode)



Figure 4.6.4 Clock Restart Timing (IDLE2 mode)



Figure 4.6.5 Timing of Clock Restart by RESET (IDLE1, IDLE2 mode)



Figure 4.6.6 Clock Suspension Timing (IDLE1, IDLE2 and STOP modes)



4.6.2 AC Timing Charts of CTC (in Inactive State)

040489



MPUZ80-558

### 4.6.3 AC Timing Charts of SIO (in Inactive State)



Figure 4.6.8 SIO Timing Diagram (a) (Inactive)





Figure 4.6.8 SIO Timing Diagram (b) (Inactive)

# 4.6.4 AC Timing Charts of WDT (in Inactive State)

(The mode setting and daisy chain interrupt setting registers on  $WDT\)$ 



Figure 4.6.9 RD/WRITE, WDTOUT Timing Diagram

### 4.7 PIN CAPACITANCE

| SYMBOL | ITEM                    | TEST CONDITION               | MIN. | TYP. | MAX. | UNIT |
|--------|-------------------------|------------------------------|------|------|------|------|
| CCLOCK | Clock Input Capacitance | F = 1MHz                     | -    | -    | 8    |      |
| CIN    | Input Capacitance       | All terminals except that to | -    | -    | 6    | PF   |
| COUT   | Output Capacitance      | be measured be earthed       | -    | -    | 10   |      |

# 5. EXTERNAL DIMENSIONS

QFJ84-P-S115



# TMPZ84C015AF-6 / TMPZ84C015AF-8 TLCS-Z80 MICROPROCESSOR

# 1. OUTLINE AND FEATURES

The TMPZ84C015A is a high-performance CMOS 8-bit microprocessor incorporating the counter timer circuit (CTC), the serial I/O port (SIO), the parallel I/O port (PIO), the clock generator/controller (CGC), and the watchdog timer (WDT) around the TLCS-Z80 MPU. This microprocessor inherits the basic architecture of the TLCS-Z80 series, allowing the user to utilize the software resources and development tools accumulated so far.

The TMPZ84C015A is based on the new CMOS process and housed in a standard 100pin mini-flat package, greatly contributing to system miniaturization and power saving.

The TMPZ84C015A incorporates the high-performance serial I/O port, the counter timer circuit which can be used as the baud rate generator, and the watchdog timer indispensable for control applications, offering the user a wide range of system applications such as the communication controllers including a communication adaptor and the various other controllers which need miniaturization.

#### Features

- Built-in TLCS-Z80 series MPU, CTC, SIO, PIO,CGC and watchdog timer features.
- High speed operation (6MHz and 8MHz operations)
- Built-in clock generator (CGC: Clock Generator Controller)
- Built-in standby capability (with the controller built in) provides 4 operation modes:

Run mode(Normal operation)Idle-1 mode(Only clock oscillation goes on. )Idle-2 mode(Wake-up by CTC enabled. )Stop mode(Clock oscillation stopped; standby state)

• Wide operational voltage range  $(5V \pm 10\% : 6MHz VERSION,$ 

 $5V \pm 5\%$ : 8MHz VERSION) supported.

- Wide operating temperature range (-40°C to +85°C: 6MHz VERSION, -10°C to +70°C: 8MHz VERSION)
- Low power dissipation

In operation : (RUN mode) 25mA TYP. at 6 MHz, 35mA TYP. at 8 MHz In idle : (IDLE-1 mode) 1.5mA TYP. at 6 MHz, 2mA TYP. at 8 MHz (IDLE-2 mode) 11mA TYP. at 6 MHz, 15mA TYP. at 8 MHz In standby : (STOP mode) 500nA TYP.

- Built-in TLCS-Z80 series SIO capability
- A pair of independent full duplex channels supports the asynchronous as well as synchronous byte-oriented (monosync and bisync) and bit-oriented HDLC and CCITT-X. 25 protocols.
- Built-in CRC generation and check capability.
- Data transfer rates of up to 1200 K bits/sec (6 MHz) and 1800 K bits/sec (8 MHz)
- Built-in TLCS-Z80 series CTC capability Four independent built-in channels. The timer or counter modes can be set . Also available as the SIO baud rate generator.
- Built-in TLCS-Z80 series PIO capability Two programmable independent 8-bit I/O ports having handshaking capability One of 4 operation modes can be selected for each port by using the program:

Mode 0 (byte output mode) Mode 1 (byte input mode) Mode 2 (byte input/output mode) Mode 3 (bit mode)

- Built-in watchdog timer
- Programmed daisy-chain interrupt control
- Built-in dynamic RAM refresh controller
- TTL/CMOS compatible
- Housed compact standard 100-pin mini-flat package
- The Toshiba real time emulator (RTE80) and the Z80 ICE commercially available can be used (the TMPZ84C015A used as the evaluator).
- The Toshiba evaluator board installed.

note: Z80 is a trade mark of Zilog Inc.

## 2. PIN ASSIGNMENT AND FUNCTIONS

#### 2.1 PIN ASSIGNMENTS (TOP VIEW)



170489



Figure 2.1.1 Pin Assignments

### 2.2 (A) PIN FUNCTIOS

|        |                         |                         | (1/6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------|-------------------------|-------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin    | Q'ty<br>(Number)        | Туре                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| D0-D7  | 8<br>(82-89)            | Input/output<br>3-state | The 8-bit bi-directional data bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| A0-A15 | 16<br>(91-100)<br>(1-6) | Output<br>3-state       | The 16-bit address bus.<br>These pins specify memory and I/O port<br>addresses. During a refresh cycle, the refresh<br>address is output to the low-order 7 bits and<br>A7RF.                                                                                                                                                                                                                                                                                                               |
| M1     | 1 (8)                   | Output<br>3-state       | The Machine Cycle 1 signal.<br>In an operation code fetch cycle, this pin goes<br>"0" with the MREQ signal. At the execution of a<br>2-byte operation code, this pin goes "0" for each<br>operation code fetch. In a maskable interrupt<br>acknowledge cycle, this pin goes "0" with the<br>IORQ signal. When the EV signal is applied, this<br>pin is put in the high-impedance state.                                                                                                     |
| RD     | 1<br>(14)               | Output<br>3-state       | The Read signal. It indicates that the MPU is<br>ready for accepting data from memory or I/O<br>device. The data from the addressed memory or<br>I/O devices is gated by this signal onto the MPU<br>data bus. When the BUSREQ signal is applied,<br>this pin is put in the high-impedance state.                                                                                                                                                                                           |
| WR     | 1<br>(13)               | Output<br>3-state       | The Write signal. This signal is output when the data to be stored in the addressed memory or I/O device is on the data bus. When the BUSREQ signal is applied, this pin is put in the high-impedance state.                                                                                                                                                                                                                                                                                |
| MREQ   | 1<br>(17)               | Output<br>3-state       | The Memory Request signal. When the execution address for memory access is on the address bus, this pin goes "0". During a memory refresh cycle, this pin also goes "0" with RFSH signal.                                                                                                                                                                                                                                                                                                   |
| IORQ   | 1<br>(15)               | Output<br>3-state       | The Input/Output Request signal. This pin goes<br>"0" when the address for an I/O read or write<br>operation is on the low-order 8 bits (A0 through<br>A7) of the address bus. The $\overline{IORQ}$ signal is also<br>output with the $\overline{M1}$ signal at interrupt<br>acknowledge to tell an I/O device that the<br>interrupt response vector can be placed on the<br>data bus. Note that the interrupt priority among<br>the TMPZ84C015A CTC, and SIO is selected by a<br>program. |

|                |                   |                 | (2/6)                                                                                                                                                                                                                                                                                                                                                                                                                        |
|----------------|-------------------|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin            | Q'ty<br>(Number)  | Туре            | Function                                                                                                                                                                                                                                                                                                                                                                                                                     |
| IEO            | 1<br>(71)         | Output          | The Interrupt Enable Output signal. In the daisy<br>chain interrupt control, this signal controls the<br>interrupt from the peripheral LSIs connected<br>next to the TMPZ84C015A. The IEO pin goes "1"<br>only when the IEI pin is "1" and the MPU is not<br>servicing an interrupt from the built-in<br>peripheral LSI.                                                                                                     |
| XTAL1<br>XTAL2 | 2<br>(65)<br>(66) | Ìnput<br>Output | The crystal oscillator connection.<br>Connects an oscillator having the oscillation<br>frequency 2 times as high as the system clock<br>(CLKOUT) frequency.                                                                                                                                                                                                                                                                  |
| CLKIN          | 1<br>(69)         | Input           | The Single-phase Clock Input.<br>When the clock input is placed in the DC state<br>(continued "1" or "0" level), this pin stops<br>operating and holds the state of that time.<br>Normally, this pin is connected with the CLKOUT<br>pin. However, to operate the system with the<br>external clock, connect the external clock to the<br>CLKIN pin.                                                                         |
| CLKOUT         | 1<br>(68)         | Output          | The Single-phase Clock Output.<br>When a Halt instruction is executed in the Stop or<br>Idle-1 mode, the CLKOUT output is retained at<br>"0". In the Run and Idle-2 mode the clock is kept<br>output. This pin provides the clock to other<br>peripheral ICs.                                                                                                                                                                |
| RESET          | 1<br>(9)          | Input           | The Reset signal input. This signal resets the internal states of the TMPZ84C015A. This signal is also used to return from the standby state in the Stop or Idle mode.                                                                                                                                                                                                                                                       |
| ĪNT            | 1<br>(19)         | Input           | The Maskable Interrupt signal. An interrupt is<br>caused by the internal CTC, SIO PIO or the<br>peripheral LSI. An interrupt is acknowledged<br>when the interrupt enable flip-flop (IFF) is set to<br>"1" by software.<br>The INT pin is normally wire-ORed and requires<br>an external pullup resistor for these applications.<br>This signal is also used to return from the stand-<br>by state in the Stop or Idle mode. |
| WAIT           | 1<br>(11)         | Input           | The Wait Request signal. This signal indicates the MPU that the addressed memory or I/O device is not ready for data transfer. As long as this signal is "0", the MPU is in the Wait state.                                                                                                                                                                                                                                  |

(3/6)

| Pin                   | Q'ty<br>(Number) | Туре              | Function                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BUSREQ                | 1<br>(10)        | Input             | The Bus Request signal. The $\overline{\text{BUSREQ}}$ signal forces the MPU address bus, data bus, and control signals $\overline{\text{MREQ}}$ , $\overline{\text{IORQ}}$ , $\overline{\text{RD}}$ , and $\overline{\text{WR}}$ to be placed in the high-impedance state. This signal is normally Wire-ORed and requires an external pullup resistor for these applications.               |
| BUSACK                | 1<br>(12)        | Output            | The Bus Acknowledge signal. In response to the BUSREQ signal, the BUSACK signal indicates to the requesting peripheral LSI that the MPU address bus, data bus, and control signals MREQ, IORQ, RD and WR have been put in the high-impedance state.                                                                                                                                          |
| HALT                  | 1<br>(81)        | Output<br>3-state | The Halt signal. This pin goes "0" when the MPU has executed a Halt instruction and is in the Halt state. It is put in the high-impedance state when the EV signal is applied.                                                                                                                                                                                                               |
| RFSH                  | 1<br>(7)         | Output            | The refresh signal. When the dynamic memory refresh address is on the low-order 8 bits of the address bus, this signal goes "0". At the same time, the MREQ signal also goes active ("0"). This pin is put in the high-impedance state when the EV signal is applied.                                                                                                                        |
| CLK/TRG0<br>~CLK/TRG3 | 4<br>(78-81)     | Input             | The external clock/timer trigger. These 4<br>CLK/TRG pins correspond to 4 channels. In the<br>counter mode, the down counter is decremented<br>by 1 and in the timer mode, the timer is activated<br>at each active edge (a rising or falling edge) of<br>the signal which are input by these pins. It can be<br>selected by program whether the active edge is a<br>rising or falling edge. |
| ZC/TO0<br>~ZC/T03     | 4<br>(74-77)     | Output            | The Zero Count/Timer Out signal. In either the<br>Timer mode, or counter mode, pulses are output<br>from these pins when the down counter has<br>reached zero.                                                                                                                                                                                                                               |
| IEI                   | 1<br>(72)        | Input             | The Interrupt Enable Input signal. This signal is<br>used with the IEO to form a priority daisy chain<br>when there is more than one interrupt-driven<br>peripheral LSI.                                                                                                                                                                                                                     |
| NMI                   | 1<br>(63)        | Input             | The Non-maskable Interrupt Request signal.<br>This interrupt request has a higher priority than<br>the maskable interrupt and is not dependent on<br>the interrupt enable flip-flop (IFF) state. This<br>signal is also used to return from the stand-by<br>state in the Stop or Idle mode.                                                                                                  |

|         |                  |                         | (4/6)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin     | Q'ty<br>(Number) | Туре                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| EV      | 1<br>(67)        | Input                   | The Evaluator signal. When this signal is active,<br>the M1, HALT, and RFSH pins are put in the high-<br>impedance state. In using the TMPZ84C015A as<br>an evaluator chip, the MPU is electrically<br>disconnected (put in the high-impedance state)<br>after one machine cycle is executed with the EV<br>signal being "1" and the BUSREQ signal being<br>"0", and follows the instructions from other MPU<br>(such as the MPU of ICE). The signals of the<br>disconnected MPU are A00 through A15, D0<br>through D7, MREQ, IORQ, RD, WR, M1, HALT,<br>and RFSH. BUSACK needs to be disconnected by<br>an externally connected circuit. The evaluator<br>board is available to use the TMPZ84C015A as an<br>evaluator chip. |
| A7RF    | 1<br>(70)        | Output                  | The 1-bit auxiliary address bus. This pin outputs<br>the same signal as the bit 7 (A7) of the address<br>bus. However, during a refresh cycle, this pin<br>outputs the address which is the most significant<br>bit of the 8-bit refresh address signal linked to<br>the low-order 7 bits of the address bus.                                                                                                                                                                                                                                                                                                                                                                                                                 |
| ASTB    | 1<br>(21)        | Input                   | The Port A Strobe Pulse From Peripheral Device.<br>This signal is used at the handshaking between<br>port A and external circuits. The meaning of this<br>signal depends on the mode of operation<br>selected for port A. (See "PIO Basic Timing".)                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| BSTB    | 1<br>(61)        | Input                   | The Port B Strobe Pulse From Peripheral Device.<br>This signal is used at the handshaking between<br>port B and external circuits. The meaning of this<br>signal is the same as the $\overline{\text{ASTB}}$ signal except when<br>port A is in the mode 2.<br>(See "PIO Basic Timing".)                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| ARDY    | 1<br>(20)        | Output                  | The Register A Ready signal. This signal is used at<br>the handshaking between port A and external<br>circuits. The meaning of this signal depends on<br>the mode of operation selected for port A.<br>(See "PIO Basic Timing".)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| BRDY    | 1<br>(62)        | Output                  | The Register B Ready signal. This signal is used at<br>the handshaking between port B and external<br>circuits. The meaning of this signal is the same as<br>the ARDY signal except when port A is in the<br>mode 2. (See "PIO Basic Timing".)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PA0-PA7 | 8<br>(22-29)     | Input/Output<br>3-state | The Port Data A signal.<br>These signals are used for data transfer between<br>port A and external circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |

(5/6)

| Pin              | Q'ty<br>(Number) | Туре                    | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------------|------------------|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PBO-PB7          | 8<br>(53-60)     | Input/Output<br>3-state | The Port Data B signal.<br>These signals are used for data transfer between<br>port B and external circuits.                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| W/RDYA<br>W/RDYB | 2<br>(30, 52)    | Output                  | The Wait/Ready signal A and the Wait/Ready<br>signal B.<br>These signals can be used as the Wait or Ready<br>depending on SIO programming. When these<br>signals are programmed as "Wait", they go<br>active at "0" to indicate to the MPU that the<br>addressed memory or I/O devices are not ready<br>for data transfer, requesting the MPU to wait.<br>When these signals are programmed as "Ready",<br>they go active at "0" to determine when a<br>peripheral device associated with a DMA port is<br>ready for a read or write data. The DMA is<br>requested to transfer data. |
| SYNCA<br>SYNCB   | 2<br>(31, 51)    | Input/Output            | The Synchronization signal. In the asynchronous receive mode, these signals act as the $\overline{\text{CTS}}$ and $\overline{\text{DCD}}$ signals. In the external sync mode, these signals act as inputs and in the internal sync mode, they act as outputs.                                                                                                                                                                                                                                                                                                                       |
| RXDA<br>RXDB     | 2<br>(32, 50)    | Input                   | The Serial Receive Data signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| RXCA<br>RXCB     | 2<br>(33, 49)    | Input                   | The Receive Clock signal. In the asynchronous mode, the Receive Clocks may be 1, 16, 32 or 64 times the data transfer rate.                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| TXCA<br>TXCB     | 2<br>(34, 48)    | Input                   | The Transmitter Clock signal.<br>In the asynchronous mode, the Transmitter<br>Clocks may be 1, 16, 32, or 64 times the data<br>transfer rate.                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| TXDA<br>TXDB     | 2<br>(35, 47)    | Output                  | The serial transmit data signal.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| DTRA<br>DTRB     | 2<br>(36, 46)    | Output                  | The Data Terminal Ready signal. These signals<br>indicate whether the data terminal is ready to<br>receive serial data or not. When it is ready, these<br>signals go active to enable the transmitter of the<br>terminal. When it is not ready, these signals go<br>inactive to disable the transfer from the terminal.                                                                                                                                                                                                                                                              |
| RTSA<br>RTSB     | 2<br>(37, 45)    | Output                  | The Request to Send signal. These pins are "0"<br>when transmitting serial data. That is, to<br>transmit data, these signals are made active to<br>enable their receivers.                                                                                                                                                                                                                                                                                                                                                                                                           |

|              |                  |        | (6/6)                                                                                                                                                                                                                                                                                                                            |
|--------------|------------------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Pin          | Q'ty<br>(Number) | Туре   | Function                                                                                                                                                                                                                                                                                                                         |
| CTSA<br>CTSB | 2<br>(38, 44)    | Input  | The Clear To Send signal. When these pins are<br>"0", the modem having transmitted these signals<br>is ready to receive serial data. When it is ready,<br>these signals go active to enable the transmitter<br>of the terminal. When it is not ready, these<br>signals go inactive to disable the transfer from<br>the terminal. |
| DCDA<br>DCDB | 2<br>(39, 43)    | Input  | The Data Carrier Detect signal. When these pins<br>are "0" the receive of serial data can be enabled.<br>That is, to transmit data, these signals are made<br>active to enable their receivers.                                                                                                                                  |
| ICT          | 2<br>(40, 42)    | Output | The test pins. To be used in the open state.                                                                                                                                                                                                                                                                                     |
| WDTOUT       | 1<br>(73)        | Output | The Watchdog Timer signal.<br>The output pulse width depends on the<br>externally connected pin.                                                                                                                                                                                                                                 |
| VCC          | 2<br>(41, 90)    |        | The power supply ( + 5 V) pins.                                                                                                                                                                                                                                                                                                  |
| VSS          | 1<br>(16, 64)    |        | The ground (0 V) pins.                                                                                                                                                                                                                                                                                                           |

170489

# 2.2 (B) TMPZ84C015A Internal I/O Address Map

| Internal I/O                                  | Channel                                                                | I/O Address |
|-----------------------------------------------|------------------------------------------------------------------------|-------------|
|                                               | ch 0                                                                   | # 10        |
| СТС                                           | ch 1                                                                   | # 11        |
| (Counter Timer)                               | ch 2                                                                   | # 12        |
|                                               | ch 3                                                                   | # 13        |
|                                               | ch A Send/Receive buffer                                               | # 18        |
| SIO                                           | ch A Command/Status Register                                           | # 19        |
| (Serial I/O)                                  | ch B Send/Receive buffer                                               | # 1A        |
|                                               | ch B Command/Status Register                                           | # 1B        |
|                                               | A Port Data                                                            | # 1C        |
| PIO                                           | A Port Command                                                         | # 1D        |
| (Parallel I/O)                                | B Port Data                                                            | # 1E        |
|                                               | B Port Command                                                         | # 1F        |
| Watch Dog Timer<br>Stand-by mode Register     | WDTER, WDTPR, HALTMR                                                   | # F0        |
| Watch Dog Timer<br>command Register           | Clear command (4E <sub>H</sub> )<br>disable command (B1 <sub>H</sub> ) | # F1        |
| Daisy-chaine interrupt<br>precedence Register | Only use bit2~bit0                                                     | # F4        |
|                                               |                                                                        | 180489      |

### 3. OPERATIONAL DESCRIPTION

#### 3.1 BLOCK DIAGRAM AND OPERATIONAL OUTLINE

#### 3.1.1 Block Diagram



MPUZ80-573

#### 3.1.2 Operational Outline

The TMPZ84C015A largely consists of a processor (MPU), a counter/timer circuit (CTC), a serial input/output controller (SIO), a parallel input/output controller (PIO), a watchdog timer (WDT), and a clock generator/controller (CGC).

- The MPU provides all the capabilities and pins of the Toshiba TLCS-Z80 MPU (TMPZ84C00A) to play the role of the TLCS-Z80 microprocessor perfectly.
- The CTC provides the capabilities of the Toshiba TLCS-Z80 CTC (TMPZ84C30A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The four independent timer channels are I/O-addressed internally.
- The SIO provides the capabilities of the Toshiba TLCS-Z80 SIO (TMPZ84C43A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The two independent serial channels are I/O-addressed internally.
- The PIO provides the capabilities of the Toshiba TLCS-Z80 PIO (TMPZ84C20A) and has the pins required to perform the necessary operations as a TLCS-Z80 peripheral LSI. The two independent parallel ports are I/O-addressed internally.
- The WDT incorporates one-channel watchdog timer and the read/write-enabled watchdog timer control registers indispensable for control applications. The WDT also has the register to determine interrupt priorities, allowing the user to set the daisy-chain interrupt priorities by program. Additionally, the WDT has the IEI and IEO pins required to process the daisy- chain interrupts caused by the peripheral LSIs to be added both inside and outside the TMPZ84C015A.
- The CGC provides the four operation modes to control the entire TMPZ84C015A chip; the Run, Idle-1, Idle-2, and Stop modes. They are program-selectable. This chip has two clock pins: CLKOUT to supply clock from the CGC and CLKIN to get clock from the outside. Therefore, the TMPZ84C015A can be operated on the clock supplied from the outside at the CLKIN pin without using the CGC. The following briefly describes the four operation modes of the CGC with the CLKOUT and CLKIN pins connected:
- In the Run mode, the clock generated by the CGC is supplied to the TMPZ84C015A and peripheral LSIs to perform the normal programmed microcomputer operations.
- In the Idle-1 mode, clock oscillation is going on but the clock is not supplied to the TMPZ84C015A and peripheral LSI, thereby saving the system power consumption and shortening the time required for system restart.

- In the Idle-2 mode, clock oscillation is performed and the clock is output from the CLKOUT pin. The clock is supplied only to the CTC in the TMPZ84C015A, permitting a wake-up operation by the CTC. Like the Idle-1 mode, the Idle-2 mode saves the system power consumption and shortens the time required for system restart.
- In the Stop mode, clock oscillation is not performed and the system operation can be stopped completely. In this mode, the system can be restarted with the internal data retained with an extremely low power consumption level unique to the CMOS technology.

Note that these modes can be set only when the MPU has executed a HALT instruction.

Additionally, the TMPZ84C015A has also the EV pin which is used with the BUSREQ pin to put the MPU in the high-impedance state for electrical disconnection, thus functioning as an evaluator chip. That is, the MPU in the TMPZ84C015A is electrically disconnected by these two pins to implement the emulation by the signal from the in-circuit emulator (ICE). For emulation, one machine cycle is performed on the MPU in the TMPZ84C015A with EV being "1" and the BUSREQ being "0" then the emulation is performed as instructed by the MPU. The MPU signals to be disconnected are A00 through A15, D0 through D7, MREQ, IORQ, RD, M1, HALT, and RFSH, BUSACK needs to be disconnected by an externally connected circuit.

#### 3.2 MPU OPERATIONS

This subsection describes the system configuration, functions and the basic operation of the MPU of the TMPZ84C015A.

#### 3.2.1 Block Diagram

Figure 3.2.1 shows the block diagram of the MPU.



170489



MPUZ80-576

### 3.2.2 MPU System Configuration

The MPU has the configuration shown in Figure 3.2.1. The address signal is put on the address bus via the address buffer. The data bus is controlled for input or output by the data bus interface. Both the address and data buses are put in the high-impedance state by the BUSREQ signal input to make them available for other peripheral LSIs. The Opcode read from memory via the data bus is written to the instruction register. This Opcode is decoded by the instruction decoder. According to the result of the decoding, control signals are sent to the relevant devices. Receiving these control signals, the ALU performs various arithmetic operations. The register array temporarily hold the information required to perform operation.

The following describes the MPU's main components and functions which the user must understand to operate the TMPZ84C015A:

[1] Internal Register Groups

The configuration of the internal register groups is as follows:

(1) Main registers

A, F, B, C, D, E, H, L

(2) Alternate registers

A', F', B', C', D', E', H', L'

(3) Special purpose registers

I, R, IX, IY, SP, PC

Figure 3.2.3 shows the configuration of the internal register groups. The register groups, each being of a static RAM, consists of eighteen 8-bit registers and four 16-bit registers. The following describes the function of each register:

- (1) Main registers (A, F, B, C, D, E, H, L)
- (a) Accumulator (A)

The accumulator is an 8-bit register used for arithmetic and data transfer operations.

(b) Flag register (F) (see Figure 3.2.2)

The flag register is an 8-bit register to hold the result of each arithmetic operation. Actually, the 6 of the 8 bits are set("1")/reset("0") according to the condition specified by an instruction.





The following 4 bits are directly available to the programmer for setting the jump, call and return instruction conditions:





#### • <u>Sign flag (S)</u>

When the result of an operation is negative, the S flag is set to "1". Actually, the content of bit 7 of accumulator is stored in this flag.

Zero flag (Z)

When all bits turn out to be "0" s after operation, the Z flag is set to "1". Otherwise, it is set to "0". With a block search instruction (CPI, CPIR, CPD or CPDR), the Z flag is set to "1" if the source data and the accumulator data match. With a block I/O instruction (INI, IND, OUTI or OUTD), the Z flag is set to "1" if the content of the B register used as the byte counter is "0" at the end of comparison.

• Parity/overflow flag (P/V)

This flag has two functions. One is the parity flag (P) that indicates the result of a logical operation (AND A, B etc.). The P flag is set to "1" if the parity is even as a result of the operation on signed values by two's complement. It is reset to "0" if the parity is odd. With a block search instruction (CPI, CPIR, CPD or CPDR) and a block transfer instruction (LDI or LDD), the P flag indicates the state of the byte counter (register pair B and C). It is set to "1" if the byte counter is not "0" and reset to "0" when the byte counter becomes"0" (at the end of comparison or data transfer). The content of the interrupt enable flip-flop (IFF) is saved to the P flag when the contents of the R register or I register are transferred to the accumulator.

The other use of the P/V flag is the overflow flag (V) that indicates whether an overflow has occurred or not as a result of an arithmetic operation. The V flag is set to "1" when the value in the accumulator gets out of a range of the maximum value +127 and the minimum value -128 and therefore cannot be correctly represented as a two's complement notation.

Whether the P/V flag operates as the P flag or V flag is determined by the type of the instruction executed.

• <u>Carry flag (c)</u>

The C flag is set to "1" if a carry occurs from bit 7 of the accumulator or a borrow occurs as a result of an operation.

The following two flags are not available to the programmer for the test and set ("1)/reset ("0") purposes. They are internally used by the MPU for BCD arithmetic operations.

• <u>Half carry flag (H)</u>

The H flag is used for holding the carry or borrow from the low-order 4 bits of a BCD operation result. When a DAA instruction (decimal adjust) is executed, the MPU automatically uses the H flag to adjust the result of a decimal addition or

subtraction.

<u>Add/subtract flag (N)</u>

In BCD operation, algorithm is different between addition and subtraction. The N flag indicates whether the executed operation is addition or subtraction.

For change of the flag state depending on the instruction, see 3.2.4 "TMPZ84C015A Instruction Set".

(c) General-purpose registers (B, C, D, E, H, L)

General-purpose registers consist of 8 bits each. They are used as 16-bit register pairs (BC, DE, HL) as well as independent 8-bit registers to supplement the accumulator. The B register and the register pair BC are used as counters when a block I/O, block transfer, or search instruction is executed. The register pair HL has various memory addressing features as compared with the register pairs BC and DE.

(2) Alternate registers (A', F', B', C', D', E', H', L')

The configuration of the alternate register is exactly the same as that of the main registers. There is no instruction that handles the alternate registers directly. The data in the alternate registers are processed by moving them into the main registers by means of exchange instructions as shown below:

EX AF, AF'  $(A \leftrightarrow A', F \leftrightarrow F')$ 

EXX  $(B \leftrightarrow B', C \leftrightarrow C', D \leftrightarrow D', E \leftrightarrow E', H \leftrightarrow H', L \leftrightarrow L')$ 

When a hign-speed interrupt response has been requested within the system, these instruction can be used to quickly move the contents of the accumulator, flag registers, and general-purpose registers into the corresponding registers. This eliminates the need for transferring the register contents to/from the external stack during execution of the interrupt handling routine, thereby shortening the interrupt servicing time greatly.

- (3) Special purpose registers (I, R, IX, IY, SP, PC)
- (a) Interrupt page address register (I)

The TMPZ84C015A provides two kinds of interrupts: maskable interrupt (INT) and non-maskable interrupt (NMI). The maskable interrupt provides three modes (0, 1, and 2) in which the interrupt is handled. These modes can be selected by instructions IMO, IMI, and IM2 respectively. In Mode 2, any memory location can be called indirectly depending on the interrupt. For this purpose, the I register stores the high-order 8 bits of the indirect address. The low-order 8 bits are supplied from the interrupting peripheral LSI. This scheme permits calling the interrupt handling routine from any memory location in an extremely short access

time. For the details of interrupts, see [4] "Interrupt Capability".

(b) Memory refresh register (R)

The R register is used as the memory refresh counter when the dynamic RAM is used for memory. This permits using of the dynamic memory in the same manner as the static memory. This 8-bit register is automatically incremented for each instruction fetch. While the MPU decodes and executes the fetched instruction, the contents of the R register are synchronized with the refresh signal to place the low-order 7 bits and A7RF on the address bus. This operation is all performed by the MPU and, therefore, dose not need a special processing by program. The MPU operation is not delayed by this operation. During refresh, the contents of the I register are placed on the high-order 8 bits of the address bus.

(c) Index registers (IX, IY)

The two independent index registers IX and IY hold the 16-bit base address when used in the index addressing mode. In this addressing mode, the memory address obtained by adding the contents of an index register to the displacement value (for example, LD IX+40H) is specified. This mode is convenient for using data tables. Also these registers can be used separately for memory addressing and data retaining registers.

#### (d) Stack pointer (SP)

The stack pointer is a 16-bit register to provide the start address information in the stack area in the external RAM. The content of the stack pointer is decremented at the execution of a CALL instruction or PUSH instruction or interrupt handling and is incremented at the execution of a RET instruction or POP instruction. At the execution of a CALL instruction or interrupt handling, the current content of the program counter is saved into the stack. At the execution of a RET instruction, the content is restored from the stack to the program counter. These operations are all performed by the MPU automatically. However, the other registers are not saved or restored automatically. For the storing of the contents of these registers, an exchange instruction (EX or EXX) for alternate register, a PUSH or a POP instruction must be used. When a PUSH instruction is executed, the contents of the specified register are saved into the stack. When a POP instruction is executed, the contents of the stack are moved to the specified register.

These data are restored on a last-in, first-out basis. Use of the stack permits processing of multiple-level interrupts, deep subroutine nestings, and various data manipulation very easily. The stack pointer is not initialized in the hardware approach. Therefore, it is required to allocate the stack area in RAM to specify initialization (at the highest address of the stack area) in the initial program. (ex)

| MEN         | MORY A<br>(HEX               | DDRES<br>)           | s       | c         | M E M O R Y<br>ADDRESS<br>(HEX) | INSTR             |          | The contents of the SP before the instruction is accepted. |
|-------------|------------------------------|----------------------|---------|-----------|---------------------------------|-------------------|----------|------------------------------------------------------------|
| LOWER       | FFEB                         | CO                   | rection | li rectio | 1230                            | CALL              | 1500H    | FFF1                                                       |
|             | FFEC<br>FFED<br>FFEE<br>FFEF | B2<br>23<br>05<br>33 | save di | restore c | 1500<br>1501                    | push<br>push      | AF<br>BC | FFEF ; A=05, F=23<br>FFED ; B=B2, C=C0                     |
| ¥<br>HIGHER | FFFU                         |                      |         | Ļ         | 1600<br>1601<br>1602            | POP<br>POP<br>RET | BC<br>AF | FFEB<br>FFED<br>FFEF                                       |

The foregoing example shows the stack pointer and stack operations in which the instructions starting with the CALL at address 1230H and ending with the RET at address 1602H have been executed. However, it is assumed that there is no instruction or interrupt other than shown above that uses the stack during the execution. When the value of the stack pointer before executing the CALL instruction at address 1230H indicates address FFF1H, address 1233H is stored at addresses FFF0H and FFEFH because the CALL instruction consists of 3 bytes, then the stack pointer is decremented. Similarly, the data are saved or restored sequentially according to the instructions. These stack and stack pointer operations are all performed automatically.

(e) Program counter (PC)

The program counter holds, in 16 bits, the memory address of the instruction to be executed next. The MPU fetches the instruction from the memory location indicated by the program counter. When the content of the program counter is put on the address bus, the program counter is incremented automatically. However, it is not incremented with a jump instruction, a call instruction, or interrupt processing. Instead, the specified new address is set on it. With a return instruction, the content restored from the stack is set on the program counter. These operations are all performed automatically and therefore, no care is required for programming.

#### [2] Halt Capability

When a HALT instruction has been executed, the MPU is put in the halt state. The halt capability can be used to halt the MPU against the external interrupts, thereby reducing the power dissipation. In the halt state the states of MPU's internal registers are retained. The halt state is cleared by reset or when an interrupt is accepted.

For the details of halt operation, see [3] "Basic Timing."

(1) Halt operation

When a HALT instruction has been executed, the MPU sets the  $\overline{\text{HALT}}$  signal to "0" to indicate that the MPU is going to be put in the halt state. Actually, the MPU in the halt state automatically continues executing NOP instructions if there is the system clock input. However, the program counter is not incremented. This keeps the refresh signal generated when the dynamic memory is used. During halt, the MPU's internal states are retained. The TMPZ84C015A contains the clock generator/controller, easily implementing the clock input control for these halt operations.

(2) Releasing the halt state

The halt state is cleared by accepting an interrupt (the  $\overline{INT}$  or  $\overline{NMI}$  signal input) or by reset (the  $\overline{RESET}$  signal input). When an interrupt is accepted, the halt state is cleared and the interrupt handling routine is executed. However, a maskable interrupt (INT) cannot be accepted unless the interrupt enable flip-flop (IFF) is set.

Note that when the halt state is cleared by the  $\overline{\text{RESET}}$  signal, the MPU is reset and the program counter is set to "0".

[3] RESET Signal

Holding the  $\overline{\text{RESET}}$  pin at the low level ("0") under the following conditions, the MPU's internal states are reset:

- (1) The supply voltage level is within the operational voltage range.
- (2) System clock stabilization.
- (3) Holding the <u>RESET</u> signal at the low level ("0") for at least 3 full clock cycles. When the <u>RESET</u> signal goes high ("1"), the MPU starts executing instructions from address 0000H after at least 2T state dummy cycles.

When reset, the MPU performs the following processing:

(1) Program counter

0000H is set.

(2) Interrupt

The interrupt enable flip-flop (IFF) is reset to "0" to disable the maskable interrupt. For the maskable interrupt processing, mode 0 is specified.

#### (3) Control output

All control outputs are made inactive ("1"). Therefore, the halt state is also cleared.

(4) Interrupt page address register (I register)

The content of the R register becomes 00H.

(5) Refresh register (R register)

The content of the R register becomes 00H.

The contents of the registers other than above and the external memory do not change.

Therefore, they must be initialized as required.

[4] Interrupt Capability

The interrupt capability is used to suspend the execution of the current program and execute the processing of the requested peripheral LSI. Normally, this interrupt processing routine contains the data exchange and transfer of status and control information between the MPU and the peripheral LSI. When this routine has been completed, the MPU returns to the state active before the interrupt has been accepted.

The TMPZ84C015A provides the non-maskable interrupt (NMI) and maskable interrupt (INT) capabilities which are detected by the  $\overline{\rm NMI}$  and  $\overline{\rm INT}$  interrupt request signals, respectively. A non-maskable interrupt, when caused by a peripheral LSI, is accepted unconditionally. This interrupt is used to support critical functions such as the protection of the system from unpredictable happening including power failure. A maskable interrupt can be enabled or disabled by program. For example, if the timer is used and, therefore, an interrupt is not desired, the system can be programmed to disable the interrupt. Table 3.2.1 lists the processing by interrupt source.

(1) Interrupt enable/disable

A non-maskable interrupt cannot be disabled by program, while a maskable interrupt can be enabled or disabled by program. The MPU has the interrupt enable flip-flop (IFF). A maskable interrupt can be enabled or disabled by setting this flip-flop to "1" (set) or "0" (rest) through an EI instruction (enable) or a DI instruction (disable) in program. Actually, the IFF consists of two flip-flops IFF1 and IFF2. IFF1 is used to select between the enable and disable of a maskable interrupt. IFF2 holds the state of IFF1 before a maskable interrupt has been accepted. Both IFF1 and IFF2 are reset to "0" when any of the following conditions occurs, disabling an interrupt:

- MPU reset
- Execution of DI instruction
- Acceptance of maskable interrupt

Both IFF1 and IFF2 are set to "1" when the the following condition occurs, enabling an interrupt:

• Execution of EI instruction

Actually, the waiting maskable interrupt request is accepted after the execution of the instruction that following the EI instruction.

This delay by one instruction is caused by accepting an interrupt after completion of the execution of a return instruction if the instruction following the EI instruction is a return instruction.

In the above operation, the contents of IFF1 and IFF2 are the same.

| Interrupt Source          | Priority | Programmed condition |        | Vector addres             | Interrupt<br>return<br>instruction |
|---------------------------|----------|----------------------|--------|---------------------------|------------------------------------|
| Non-maskable interrupt    | 1        | None                 |        | Address 66H               | RETN                               |
| (the falling edge of NMI) |          |                      |        |                           |                                    |
|                           |          |                      |        | Instruction from          |                                    |
| Maskable interrupt (INT   | 2        | IFF = 1              | Mode 0 | peripheral LSI.           | (Note)                             |
| becomes "0" at            |          |                      |        | Normally, CALL or RST     | RETI                               |
| instruction's last clock) |          |                      | [      | instruction.              |                                    |
|                           |          |                      | Mode 1 | Address 38H.              |                                    |
|                           |          |                      |        | The address indicated by  |                                    |
|                           |          |                      |        | the data table (memory)   |                                    |
|                           |          |                      | Mode 2 | at the address specified  |                                    |
|                           |          |                      |        | by I register (high-order |                                    |
|                           |          |                      | 1      | 8 bits) and data from     |                                    |
|                           |          |                      |        | peripheral LSI (low-      |                                    |
|                           |          |                      |        | order 8 bits, LSB = "0"). |                                    |

Table 3.2.1 Processing by Interrupt Source

Note: Mode 0 applies when the instruction from peripheral LSI is CALL or RST instruction.



Figure 3.2.4 Interrupt Enable Flip-Flop (IFF)

When a non-maskable interrupt has been accepted, IFF1 is reset to "0" (interrupt disable) until an EI or RETN instruction is executed, so as to prevent from accepting the next interrupt. For this purpose, the state (interrupt enable/disable) of IFF1 immediately before non-maskable interrupt acceptance must be stored. This state is copied into IFF2 upon acceptance of a non-maskable interrupt. The content of IFF2 is copied into the parity flag at the execution of the following instructions, so that the copied data can be tested or stored:

- The load instruction (LD A, I) to load the contents of the I register into the accumulator.
- The load instruction (LD A, I) to load the contents of the R register into the accumulator.

When the return instruction (RETN) from the non-maskable interrupt is executed, the contents of the current IFF2 are copied back to IFF1. If an operation which changes the contents of IFF2 (due to the execution of EI or DI instruction, for example) has not been performed during interrupt handling, IFF1 automatically returns to the state immediately before the interrupt acceptance. Table 3.2.1 lists the states of IFF1 and IFF2 after execution of interrupt-related instructions.

170489

| Operation sequence | IFF1 | IFF2 | Remarks          |
|--------------------|------|------|------------------|
| MPU reset          | 0    | 0    |                  |
| EI                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| LD A, I            | *    | *    | Parity flag←IFF2 |
| RETN               | 1    | 1    | IFF1←IFF2        |
| LD A, R            | *    | *    | Parity flag←IFF2 |
| INT acceptance     | 0    | 0    |                  |
| RETI               | *    | *    |                  |
| EI                 | 1    | 1    |                  |
| NMI acceptance     | 0    | 1    |                  |
| DI                 | 0    | 0    |                  |
| RETN               | *    | *    |                  |

Table 3.2.2 State of IFF1 and IFF2

Note: \* = no change.

(2) Interrupt processing

With a non-maskable interrupt, the internal NMI flip-flop is set to "1" on the falling edge of the interrupt signal,  $\overline{\text{NMI}}$ . The state of this flip-flop is sampled on the rising edge of the last clock of each instruction to accept an interrupt. A maskable interrupt is accepted if the interrupt signal  $\overline{\text{INT}}$  is low ("0") on the rising edge of the last clock of each instruction and the interrupt enable state (IFF=1 and  $\overline{\text{BUSREQ}}$  signal=inactive ("1") ) is on. The following is the processing to be performed after a non-maskable interrupt and a maskable interrupt are accepted:

(a) Non-maskable interrupt (NMI)

When a non-maskable interrupt has been accepted, the MPU performs the following processing:

- 1 The internal NMI flip-flop is reset to "0".
- 2 IFF1 is reset to "0", disabling the maskable interrupt.

The contents of the IFF1 immediately before the interrupt acceptance are copied into the IFF2

- 3 The contents of the current program counter are saved into the stack.
- 4 The instructions starting from non-maskable interrupt vector address 66H are executed.

The non-maskable interrupt processing program terminates after executing the RETN instruction. This return instruction performs the following:

1 The contents of the current IFF2 are copied into IFF1.

2 The contents of the program counter are restored from the stack.



Figure 3.2.5 Non-Maskable Interrupt Processing

(b) Maskable interrupt (INT)

When a maskable interrupt has been accepted, the MPU performs the following processings:

- 1 Both IFF1 and IFF2 are reset to "0", disabling the maskable interrupts.
- 2 The contents of the current program counter are saved into the stack.

3 A maskable interrupt is serviced in one of the three modes 0, 1 and 2. A mode is selected by executing the instruction IMO, IM1 or IM2 before the interrupt is serviced. The instructions are executed starting from the vector address corresponding to the selected mode.

• Mode 0

In mode 0, the interrupting peripheral LSI puts a restart instruction (RST) or a call instruction (CALL) on the data bus and the MPU executes the interrupt service routine according to that instruction. At reset, this mode is automatically set.



Address specified by CALL or Execution of RETI instruction RST from peripheral LSI.



Mode 1

When an interrupt is accepted in mode 1, restart is performed from address 0038H. Therefore, the service routine for this interrupt is programmed from the address 0038H.



Figure 3.2.7 Interrupt Processing in Mode 1

• <u>Mode 2</u>

The interrupt processing in mode 2 requires a 16-bit pointer consisting of the high-order 8 bits of the I register and the low-order 8 bits (with the LSB = "0") of the data fetched from the interrupting CTC or TLCS-Z80 family peripheral LSI. Therefore, the necessary value must be loaded in the I register beforehand. This pointer is used to specify the memory address in the table. The contents of the specified address and the next address provide the start address of the service routine. Therefore, use of this mode requires the table of the service routine's start address (16 bits) to be set at appropriate location under software control. This location can be anywhere in memory. The LSB of the table pointer is set to "0" because a 2-byte data is needed to specify the service routine start address in 16 bits and start that address from an even-number address. In the table, the start that address begins with the low-order byte followed by the high-order byte as shown in Figure 3.2.8.


Figure 3.2.8 Interrupt Processing in Mode 2

Mode 2 is used in the daisy chain interrupt processing using the CTC and TLCS-Z80 family LSI. The CTC and TLCS-Z80 family peripheral LSIs all contain the interrupt priority controller in daisy chain structure. In this interrupt structure, the interrupt request signals are connected one after another and given priorities for processing when two or more maskable interrupt requests occur at a time. Only the interrupt vector from the peripheral LSI having the highest priority is put on the data bus. By receiving the interrupt vector in mode 2, the processing for that peripheral LSI can be performed. When an interrupt requested by a peripheral LSI having a priority higher than that of the current peripheral LSI during the execution of the interrupt processing routine, the higher priority interrupt can be enable by the EI instruction to form a interrupt nesting.

The maskable interrupt processing program terminates by executing an RETI instruction. This return instruction performs the following processings:

- Restores the content of the program counter from the stack.
- Notifies the requesting peripheral LSI of the termination of interrupt processing.

#### 3.2.3 MPU Status Transition Diagram and Basic Timing

The following describes the MPU status transition and the basic timing of each MPU operation.

[1] Instruction Cycle

Each TMPZ84C015A instruction is executed by combining the basic operations of memory read/write, input/output, bus request/acknowledge, and interrupt. These basic operations are performed synchronizing with the system clock (the CLK signal).

One clock period is called a state (T). The smallest unit of each basic operation is called a machine cycle (M). Each instruction consists of 1 to 6 machine cycles and each machine cycle consists of 3 to 6 clock states basically. However, the number of clock states in a machine cycle can be increased by the WAIT signal described later on. Figure 3.2.9 shows an example of the basic timing of a 3-machine-cycle instruction.

The first machine cycle (M1) of each instruction is the cycle in which the Opcode of the instruction to be executed next is read (this is called the Opcode fetch cycle). The Opcode fetch cycle basically consists of 4 to 6 clock states. In the machine cycle that follows the Opcode fetch cycle, data is transferred between the MPU and the memory or peripheral LSIs. This operation basically consists of 3 to 5 clock states.





### TOSHIBA





170489

#### MPUZ80-592

#### [3] Basic Timing

(1) Opcode fetch cycle (M1)

In the Opcode fetch cycle, MPU fetches an Opcode in the machine-language codes in memory. This is also called the M1 cycle because it is the first machine cycle to execute each instruction.

Figure 3.2.12 shows the basic timing of a basic Opcode fetch cycle.

In clock state T1, the content of the program counter is put on the address bus. The  $\overline{\text{M1}}$  signal goes "0", indicating to the MPU that this is the Opcode fetch cycle. At the same time,  $\overline{\text{MREQ}}$  and  $\overline{\text{RD}}$  signals go "0". When the  $\overline{\text{MREQ}}$  signal goes "0", the address signal has already been stabilized. Therefore, this signal can be used for the memory chip enable signal. The  $\overline{\text{RD}}$  signal indicates that the MPU is ready to accept the data from memory. By these signals, the MPU accesses memory to fetch the Opcode in the instruction register. The MPU samples the  $\overline{\text{WAIT}}$  signal on the falling edge of clock state T2. If the  $\overline{\text{WAIT}}$  signal is "0" on the falling edge of clock state T2 and the following wait state (TW), the next state becomes clock state TW. Figure 3.2.13 shows the delay state of the Opcode fetch cycle caused by the  $\overline{\text{WAIT}}$  signal.

The data (Opcode) on the data bus is fetched on the rising edge of clock state T3 then, the  $\overline{\text{MREQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{MI}}$  signals go "1". In clock state T3, a memory refresh address is put on the 8 bits consisting of the low-order 7 bits of the address bus and the A7RF corresponding to bit 8 and the  $\overline{\text{RFSH}}$  signal goes "0" and the  $\overline{\text{MREQ}}$ signal goes "0" again. This signal indicates that the memory refresh cycle is on. At this time, the contents of the I register are put on the high-order 8 bits of the address bus and the 7 bits of the R register contents and the A7RF signal corresponding to bit 8 are put on the low-order 8 bits of the address bus. By using the  $\overline{\text{RFSH}}$  and  $\overline{\text{MREQ}}$  signals, memory refresh is performed in clock state T3 and T4. However, the  $\overline{\text{RD}}$  signal remains "1" because the contents of the memory refresh address are not put on the data bus.

The address bus of 8 bits consisting of the address low-order 7 bits of address (A6 through A0) and the A7RF are used as the 8-bit refresh address. That is, when A7RF is used for the refresh address, signals "00H" through "FFH" are output. In cycles other than the refresh cycle, the signal equivalent to A7RF are output. However, at reset, the signals to be output are uncertain. Figure 3.2.11 shows the refresh timing.



Figure 3.2.11 Refrish Timing

In clock state T4, the  $\overline{\text{MREQ}}$  signal returns to "1". The refresh address is kept output until the rising edge of the clock state T1 in the next machine cycle, keeping the  $\overline{\text{RFSH}}$  signal set to "0". The cycle delay state caused by setting the  $\overline{\text{WAIT}}$  signal to "0" is the same in the memory read/write, input/output, and maskable interrupt acknowledge cycles. The diagram of the cycle delay state caused by the  $\overline{\text{WAIT}}$  signal set to "0" is omitted in the following description.



Figure 3.2.12 Opcode Fetch Timing

MPUZ80-594



Figure 3.2.13 Opcode Fetch Timing Including Wait State

#### (2) Memory read/write operations

Figure 3.2.14 shows the basic timing of memory read/write operations (except for the Opcode fetch cycle) in the same diagram for convenience.

In each operation, the memory address signal to read/write data on the address bus is output in clock state T1. The operation in which the  $\overline{WAIT}$  signal is sampled in clock state T2 and the following TW state is the same as the Opcode fetch cycle.

In memory read, memory data is put on the data bus by the address  $\overline{\text{MREQ}}$ , and  $\overline{\text{RD}}$  signals. The MPU reads this data.

In memory write, the memory address signal is put on the address bus then the  $\overline{\text{MREQ}}$  signal is set to "0" to put the write data onto the data bus. When the data bus has been stabilized the  $\overline{\text{WR}}$  signal is output in clock state T2. The  $\overline{\text{WR}}$  signal can be used as the memory write signal.





#### (3) Input/output operations

Figure 3.2.15 shows the basic timing of input/output operations. The feature of the I/O operation timing is that, regardless of the state of the WAIT signal in clock state T2, the I/O cycle automatically goes in the wait state (TW\*) after clock T2. The WAIT signal is sampled on the falling edge of TW\*. If the WAIT signal is "0" on the falling edges of TW\* and the following clock state, the I/O operation enters into clock state TW\*. Clock state TW\* is inserted because the  $\overline{IORQ}$  signal goes "0" in clock state T2, so that it is too late to sample the WAIT signal after decoding the I/O port address. In each of input and output operations, the I/O port address is put on the low-order 8 bits of the address bus in clock state T1. On the high-order 8 bits, the contents of the accumulator or B register are output. In clock state T2, the  $\overline{IORQ}$  signal goes "0" instead of the MREQ signal. The  $\overline{IORQ}$  signal can be used as the chip enable signal for a peripheral LSI.

In an input operation, the contents of the input port are read onto the data bus by the address,  $\overline{\text{IORQ}}$ , or  $\overline{\text{RD}}$  signals. The MPU reads this data.

In an output operation, the output port address and the output data are respectively put on the address bus and data bus in clock state Tl, then the  $\overline{IORQ}$  and  $\overline{WR}$  signals go "0" in clock state T2. The  $\overline{WR}$  signal can be used as the output port write signal.



Figure 3.2.15 I/O Operating Timing

#### (4) Bus request and bus acknowledge operations

Figure 3.2.16 shows the basic timing of bus request and bus acknowledge operations.

The address bus (A0 through A15), data bus (D0 through D7),  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ , and  $\overline{\text{WR}}$  signals controlled by the MPU can be put in the high-impedance state (floating) to electrically disconnect them from the MPU. This operation, after sampling the  $\overline{\text{BUSREQ}}$  signal on the rising edge of the last clock of each machine cycle, starts on the rising edge of the next clock if this signal is found "0".

Subsequently, these buses are controlled by external peripheral LSIs. For example, data can be directly transferred between memory and these peripheral LSIs. This state is cleared if the  $\overline{\text{BUSREQ}}$  signal is found"1"after sampling it on the rising edge of each subsequent clock state (TX), and enters into the next machine cycle. During the floating state, the  $\overline{\text{BUSACK}}$  signal goes "0" to indicate it to the peripheral LSIs.

In this state, however, no memory refresh is performed and, therefore, the  $\overline{\text{RFSH}}$  signal is set to "1". Hence, to maintain this state for a long time with a system using dynamic memory, memory refresh must be performed by the external controller.

Note that, in the floating state, neither maskable interrupt (INT) nor nonmaskable interrupts (NMI) can be accepted.



Figure 3.2.16 Bus Request and Bus Acknowledge Timing

(5) Maskable interrupt acknowledge operation

Figure 3.2.17 shows the basic timing of the maskable interrupt acknowledge.

The MPU samples the maskable interrupt request signal (INT) on the rising edge of the last clock of each instruction execution. If the INT signal is found "0", a maskable interrupt is accepted except in the following cases:

- The interrupt enable flip-flop is reset to "0".
- The **BUSREQ** signal is "0".

When a maskable interrupt has been accepted, a special Opcode fetch cycle is generated. In this cycle, 2 clock states of wait state (TW\*) is automatically inserted after the clock state T2. The WAIT signal is sampled on the falling edges of the second clock state TW\* and the following clock state TW and, if the WAIT signal is found "0", the instruction cycle enters in the next clock state TW. In this Opcode fetch cycle, the  $\overline{IORQ}$  signal goes "0" in the first TW\* state instead of the MREQ signal while, in a normal Opcode fetch cycle, the  $\overline{MREQ}$  signal goes "0" in clock state T1. This indicates to the maskable interrupt requesting LSI that the 8-bit interrupt vector can be put on the data bus. The MPU reads this data to perform interrupt processing. Therefore, the contents of the program counter put on the address bus are not used. Unlike an ordinary I/O operation, the  $\overline{RD}$  signal does not go "0".

In clock state T3 the memory refresh address signal is put on the address bus for memory refresh like normal Opcode fetch cycle and the  $\overline{\text{RFSH}}$  signal goes "0". In the subsequent machine cycles (M2 and M3), the contents of the current program counter are saved into the stack. In machine cycles M4 and M5, the contents of the I register (the high-order 8 bits) and the contents of the address indicated by the address of the vector (the low-order 8 bits) from the CTC and the peripheral LSI are fetched in the program counter.





#### (6) Non-maskable interrupt acknowledge operation

Figure 3.2.18 shows the basic timing of non-maskable interrupt acknowledge. When the non-maskable interrupt request signal ( $\overline{\rm NMI}$ ) goes low, the internal non-maskable flip-flop is set to "1". The  $\overline{\rm NMI}$  signal is detected in any timing of each instruction. However, the internal NMI flip-flop is sampled on the rising edge of the last clock of each instruction. Therefore, the  $\overline{\rm NMI}$  signal should go low by the last clock state of an instruction. The Opcode fetch cycle for non-maskable interrupt request acknowledge is generally the same as the ordinary Opcode fetch cycle. However, the Opcode on the data bus at the time is ignored. The contents of the current program counter are saved into the stack in the subsequent machine cycles (M2 and M3). In the following machine cycle, the operation jumps to address 0066H, the non-maskable interrupt vector address. The machine cycles after these depend on the contents of the fetched Opcode.



Figure 3.2.18 Non-Maskable Inpterrupt Acknowledge Timing

(7) Halt operation

When a HALT instruction is fetched in the Opcode fetch cycle, the MPU sets the HALT signal to "0" synchronized with the falling edge of clock state T4 to indicate it to the peripheral LSI and stops operating. If the system clock is kept supplied in the halt state, the MPU continues executing NOP instructions. This is done to output refresh signals when the dynamic memory is used. The NOP instruction execution cycle is the same as the ordinary Opcode fetch cycle except the data on the data bus are ignored.

The halt state is cleared when an interrupt is accepted or the RESET signal is set to "0" to reset the MPU. Figure 3.2.19 shows the halt state clear operation by interrupt acknowledge. An interrupt is sampled on the rising edge of the last clock (clock state T4) of the NOP instruction. A maskable interrupt can be accepted when the  $\overline{INT}$  signal is "0". A non-maskable interrupt is accepted when the internal NMI flip-flop which is set on the falling edge of the  $\overline{NMI}$  signal is set at

"1". However, it is required that the interrupt enable flip-flop is set to "1" for a maskable interrupt to be accepted. The interrupt processing for the accepted interrupt starts from the next cycle.

However, when the supply of the system clock from the CGC has been stopped by the power down operation, it is required to restart the supply of the system clock and input the  $\overline{\text{INT}}$  signal until the execution of one instruction is completed or the RESET signal until 3 clocks are output. Figure 3.2.20 shows the timing of clearing the halt state caused by power down.

For the reset operation, see (8) "Reset operation". Note that the  $\overline{INT}$  and  $\overline{NMI}$  signals are shown on the same diagram in Figures 3.2.19 and 3.2.20 for convenience.



Figure 3.2.19 Timing of Clearing Halt State Caused by Interrupt Acknowledge





MPUZ80-601

#### (8) Reset operation

Figure 3.2.21 shows the basic timing of reset operation.

To reset the MPU, the  $\overline{\text{RESET}}$  signal must be kept at "0" for at least 3 clocks. When the  $\overline{\text{RESET}}$  signal goes "1", instruction execution starts from address 0000H after a dummy cycle of at least 2T clock states.



Figure 3.2.21 Reset Timing

To clear the power down state by using the  $\overline{\text{RESET}}$  signal, the  $\overline{\text{RESET}}$  signal must be input until 3 clocks or more are supplied by restarting the supply of the system clock from the CGC.

#### (9) Evaluation operation

Each of the MPU signals (A0 through A15, D0 through D7,  $\overline{\text{MREQ}}$ ,  $\overline{\text{IORQ}}$ ,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ ,  $\overline{\text{HALT}}$ ,  $\overline{\text{M1}}$ , and  $\overline{\text{RFSH}}$ ) can be put in the high-impedance state by EV and  $\overline{\text{BUSREQ}}$  signals to electrically disconnect them from the MPU.



Figure 3.2.22 Evaluation Timing

Figure 3.2.23 shows the block diagram of the TMPZ84C015A operating as an evaluator in the evaluation mode.

The operations controlled by signals from the external MPU in the evaluation mode are the same as those of each device constituting the TMPZ84C015A. (However, for the watchdog timer operations, see "WDT Operational Description" because the watchdog timer is of random logic configuration.)

For the electrical characteristics and timing of each device, see "Inactive State".

## TOSHIBA



170489



MPUZ80-604

### 3.2.4 TMPZ84C015A Instruction Set

This subsection lists the TMPZ84C015A instruction codes and their functions. The table below lists the symbols and abbreviations used to describe the instruction set. The symbols which require special attention are described in the locations in which they appear.

• Symbols (1/2)

| Classification | Symbol          |                       | Meaning                  |
|----------------|-----------------|-----------------------|--------------------------|
| Register       | r, g            | Register              | B, C, D, E, H, L, A,     |
|                | t               | Register pair         | BC, DE, HL               |
|                |                 | Stack pointer         | SP                       |
|                | q               | Register pair         | BC, DE, HL, AF           |
|                | р               | Register pair         | BC, DE                   |
|                |                 | Index register        | IX                       |
|                |                 | Stack pointer         | SP                       |
|                | S               | Register pair         | BC, DE                   |
|                |                 | Index register        | IY                       |
|                |                 | Stack pointer         | SP                       |
|                | t <sub>H</sub>  | Higher register of    | register pair            |
|                |                 |                       | (B, D, H)                |
|                |                 | Higher 8 bits of sta  | ack pointer (SP)         |
|                | qн              | Higher register of    | register pair            |
|                |                 |                       | (B, D, H, A)             |
|                | IX <sub>H</sub> | Higher 8 bits of inc  | dex register IX          |
|                | IY <sub>H</sub> | Higher 8 bits of inc  | dex register IY          |
|                | PCH             | Higher 8 bits of pr   | ogram counter (PC)       |
|                | tL              | Lower register of r   | egister pair             |
|                |                 | _                     | (C, E, L)                |
|                |                 | Lower 8 bits of sta   | ck pointer (SP)          |
|                | qL              | Lower register of r   | egister pair             |
|                |                 | _                     | (C, E, L, F)             |
|                | IXL             | Lower 8 bits of ind   | ex register IX           |
|                | IYL             | Lower 8 bits of ind   | ex register IY           |
|                | PCL             | Lower 8 bits of pro   | ogram counter (PC)       |
|                | rb              | Bit b (0-7) of regist | er (B, C, D, E, H, L, A) |

## • Symbols (2/2)

| Classification     | Symbol                                                                    | Meaning                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|--------------------|---------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Memory             | mn<br>(HL) <sub>b</sub><br>(IX + d) <sub>b</sub><br>(IY + d) <sub>b</sub> | Memory address represented in 16 bits.<br>m indicates higher 8 bits and n, lower 8 bits.<br>Bit b (0-7) of the contents of the memory<br>address indicated by register pair HL.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IX.<br>Bit b (0-7) of the contents of the memory<br>address indicated by the value obtained by<br>adding 8-bit data d to the content of index<br>register IX. |
| Flag change symbol | 0<br>1<br>*<br>X<br>P                                                     | Reset to "0" by operation.<br>Set to "1" by operation.<br>No change<br>Affected by operation<br>Undefined<br>Handled as parity flag.<br>P = 0: odd parity<br>P = 1: even parity<br>Handled as overflow flag.<br>V = 0: No overflow<br>V = 1: Overflow                                                                                                                                                                                                                                               |
| Operator           | ←<br>+<br>-<br>~<br>♥                                                     | Transfer<br>Exchange<br>Add<br>Subtract<br>Logical and between bits.<br>Logical or between bits.<br>Exclusive or between bits                                                                                                                                                                                                                                                                                                                                                                       |
| Others             | IFF<br>CY<br>Z                                                            | Interrupt enable flip-flop<br>Carry flag<br>Zero flag                                                                                                                                                                                                                                                                                                                                                                                                                                               |

## TMPZ84C015A Instruction Set (1/9)

| ITEM/<br>CLASSI | Assembler                | Object                                 | code                | Eurotion           |                      |   |        | FI | ag     |               |   |          | No.<br>Of     | No.<br>OF   |                         |
|-----------------|--------------------------|----------------------------------------|---------------------|--------------------|----------------------|---|--------|----|--------|---------------|---|----------|---------------|-------------|-------------------------|
| -FICA-<br>TION  | mnemonic                 | Binary<br>76 543 210                   | Hex                 | Punction           | s                    | Z |        | н  |        | P/V           | N | с        | CY.<br>CLES   | STA-<br>TES |                         |
|                 | LD r,g<br>LD r,n         | 01 rrr ggg<br>00 rrr 110               | 40+r×8+g<br>06+r×8  | r+g<br>r+n         | <u>-</u><br>-        | - | X<br>X | -  | X<br>X | -             | - | -        | <u>1</u><br>2 |             | r rrr                   |
|                 | LD r,(HL)<br>LD r,(IX+d) | 01 rrr 110<br>11 011 101               | n<br>46+r×8<br>DD   | r←(HL)<br>r←(IX+d) | <br><del></del><br>- | - | X<br>X | -  | X<br>X | -<br>-        | - | -        | 2<br>5        | 7<br>19     | 9 999<br>B 000<br>C 001 |
|                 | LD r,(IY+d)              | 01 rrr 110<br>dd ddd ddd<br>11 111 101 | 46+r×8<br>d<br>FD   | r←(IY+d)           |                      | - | x      | -  | x      | -             | - | -        | 5             | 19          | D 010<br>E 011<br>H 100 |
|                 | LD (HL).r                | 01 rrr 110<br>dd ddd ddd<br>01 110 rrr | 46+r×8<br>d<br>70+r |                    |                      | - | x      | -  | x      | _             | _ | -        |               | 7           | L 101<br>A 111          |
|                 | LD (IX+d),r              | 11 011 101<br>01 110 rrr<br>dd ddd ddd | DD<br>70+r<br>d     | (IX+d)←r           | -                    | - | x      | -  | x      | -             | - | -        | 5             | 19          |                         |
| ٥               | LD (IY+d),r              | 11 111 101<br>01 110 rrr               | FD<br>70+r          | (IY+d)←r           | -                    | - | х      | -  | x      | -             | - | -        | 5             | 19          |                         |
| r o 4           | LD (HL),n                | 00 110 110<br>nn nnn nnn               | 36<br>n             | (HL)+n             | -                    | - | x      | -  | x      | -             | - | -        | 3             | 10          |                         |
| DATA            | LD (IX+d), n             | 11 011 101<br>00 110 110<br>dd ddd ddd | 36<br>d             | (1X+d)+n           | -                    | - | х      | -  | х      | -             | - | -        | 5             | 19          |                         |
| BIT             | LD (IY+d),n              | 11 111 101<br>00 110 110<br>dd ddd ddd | FD<br>36<br>d       | (IY+d)+n           | -                    | - | X      | -  | X      | -             | - | -        | 5             | 19          |                         |
| 8               | LD A,(BC)<br>LD A,(DE)   | nn nnn nnn<br>00 001 010<br>00 011 010 | n<br>0A<br>1A       | A←(BC)<br>A←(DE)   | <br>                 | - | X<br>X | -  | X<br>X | <u>-</u><br>- |   | -        | 2<br>2        | 7           |                         |
|                 | LD A,(mn)                | 00 111 010<br>nn nnn nnn<br>mm mmm mmm | 3A<br>n<br>m        | A←(mn)             | -                    | - | х      | -  | x      | -             | - | -        | 4             | 13          |                         |
|                 | LD (BC),A                | 00 000 010                             | 02                  | (BC)←A             | -                    |   | х      | _  | x      | -             | _ | -        | 2             | 7           |                         |
|                 | LD (DE),A                | 00 010 010                             | 12                  | (DE)+A             | -                    | - | Х      | -  | X      | -             | - | -        | 2             | 7           |                         |
|                 | LD (mn),A                | 00 110 010<br>nn nnn nnn<br>mm mmm mmm | 32<br>n<br>m        | (mn)+A             | -                    | - | х      | -  | x      | -             | - | -        | 4             | 13          |                         |
|                 | LD A,I                   | 11 101 101<br>01 010 111               | ED<br>57            | A←I                | *                    | * | Х      | 0  | x      | IFF           | 0 | -        | 2             | 9           |                         |
|                 | LD A,R                   | 11 101 101<br>01 011 111               | ED<br>5F            | A←R                | *                    | * | Х      | 0  | X      | IFF           | 0 | -        | 2             | 9           |                         |
|                 | LD I,A                   | 11 101 101<br>01 000 111               | ED<br>47            | I+A                | -                    | - | X      | -  | X      | -             | - | -        | 2             | 9           |                         |
|                 | LD R,A                   | 01 001 101                             | 4F                  | R←A                | -                    | - | X      | -  | X      | -             | - | -        | 2             | 9           |                         |
| DAT⊅<br>LOAD    | LU U, mil                | 55 CCO 001<br>55 NNN 55N<br>MM MMM MMM | u<br>01+1 × 10      | - uni              | -                    | - | *      | -  | *      | -             | - | -        | 3             | 10          | t tt<br>BC 00           |
| 6 - B I T       | LD IX,mn                 | 11 011 101<br>00 100 001<br>nn nnn nnn | DD<br>21<br>n       | IX←mn              | -                    | - | X      | -  | X      | -             | - | -        | 4             | 14          | DE 01<br>HL 10<br>SP 11 |
| L               |                          | mm mmm mmm                             | m                   | I                  |                      |   |        |    |        |               |   | <u> </u> |               |             |                         |

Note : r,g means any of the registers A, B, C, D, E, H, L.

IFF in "Flag" column indicates that the content of the interrupt enable flip-flop is copied into the P/V flag.

### TMPZ84C015A Instruction Set (2/9)

| ITEM/<br>CLASSI | Assembler             | Object                                               | code               |                                                          |   |   |        | F | lag    |     |   |   | No.<br>OF   | No.<br>OF   |                |
|-----------------|-----------------------|------------------------------------------------------|--------------------|----------------------------------------------------------|---|---|--------|---|--------|-----|---|---|-------------|-------------|----------------|
| -FICA-<br>TION  | mnemonic              | Binary<br>76 543 210                                 | Hex                | Function                                                 | s | z |        | н |        | P/V | N | с | CY-<br>CLES | STA-<br>TES |                |
|                 | LD IY,mn              | 11 111 101<br>00 100 001<br>nn nnn nnn               | FD<br>21<br>n      | IY←mn                                                    | - | - | x      | - | x      | -   | - | - | 4           | 14          |                |
|                 | LD HL,(mn)            | mm mmn mmm<br>00 101 010<br>nn nnn nnn               | m<br>2A<br>n       | H←(mn+1)<br>L←(mn)                                       | - | - | x      | - | x      | -   | - | - | 5           | 16          | t tt<br>BC 00  |
|                 | LD t,(mn)             | 11 101 101<br>01 tt1 011<br>nn nnn nnn               | ED<br>4B+t×10<br>n | tH+(mn+1)<br>tL+(mn)                                     | - | - | x      | - | x      | -   | - | - | 6           | 20          | HL 10<br>SP 11 |
|                 | LD IX,(mn)            | mm mmm mmm<br>11 011 101<br>00 101 010               | m<br>DD<br>2A      | IXH←(mn+1)<br>IXL←(mn)                                   | - | - | x      | - | x      | -   | - | - | 6           | 20          |                |
| LOAD            | LD IY,(mn)            | mm mmm mmm<br>11 111 101<br>00 101 010<br>nn nnn nnn | FD<br>2A<br>n      | IYH←(mn+1)<br>IYL←(mn)                                   | - | - | x      | - | x      | -   | - | - | 6           | 20          |                |
| DATA            | LD (mn),HL            | mm mmm mmm<br>00 100 010<br>nn nnn nnn<br>mm mmm mmm | m<br>22<br>n<br>m  | (mn+1)+H<br>(mn)+L                                       | - | - | x      | - | x      | -   | - | - | 5           | 16          |                |
| B I T [         | LD (mn),t             | 11 101 101<br>01 tt0 011<br>nn nnn nnn               | ED<br>43+t×10<br>n | (mn+1)←tH<br>(mn)←tL                                     | - | - | x      | - | x      | -   | - | - | 6           | 20          |                |
| 16 -            | LD (mn),IX            | mm mmm mmm<br>11 011 101<br>00 100 010<br>nn nnn nnn | m<br>DD<br>22<br>n | (mn+1)←IX <sub>H</sub><br>(mn)←IXL                       | - | - | x      | - | x      | -   | - | - | 6           | 20          |                |
|                 | LD (mn),IY            | 11 111 101<br>00 100 010<br>nn nnn nnn               | FD<br>22<br>n      | (mn+1)←IYH<br>(mn)←IYL                                   | - | - | x      | - | x      | -   | - | - | 6           | 20          |                |
|                 |                       |                                                      | FO                 | SD4Hi                                                    |   |   |        |   |        |     |   |   | ·           |             |                |
|                 | LD SP,IX              | 11 011 101<br>11 111 001                             | DD<br>F9           | SP+IX                                                    | - | - | x      | - | x      | -   | - | - | 2           | 10          |                |
|                 | LD SP,IY              | 11 111 101<br>11 111 001                             | FD                 | SP←IY                                                    | - | - | X      | - | x      | -   | - | - | 2           | 10          |                |
|                 | PUSH q                | 11 qq0 101                                           | C5+q×10            | (SP-2)←qL,(SP-1)←qH,<br>SP←SP-2                          | - | - | X      | - | X      | -   | - | - | 3           | 11          | q qq<br>BC 00  |
|                 | PUSH IX               | 11 011 101<br>11 100 101                             | DD<br>E5           | (SP-2)+IXL,(SP-1)+IXH<br>SP+SP-2                         | - | - | х      | - | x      | -   | - | - | 4           | 15          | DE 01<br>HL 10 |
|                 | PUSH IY               | 11 111 101<br>11 100 101                             | FD<br>E5           | (SP-2)+IYL,(SP-1)+IY <sub>H</sub><br>SP+SP-2             | - | - | х      | - | x      | -   | - | - | 4           | 15          | AF 11          |
|                 | POP q                 | 11 qq0 001                                           | C1+q×10            | qH←(SP+1),qL←(SP),<br>SP←SP+2                            | - | - | x      | - | x      | -   | - | - | 3           | 10          |                |
|                 | POP IX                | 11 011 101<br>11 100 001                             | DD<br>E1           | IX <sub>H</sub> ←(SP+1),IX <sub>L</sub> ←(SP)<br>SP←SP+2 | - | - | X      | - | x      | -   | - | - | 4           | 14          |                |
| 1               | POP IY                | 11 111 101<br>11 100 001                             | FD<br>E1           | IY <sub>H</sub> ←(SP+1),IY <sub>L</sub> ←(SP)<br>SP←SP+2 | - | - | X      | - | x      | -   | - | - | 4           | 14          |                |
| *1              | EX DE,HL<br>EX AF,AF' | 11 101 011<br>00 001 000                             | EB<br>08           | DE⇔HL<br>AF⇔AF′                                          |   | - | X<br>X | - | X<br>X | -   | - | - | 1.          | 4           |                |
| L               | EXX                   | 11 011 001                                           | D9                 | BC⇔BC′,DE⇔DE′,HL⇔HL′                                     | - | - | Х      | - | X      |     | - | - | 1           | 4           |                |

Note : t is any of the register pairs BC, DE, HL, SP.

q is any of the register pairs AF, BC, DE, HL.  $(PAIR)_{H}$ ,  $(PAIR)_{L}$  refer to high order and low order eight bits of the register pair respectively. (Ex)  $BC_{L} = C$ ,  $AF_{H} = A$ .

120489

\*1 : EXCHANGE

MPUZ80-608

### TMPZ84C015A Instruction Set (3/9)

| ITEM/                                                                                              | Assembles     | Object     | code    |                                                 |            |           |          | c     | 20     |                |   |              | No.       | No.        |                          |
|----------------------------------------------------------------------------------------------------|---------------|------------|---------|-------------------------------------------------|------------|-----------|----------|-------|--------|----------------|---|--------------|-----------|------------|--------------------------|
| CLASSI                                                                                             | mnemonic      | Binary     | Hex     | Function                                        |            |           |          |       |        |                |   |              | OF<br>CY- | OF<br>STA- |                          |
| TION                                                                                               |               | 76 543 210 |         |                                                 | s          | z         |          | н     |        | P/V            | N | с            | CLES      | TES        |                          |
| ш                                                                                                  | EX (SP),HL    | 11 100 011 | E3      | H⇔(SP+1),L⇔(SP)                                 |            |           | X        | -     | X      | -              | - | <del>.</del> | 5         | 19         |                          |
| Z                                                                                                  | EX (SP),IX    | 11 011 101 | DD      | IX <sub>H</sub> ⇔(SP+1)                         | -          | -         | х        | -     | х      | -              | - | -            | 6         | 23         |                          |
| Ē                                                                                                  | FY (SP) TY    |            | FD      | $IX_{\downarrow} \leftrightarrow (SP)$          | - <u>-</u> | ŀ         |          | ···_· |        | ·              |   | ···_·        | <br>6     | 23         |                          |
| Ň                                                                                                  | LA (0),11     | 11 100 011 | E3      | IY <sub>I</sub> ↔(SP)                           |            |           | Î        |       | Ŷ      |                |   |              | ľ         |            |                          |
|                                                                                                    | LDI           | 11 101 101 | ED      | (DE)←(HL),DE←DE+1                               | -          | -         | x        | 0     | Х      | *м             | 0 | -            | 4         | 16         |                          |
|                                                                                                    |               | 10 100 000 | A0      | HL←HL+1,BC←BC−1                                 |            | ļ         | ļ        |       |        |                |   |              |           | ļ          |                          |
|                                                                                                    | LDIR          | 11 101 101 | ED      | (DE)+(HL), DE+DE+1                              | -          | -         | X        | 0     | х      | 0              | 0 | -            | 5         | 21         | ←[BC< >0]                |
| ~                                                                                                  |               | 10 110 000 | BU      | RC=0                                            |            |           |          |       |        |                |   |              | 4         | 16         | €[BC=0]                  |
| ω                                                                                                  | LDD           | 11 101 101 | ٤D      | (DE)←(HL),DE←DE-1                               |            | -         | ι<br>Σ   | 0     | x      | * <sub>M</sub> | 0 | _            | 4         | 16         |                          |
| S U                                                                                                |               | 10 101 000 | A8      | HL+HL-1,BC+BC-1                                 |            |           |          |       |        |                |   |              | l         |            |                          |
| Z Z<br>Z Z                                                                                         | LDDR          | 11 101 101 | ED      | (DE)←(HL),DE←DE-1                               | -          | -         | Х        | 0     | Х      | 0              | 0 | -            | 5         | 21         | ←[BC < >0]               |
| ы<br>В 1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1<br>1 |               | 10 111 000 | B8      | HL←HL−1,BC←BC−1 Repeat until                    |            |           |          |       |        |                |   |              | 4         | 16         | ←[BC=0]                  |
|                                                                                                    | CDI           | 11 101 101 | ED      | BC=0                                            |            |           |          |       |        |                |   |              |           | 16         |                          |
| ΰΰ                                                                                                 | CPI           | 10 100 001 | A1      | $HL \leftarrow HL + 1$ , $BC \leftarrow BC - 1$ | Γ.         | - N       |          |       | ^      | M              | 1 | _            | 4         | 10         |                          |
| 20                                                                                                 | CPIR          | 11 101 101 | ED      | A-(HL),HL←HL+1,BC←BC-1                          | *          | * M       | X        | •     | х      | *м             | 1 | _            | 5         | 21         | ←[BC< >0 &               |
| <u>ه</u> ه                                                                                         |               | 10 110 001 | B1      | Repeat until A=(HL) or BC=0                     | l          |           | <u>.</u> |       |        |                |   |              | 4         | 16         | A<> (HL)]                |
|                                                                                                    | CPD           | 11 101 101 | ED      | A-(HL)                                          | *          | *N        | Х        | ٠     | х      | *м             | 1 | -            | 4         | 16         | A= (HL)]                 |
|                                                                                                    |               | 10 101 001 | A9      | HL←HL−1,BC←BC−1                                 | l          |           |          |       |        |                |   |              |           |            |                          |
|                                                                                                    | CPDR          | 11 101 101 | ED      | A-(HL), HL+HL-1, BC+BC-1                        | •          | *N        | X        | *     | х      | *м             | 1 | -            | 5         | 21         | ←[BC< >0 &<br>A< > (HL)] |
|                                                                                                    | ADD A.c       | 10 000 ccc | 80+r    | A+A+r                                           | +          | *         | Y Y      |       | x      | v              | 0 |              | 4         | 10         | ⊾[BC=0 or                |
|                                                                                                    | ADD A,n       | 11 000 110 | C6      | A←A+n                                           | *          | *         | X        | ٠     | X      | v              | 0 | ٠            | 2         | 7          | A= (HL)]                 |
|                                                                                                    |               | nn nnn nnn | n       |                                                 |            | l         |          |       |        |                |   |              | l         | l          | A                        |
|                                                                                                    | ADD A,(HL)    | 10 000 110 | 86      | A←A+(HL)                                        |            |           | X        |       | Х      | V              | 0 | . •          | 2         | 7          | r rrr                    |
|                                                                                                    | ADD A,(IX+d)  | 11 011 101 | DD      | A←A+(IX+d)                                      | *          | •         | X        | *     | х      | v              | 0 | •            | 5         | 19         | B 000                    |
| 1                                                                                                  |               | 10 000 110 | 86      |                                                 |            | 1         | 1        |       |        |                |   |              |           |            | C 001                    |
| U U                                                                                                | ADD A. (IY+d) | 11 111 101 | FD      | A←A+(IY+d)                                      | *          | •         | Ϋ́       | *     | x      | v              | 0 | •            | 5         | 19         | D 010                    |
| 5                                                                                                  |               | 10 000 110 | 86      |                                                 |            |           |          |       |        |                |   |              |           |            | H 100                    |
| 2                                                                                                  |               | dd ddd ddd | d       |                                                 |            | <u>.</u>  | <u>.</u> |       |        |                |   |              |           |            | L 101                    |
|                                                                                                    | ADC A,r       | 10 001 rrr | 88+r    | A←A+r+CY                                        |            | . •       | X        | ٠     | X      | ٧              | 0 |              | 1         | 4          | A 111                    |
| z                                                                                                  | ADC A,n       | 11 001 110 | CE      | A←A+n+CY                                        | *          | *         | X        | *     | х      | v              | 0 | •            | 2         | 7          |                          |
| <                                                                                                  |               | 10 001 110 | n<br>95 |                                                 | ·          |           |          |       |        |                |   |              |           | ····       |                          |
| 2                                                                                                  | ADC A.(IX+d)  | 11 011 101 | DD      | A+A+(IX+d)+CY                                   | *          | •         | X X      |       | ^<br>X | :¥<br>: v      | 0 | •            | 5         | 19         |                          |
| ⊢ .                                                                                                |               | 10 001 110 | 8E      |                                                 |            | 1         | 1        |       |        |                |   |              |           |            |                          |
| Σ                                                                                                  |               | dd ddd ddd | d       |                                                 | ]          |           |          |       |        |                |   |              |           | l          |                          |
| T T                                                                                                | ADC A,(IY+d)  | 11 111 101 | FD      | A←A+(IY+d)+CY                                   | •          | ٠         | X        | •     | х      | v              | 0 | ٠            | 5         | 19         |                          |
| -                                                                                                  |               | 10 001 110 | 8E      |                                                 |            |           | 1        |       |        |                |   |              |           |            |                          |
| ₹                                                                                                  | SUB r         |            | 90+r    |                                                 |            | •         | Y        | •     | Y      | · · · · · ·    |   | •            | 1         |            |                          |
| ⊢ ⊢                                                                                                | SUB n         | 11 010 110 | D6      | A←A−n                                           |            | •         | :.^<br>X |       | ^<br>X | · · · · ·      | 1 | •            | 2         | 4.         |                          |
| -                                                                                                  |               | nn nnn nnn | n       |                                                 |            |           |          |       |        |                |   |              | <u> </u>  |            |                          |
| <b>'</b>                                                                                           | SUB (HL)      | 10 010 110 | 96      | A←A-(HL)                                        | •          | •         | X        | ٠     | Х      | v              | 1 | ٠            | 2         | 7          |                          |
| <sup></sup>                                                                                        | SUB (IX+d)    | 11 011 101 | DD      | A+A-(IX+d)                                      | +          | ٠         | Х        | ٠     | х      | v              | 1 | ٠            | 5         | 19         |                          |
|                                                                                                    |               | 10 010 110 | 96      |                                                 |            |           |          |       |        |                |   |              |           |            |                          |
|                                                                                                    | (LIN (TV))    | dd ddd ddd | d<br>ED |                                                 |            | - <u></u> | }-;      |       | ŀ      | ļ              |   |              | <u>.</u>  | 1.         |                          |
|                                                                                                    | 306 (1174)    | 10 010 110 | 96      | [ A*A=(11+0)                                    | ١Ť.        | Ť         |          | Ţ     | ^      | v              | 1 | Ť            | °         | 1.19       |                          |
| 1                                                                                                  |               |            | d       |                                                 |            | :         | 1        |       |        |                |   |              |           |            |                          |

Note : \*M P/V flag is 0 if the result of BC - 1 = 0, otherwise P/V = 1.

\*N Z flag is 1 if A = (HL), otherwise Z = 0.

[ ]indicates the total condition of the number of cycles and states indicated by arrow.

r means any of the registers A, B, C, D, E, H, L.

### TMPZ84C015A Instruction Set (4/9)

| ITEM/<br>CLASSI | Assembler                  | Object                                 | code               | Eurotion                     |   |          |            | F      | lag      |        |        |        | No.<br>OF   | No.<br>OF   |                         |
|-----------------|----------------------------|----------------------------------------|--------------------|------------------------------|---|----------|------------|--------|----------|--------|--------|--------|-------------|-------------|-------------------------|
| -FICA-<br>TION  | mnemonic                   | 76 543 210                             | Hex                | Tunction                     | s | Z        |            | н      |          | P/V    | N      | с      | CY-<br>CLES | STA-<br>TES |                         |
|                 | SBC A,r<br>SBC A,n         | 10 011 rrr<br>11 011 110               | 98+r<br>DE<br>n    | A←A−r−CY<br>A←A−n−CY         | * | *        | X<br>X     | *      | X<br>X   | V<br>V | 1<br>1 | *      | 1<br>_2     | 4           | r rrr<br>B 000<br>C 001 |
|                 | SBC A,(HL)<br>SBC A,(IX+d) | 10 011 110<br>11 011 101<br>10 011 110 | 9E<br>DD<br>9E     | A+A-(HL)-CY<br>A+A-(IX+d)-CY | * | *        | X<br>X     | *      | X<br>X   | v<br>v | 1<br>1 | *      | 2<br>5      | 7<br>19     | D 010<br>E 011<br>H 100 |
|                 | SBC A,(IY+d)               | 11 111 101<br>10 011 110<br>dd ddd ddd | d<br>FD<br>9E<br>d | A+A-(IY+d)-CY                | * | *        | X          | ٠      | x        | v      | 1      | •      | 5           | 19          | A 111                   |
|                 | AND r<br>AND n             | 10 100 rrr<br>11 100 110               | A0+r<br>E6         | A←A∧r<br>A←A∧n               | * | *        | X<br>X     | 1<br>1 | X<br>X   | P<br>P | 0<br>0 | 0<br>0 | 1<br>2      | 4           |                         |
| 0 - 0           | AND (HL)                   | nn nnn nnn<br>10 100 110               | n<br>A6            | A←A∧(HL)                     |   | *        | x          | 1      | x        | Р      | 0      | 0      | 2           | 7           |                         |
| L O             | ANU (1X+0)                 | 10 100 100<br>10 100 110<br>dd ddd ddd | A6<br>d            | A←A/\(1X+0)                  | * | *        | х          | 1      | X        | Р      | 0      | 0      | 5           | 19          |                         |
| D N A           | AND (IY+d)                 | 11 111 101<br>10 100 110<br>dd ddd ddd | FD<br>A6<br>d      | A←A∧(IY+d)                   | * | *        | х          | 1      | х        | Р      | 0      | 0      | 5           | 19          |                         |
| U<br>-          | OR r<br>OR n               | 10 110 rrr<br>11 110 110               | B0+r<br>F6         | A←A∨r<br>A←A∨n               | * | *        | X<br>X     | 0<br>0 | X<br>X   | P<br>P | 0<br>0 | 0<br>0 | 1<br>2      | 4           |                         |
| M E             | OR (HL)                    | nn nnn nnn<br>10 110 110               | n<br>B6            | A←A∨(HL)                     | * | •        | x          | 0      | X        | Р      | 0      | 0      | 2           |             |                         |
| H F I           | OR (1X+d)                  | 10 110 110<br>10 110 110<br>dd ddd ddd | B6<br>d            | A~A\(11+0)                   |   |          | X          | U      |          | ٢      | U      | U      | 5           | 19          |                         |
| A<br>R          | OR (IY+d)                  | 11 111 101<br>10 110 110<br>dd ddd ddd | FD<br>B6           | A←A∨(IY+d)                   | * | *        | х          | 0      | х        | Р      | 0      | 0      | 5           | 19          |                         |
| ⊢               | XOR r                      | 10 101 rrr                             | A8+r               | A+A+r                        | * |          | Y          |        | ·        | p      | 0      | 0      | 1           | ····        |                         |
| 8               | XOR n                      | 11 101 110<br>nn nnn nnn               | EE                 | A←A₩n                        | * | *        | X          | 0      | X        | Р      | 0      | 0      | 2           | 7           |                         |
| ω               | XOR (HL)                   | 10 101 110                             | AE                 | A←A <del>∀</del> (HL)        | * | ٠        | X          | 0      | x        | р      | 0      | 0      | 2           | 7           |                         |
|                 | XOR (IX+d)                 | 11 011 101<br>10 101 110<br>dd ddd ddd | DD<br>AE<br>d      | A←A∀(IX+d)                   | * | *        | x          | 0      | x        | р      | 0      | 0      | 5           | 19          |                         |
|                 | XOR (IY+d)                 | 11 111 101<br>10 101 110<br>dd ddd ddd | FD<br>AE<br>d      | A←A∀(IY+d)                   | * | *        | Х          | 0      | х        | р      | 0      | 0      | 5           | 19          |                         |
|                 | CP r                       | 10 111 rrr                             | B8+r               | A-r                          | * | *        | Х          | *      | X        | v      | 1      | *      | 1           | 4           |                         |
|                 | CP n                       | 11 111 110<br>nn nnn nnn               | FE                 | A-n                          | * | *        | X          | *      | х<br>    | v      | 1      | *      | 2           | 7           |                         |
|                 | CP (HL)                    | 10 111 110                             | BE                 | A-(HL)                       | * | <b>*</b> | <u>х</u> . |        | <u> </u> | v      | . 1    |        | 2           | 7           |                         |
|                 | CP (IX+d)                  | 11 011 101<br>10 111 110<br>dd ddd ddd | DD<br>BE<br>d      | A-(IX+d)                     | * | *        | Х          | •      | X        | V      | 1      | *      | 5           | 19          |                         |
|                 | CP (IY+d)                  | 11 111 101<br>10 111 110<br>dd ddd ddd | FD<br>BE<br>d      | A-(IY+d)                     | * | *        | Х          | *      | x        | ٧      | 1      | *      | 5           | 19          |                         |
| 1               | INC r                      | 00 rrr 100                             | 04+r×8             | r←r+1                        | * | *        | X          |        | x        | v      | 0      | -      | 1           | 4           | 1                       |
| 1               | INC (HL)                   | 00 110 100                             | 34                 | (HL)←(HL)+1                  | * | *        | X          | *      | х<br>Х   | v      | 0      | _      | 3           | 11          |                         |
| 1               | INC (IX+d)                 | 11 011 101                             | DD                 | (IX+d)←(IX+d)+1              | * | *        | X          | ٠      | X        | v      | 0      | -      | 6           | 23          | 1                       |
|                 |                            | 00 110 100<br>dd ddd ddd               | 34<br>d            |                              |   |          |            |        |          |        |        |        |             |             |                         |

Note : r means any of the registers A, B, C, D, E, H, L.

## TMPZ84C015A Instruction Set (5/9)

| ITEM/      | Assembler  | Object     | code      |                            |              |                |               | F            | lag               |                |          |                      | No.<br>OF      | No.  |       |
|------------|------------|------------|-----------|----------------------------|--------------|----------------|---------------|--------------|-------------------|----------------|----------|----------------------|----------------|------|-------|
| -FICA-     | mnemonic   | Binary     | Hex       | Function                   |              |                |               |              |                   |                |          |                      | CY-            | STA- |       |
| TION       |            | 76 543 210 |           |                            | s            | z              |               | н            |                   | P/V            | N        | С                    | CLES           | TES  |       |
| U          | INC (IY+d) | 11 111 101 | FD        | (IY+d)←(IY+d)+1            | *            | *              | х             | *            | х                 | v              | 0        | -                    | 6              | 23   |       |
| Ē          |            | 00 110 100 | 34        |                            |              |                |               |              |                   |                |          |                      |                |      |       |
| ш<br>5     |            | dd ddd ddd | d         |                            |              |                |               |              |                   |                |          |                      |                |      |       |
| Ξų         |            | 00 110 101 | 05+r×8    | $\Gamma + \Gamma - I$      |              |                | . X.          |              | . X.              | V              | 1        |                      | 11             | 4    |       |
| - 0        | DEC (TX+d) | 11 011 101 | 00        | $(12)^{-}(12)^{-1}$        |              |                |               |              | ·                 | · · · · ·      |          | · · <del>·</del> · · |                |      | C 001 |
| 4 U        | 000 (17.0) |            | 35        |                            |              |                | 1             |              | · ^               |                | 1        |                      | ľ              | 23   | D 010 |
| Õ          |            | dd ddd ddd | d         |                            |              |                |               |              |                   |                |          |                      |                |      | E 011 |
|            | DEC (IY+d) | 11 111 101 | FD        | (IY+d)←(IY+d)-1            | *            | *              | x             | *            | x                 | v              | 1        | _                    | 6              | 23   | H 100 |
| m 0        |            | 00 110 101 | 35        |                            |              |                |               |              |                   |                | 1        |                      |                |      | L 101 |
| ∞∢         |            | bbb bbb bb | d         |                            |              |                |               |              |                   |                |          |                      |                |      | A 111 |
| -          | DAA        | 00 100 111 | 27        | Decimal adjust accumulator | *            | *              | Х             | *            | Х                 | Р              | -        | *                    | 1              | 4    |       |
| R O        | CPL        | 00 101 111 | 2F        | A←Ā                        | -            | -              | X             | 1            | X                 | -              | 1        | -                    | 1              | 4    |       |
| Ż          | NEG        | 11 101 101 | ED        | A←0-A                      | *            | *              | Х             | ٠            | Х                 | v              | 1        | ٠                    | 2              | 8    |       |
| Ö          |            | 01 000 100 | 44        |                            |              |                | ļ             |              |                   | ļ              | <u>.</u> |                      |                |      |       |
|            | CCF        | 00 111 111 | 3F        | CY←CY                      |              |                | X             | Х.           | X                 |                | 0        |                      | 1              | 4    |       |
| L L        | SCF        | 00 110 111 | 37        | CY+1                       |              |                | Х.,           | 0            | X                 | <del>.</del>   | 0        | . 1                  | 11             | 4    |       |
| ≥          | NOP        | 00 000 000 | 00        | no operation               |              |                | <u>; Х.</u>   |              | <u>    X     </u> | ļ <del>.</del> |          |                      | 1.             | 4    |       |
| ND O       | HALT       | 01 110 110 | 76        | MPU Halted                 |              | ļ <del>.</del> | <u>; х</u> ., |              | <u> </u>          | ļ <del>.</del> |          |                      | 1              | 4    |       |
| d A        |            |            | F3        | 1 1FF + 0                  | <del>.</del> | ·. <del></del> | X             | <del>.</del> | . X               | ļ <del></del>  |          |                      | 11.            | 4    |       |
| ΣU         | 1 E1       |            | FB        |                            |              |                | . <u>X</u> .  |              | . <u>X</u>        | ·              | ÷        |                      | <u>1</u> .     |      |       |
| ΞĒ         | IM U       | 01 000 110 | 46        | set interrupt mode o       | -            | -              | : ^           | -            | `                 | -              | -        | -                    | 2              | 8    |       |
| ΨΣ         | тм 1       | 11 101 101 | FD        | Set interrupt mode 1       |              | · · · · ·      | v             |              |                   | <u></u>        | ·        | ·····                | ·····          |      |       |
| L L        |            | 01 010 110 | 56        | set menupt mode i          |              | -              | ^             |              | ^                 |                |          |                      | 6              | Ů    |       |
| и и<br>И и | IM 2       | 11 101 101 | ED        | Set interrupt mode 2       | - 1          |                | X             | _            | χ                 | :<br>:<br>-    | î _ 1    | -                    | 2              | 8    |       |
| ⊳∢         |            | 01 011 110 | 5E        | 1                          |              |                |               |              |                   |                |          |                      | -              |      | 1     |
|            | ADD HL,t   | 00 tt1 001 | 09+t×10   | HL←HL+t                    | -            | -              | X             | Х            | Х                 | -              | 0        | ٠                    | 3              | 11   | t tt  |
|            | ADC HL,t   | 11 101 101 | ED        | HL←HL+t+CY                 | *            | *              | X             | Х            | Х                 | v              | 0        | ٠                    | 4              | 15   | BC 00 |
|            |            | 01 tt1 010 | 4A+t×10   |                            |              | İ              | ļ             |              |                   | <u>.</u>       |          |                      |                |      | DE 01 |
| -          | SBC HL,t   | 11 101 101 | ED        | HL←HL−t−CY                 | *            | *              | Х             | Х            | Х                 | v              | 1        | ٠                    | 4              | 15   | HL 10 |
| +          |            | 01 tt0 010 | 42+t×10   |                            |              |                | ļ             |              |                   | ļ              | <u>.</u> |                      |                |      | SP 11 |
| Ξ          | ADD IX,p   | 11 011 101 | DD        | IX←IX+p                    | -            | -              | X             | Х            | Х                 | -              | 0        | *                    | 4              | 15   |       |
| н          |            | 00 pp1 001 | 09+p×10   |                            |              |                |               |              |                   | ļ              | ļ        |                      |                |      | p pp  |
| -          | ADD IY,S   |            | FU        | IA+IA+2                    | -            | -              | X             | х            | X                 |                | 0        | *                    | 4              | 15   | BC 00 |
| AR         | TNC +      | 00 551 001 | 02++ × 10 | +4++1                      |              |                |               |              | ·                 | <b>.</b>       |          |                      |                |      |       |
|            |            |            | 03+1 × 10 |                            |              |                |               |              | ·                 | <u>.</u>       |          | <del>.</del>         | <u>1</u> .     | 10   | SD 11 |
| -          | INC IX     |            | 23        | 10,10,1                    | -            | -              | ^             |              | ^                 | -              |          | -                    | 1 <sup>2</sup> | 10   |       |
|            |            |            | FD        |                            |              | <u></u>        | Y             | ·····        | y.                | †              | <u></u>  | ·····                |                | 10   | 5 55  |
| ف          |            | 00 100 011 | 23        |                            |              |                | 1             |              |                   | 1              |          |                      | 1              | 10   | BC 00 |
| -          | DEC t      | 00 tt1 011 | 0B+t×10   | t+t−1                      |              | -              | x             | -            | x                 | -              | -        |                      | 1              | 6    | DE 01 |
|            | DEC IX     | 11 011 101 | DD        | IX+IX-1                    | -            | -              | X             | -            | X                 | -              | - 1      | -                    | 2              | 10   | IY 10 |
|            |            | 00 101 011 | 2B        |                            |              |                |               |              |                   |                |          |                      |                |      | SP 11 |
|            | DEC IY     | 11 111 101 | FD        | IY+IY-1                    | -            | -              | Х             | -            | х                 | -              | -        | -                    | 2              | 10   |       |
|            |            | 00 101 011 | 2B        |                            |              |                |               |              |                   |                |          |                      |                |      |       |
| ROTATE     | RLCA       | 00 000 111 | 07        | CY 7 + 0 +                 | -            | -              | x             | 0            | x                 | -              | 0        | ٠                    | 1              | 4    |       |

Note : ss is any of the register pairs BC, DE, HL, SP. PP is any of the register pairs BC, DE, IX, SP. rr is any of the register pairs BC, DE, IY, SP.

# TMPZ84C015A Instruction Set (6/9)

| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ITEM/<br>CLASSI | Assembler  |            |               | Object       | code             | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |   |   |     | F | lag      |            |          |       | No.<br>OF   | No.<br>OF   |                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|------------|------------|---------------|--------------|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----|---|----------|------------|----------|-------|-------------|-------------|----------------|
| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -FICA-<br>TION  | mnemonic   | 76         | Bin<br>543    | ary<br>210   | Hex              | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | s | z | -   | н |          | P/V        | N        | с     | CY-<br>CLES | STA-<br>TES |                |
| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 | RLA        | 00         | 010           | 111          | 17               | $\begin{array}{c} \hline CY \\ \hline A \end{array}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | - | - | x   | 0 | x        | -          | 0        | *     | 1           | 4           |                |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 | RRCA       | 00         | 001           | . 111        | OF               | $\begin{array}{c} \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | - | - | x   | 0 | x        | -          | 0        | •     | 1           | 4           |                |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 | RRA        | 00         | 011           | . 111        | 1F               | $ \begin{array}{c} \hline \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | - | - | x   | 0 | x        | -          | 0        | •     | 1           | 4           |                |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                 | RLC r      | 11         | 001           | 011          | СВ               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | * | * | X   | 0 | X        | Р          | 0        | *     | 2           | 8           | r rrr          |
| $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 | RIC (HL)   | 00         | 000           | 011          | 00+r<br>CB       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | • | Y   |   | <br>¥    | р          |          | <br>• |             | 15          | B 000          |
| $ \begin{array}{c} \begin{matrix} RLC (IX+d) & II \ 01I \ 10I \ 01O \\ II \ 00I \ 00I \ CS \\ dd \ ddd \ ddd \ dd \\ dd \ dd \ ddd \ dd \\ dd \ ddd \ dd \ dd \\ dd \ ddd \ dd                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                 | 1.20 (112) | 00         | 000           | 110          | 06               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   | Î.  |   | <u>^</u> | · ·        |          |       |             | 15          | D 010          |
| $ \begin{array}{c} 1 & 0 & 0 & 0 & 1 & 0 & 0 & 0 & 1 & 0 & 0$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 | RLC (IX+d) | 11         | 011           | 101          | DD               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | • | ٠ | Х   | 0 | х        | р          | 0        | ٠     | 6           | 23          | E 011          |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | +               |            | 11<br>  dd | . 001<br>Iddd | 011<br>ddd   | d                | $\begin{bmatrix} CY \\ \leftarrow IX + d \end{bmatrix} \leftarrow 0 \\ (IX + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d) \\ (IY + d$ |   |   | -   |   |          |            |          |       |             |             | H 100<br>L 101 |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | -               |            | 00         | 000           | 110          | 06               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |     |   |          |            | <u>.</u> |       |             |             | A 111          |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ВH              | RLC (IY+d) | 11         | 111           | 101          | FD               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | • | ٠ | х   | 0 | х        | Р          | 0        | ٠     | 6           | 23          |                |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1               |            | dd         | ddd           | ddd          | d                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | - |     |   |          |            | 1        |       |             |             |                |
| $ \begin{array}{c} \begin{array}{c} \begin{array}{c} \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \\ \end{array} \end{array} \\ \end{array} \\ \end{array} \\ \begin{array}{c} \\ \\ \\ \\ \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ \end{array} \\ $ | ш<br>н          |            | 00         | 000           | 110          | 06               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |     |   |          |            | <u>.</u> |       |             |             |                |
| $ \begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | ∢               | RL r       | 11         | 001           | 011          | СВ               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | • | ٠ | X   | 0 | х        | Р          | 0        | ٠     | 2           | 8           |                |
| $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ROT             | RL (HL)    | 11         | 010           | 011<br>011   | 10+r<br>CB<br>16 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | * | ٠ | x   | 0 | x        | Р          | 0        | •     | . 4         | 15          |                |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 | RL (IX+d)  | 11         | 011           | 101          | DD               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   | X   | 0 | x        | Р          | 0        | •     | 6           | 23          |                |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1               |            | 11         | 001           | 011          | СВ               | CY < 7 + 0 <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |   |   | -   |   |          |            | -        | -     |             |             |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | dd         | ddd           | ddd          | d                | r,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   |   | -   |   |          |            | -        |       | l           |             |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 | RI (IY+d)  | 11         | 111           | 101          | 16<br>FD         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | • | ÷., |   |          |            |          |       |             | 23          |                |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |            | 11         | 001           | 011          | CB               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   | : ^ |   | <b>^</b> | · ·        |          |       |             | 23          |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | dd         | ddd           | ddd          | d                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |     |   |          |            | -        | -     |             |             |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 | DDC -      | 00         | 010           | 110          | 16               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |     | ļ |          | ļ <u>.</u> |          |       |             |             |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 | KRC P      | 00         | 001           |              | 08+r             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | • | X   | 0 | x        | Р          | 0        | •     | 2           | 8           |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 | RRC (HL)   | 11         | 001           | 011          | СВ               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | * | * | X   | 0 | x        | Р          | 0        | •     | 4           | 15          | i i            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | 00         | 001           | 110          | OE               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | ļ | ļ   | ļ |          |            | ļ        | ļ     |             | ļ           |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | l               | KRC (IX+d) | 11         | 011           | 011          | DU<br>CB         | $ \begin{array}{c} \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | * | • | X   | 0 | X        | Р          | 0        | •     | 6           | 23          |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | dd         | ddd           | ddd          | d                | (nz),(nz),(nx),(nx)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |   |   |     |   |          |            |          |       |             |             | 1              |
| $\begin{array}{c c c c c c c c c c c c c c c c c c c $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |            | 00         | 001           | 110          | OE               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | ļ | ļ   | ļ | ļ        | ļ          | ļ        | į     |             |             | 1              |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 | RRC (IY+d) | 11         | . 111         | 101          | FD               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | * | ٠ | х   | 0 | х        | Р          | 0        | *     | 6           | 23          |                |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | 11<br>dd   | 1001.<br>bbb  | . 011<br>ddd | CB               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 |   |     |   |          |            |          |       |             |             | · ·            |
| $\begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                 |            | 00         | 001           | 110          | OE               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 |   |     |   |          |            |          |       |             |             | 1              |
| $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 | RR r       | 11         | 001           | 011          | СВ               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | • | ٠ | Х   | 0 | x        | р          | 0        | •     | 2           | 8           | 1              |
| $\begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                 |            | 00         | 011           |              | 18+r             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   | ļ | ļ   |   | <u>.</u> |            | Ļ        |       |             |             | 1              |
| RR (IX+d) 11 011 101 DD<br>11 001 011 CB<br>dd ddd ddd d<br>0.011 110 1F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                 | (nL)       | 00         | 001           | 110          | 11               | $\rightarrow$ 7 $\rightarrow$ 0 $\rightarrow$ CY $\rightarrow$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1 | • | X   | 0 | ×        | P          | 0        | •     | 4           | 15          |                |
| 11 001 011 CB<br>dd ddd ddd d<br>00 011 110 1F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1               | RR (IX+d)  | 11         | 011           | 101          | DD               | r,(HL),(IX+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | • | • | x   | 0 | x        | Р          | 0        | •••   | 6           | 23          |                |
| dd ddd dd   d                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                 |            | 11         | 001           | 011          | СВ               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1 |   |     |   |          |            |          |       |             | l           | l              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                 |            | dd<br>00   | ddd<br>011    | 1 ddd<br>110 | d<br>1F          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |   |   |     |   |          |            |          |       |             |             |                |

Note : r means any of the registers A, B, C, D, E, H, L.

## TMPZ84C015A Instruction Set (7/9)

| ITEM/<br>CLASSI      | Assembler  | Object                                               | code                | -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |   |   |   | Fl | ag |     |          |   | No.<br>OF   | No.<br>OF   |                                  |
|----------------------|------------|------------------------------------------------------|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|---|----|----|-----|----------|---|-------------|-------------|----------------------------------|
| -FICA-<br>TION       | mnemonic   | Binary<br>76 543 210                                 | Hex                 | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | s | z |   | н  |    | P/V | N        | с | CY.<br>CLES | STA-<br>TES |                                  |
|                      | RR (IY+d)  | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d       | $\begin{array}{c} \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline \hline$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | • | ٠ | x | 0  | X  | Р   | 0        | * | 6           | 23          |                                  |
|                      | SLA r      | 00 011 110<br>11 001 011<br>00 100 rrr               | 1E<br>CB<br>20+r    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | • | • | x | 0  | x  | Р   | 0        | • | 2           | 8           | r rrr<br>B 000                   |
|                      | SLA (HL)   | 11 001 011                                           | CB                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * | ٠ | Х | 0  | x  | Р   | 0        | ٠ | 4           | 15          | C 001                            |
|                      | SLA (IX+d) | 11 011 101<br>11 001 011<br>dd ddd ddd               | DD<br>CB<br>d       | $\boxed{\begin{array}{c} CY \\ \hline CY \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \hline \\ \\ \hline \\ \\ \hline \\ \\ \hline \\ \hline \\ \hline \\ \\ \hline \\ \hline \\ \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \\ \hline \hline \\ \hline \\ \hline \\ \hline \\ \hline \hline \\ \hline \\ \hline \hline \\ \hline \\ \hline \hline \\ \hline \hline \\ \\$ | * | ٠ | x | 0  | X  | Р   | 0        | * | 6           | 23          | E 011<br>H 100<br>L 101          |
|                      | SLA (IY+d) | 11 111 101<br>11 001 011<br>dd ddd ddd               | FD<br>CB<br>d       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * | * | x | 0  | X  | Р   | 0        | * | 6           | 23          |                                  |
| н<br>н<br>-          | SRA r      | 00 100 110<br>11 001 011                             | 26<br>CB<br>28+c    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * | * | x | 0  | x  | Р   | 0        | • | 2           | 8           |                                  |
| н                    | SRA (HL)   | 11 001 011                                           | CB                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * | * | х | 0  | x  | Р   | 0        | • | 4           | 15          |                                  |
| АТЕ                  | SRA (IX+d) | 11 011 110<br>11 001 011<br>11 001 011<br>dd ddd ddd | DD<br>CB<br>d       | $\begin{array}{c} \hline 7 \rightarrow 0 \end{array} \rightarrow \boxed{CY}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | • | * | x | 0  | x  | р   | 0        | * | 6           | 23          |                                  |
| ROT                  | SRA (IY+d) | 00 101 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 2E<br>FD<br>CB<br>d | r,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | • | * | x | 0  | X  | р   | 0        | * | 6           | 23          |                                  |
|                      | SRL r      | 00 101 110                                           | 2E<br>CB<br>38+c    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | • | • | x | 0  | x  | Р   | 0        | • | 2           | 8           |                                  |
|                      | SRL (HL)   | 11 001 011                                           | CB                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | * | * | х | 0  | x  | Р   | 0        | • | 4           | 15          |                                  |
|                      | SRL (IX+d) | 00 111 110<br>11 011 101<br>11 001 011<br>dd ddd ddd | DD<br>CB<br>d       | $0 \rightarrow 7 \rightarrow 0 \rightarrow CY$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | • | * | x | 0  | x  | Р   | 0        | * | 6           | 23          |                                  |
|                      | SRL (IY+d) | 00 111 110<br>11 111 101<br>11 001 011<br>dd ddd ddd | 3E<br>FD<br>CB<br>d | г,(HL),(IX+d),(IY+d)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | * | * | x | 0  | x  | Р   | 0        | * | 6           | 23          |                                  |
|                      | RLD        | 00 111 110<br>11 101 101<br>01 101 111               | 3E<br>ED<br>6F      | A 7 43 0 7 43 0 (HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | • | * | x | 0  | x  | Р   | 0        | - | 5           | 18          | *1                               |
|                      | RRD        | 11 101 101<br>01 100 111                             | ED<br>67            | A 7 43 0 7 43 0 (HL)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | • | • | x | 0  | x  | Р   | 0        | - | 5           | 18          | *1<br>b   bbb                    |
| TEST                 | BIT b,r    | 11 001 011<br>01 bbb ccc                             | CB<br>40+b x 8+r    | 7+1-                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | x | * | х | 1  | x  | Х   | 0        | - | 2           | 8           | 0 000                            |
| IT SET<br>ESET AND 1 | BIT b,(HL) | 11 001 011<br>01 bbb 110                             | CB<br>46+b×8        | Z+(HL)b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | x | * | x | 1  | x  | x   | 0        | - | 3           | 12          | 2 010<br>3 011<br>4 100<br>5 101 |
| B<br>RF              | L          | L                                                    | l                   | <u> </u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |   | : |   |    |    |     | <u> </u> | : | L           |             | 6 110<br>7 111                   |

Note : \*1 : Rotate digit left and right between the accmulator and location (HL).

The content of the upper half of the accumulator is unaffected.

The notation  $(HL)_b$  indicates bit  $_b$  (0 to 7) within the contents of the HL register pair. The notation  $r_b$  indicates bit  $_b$  (0 to 7) within the r register.

## TMPZ84C015A Instruction Set (8/9)

| ITEM/<br>CLASSI | Assembler                       | Object<br>Binary   | code<br>Hex        | Function                               |                 |              |          | F              | lag  |              |                |                                              | No.<br>OF   | No.<br>OF   |                 |
|-----------------|---------------------------------|--------------------|--------------------|----------------------------------------|-----------------|--------------|----------|----------------|------|--------------|----------------|----------------------------------------------|-------------|-------------|-----------------|
| -FICA-<br>TION  | mnemonic                        | 76 543 210         |                    |                                        | s               | Z            |          | н              |      | P/V          | N              | с                                            | CY-<br>CLES | STA.<br>TES |                 |
|                 | BIT b,(IX+d)                    | 11 011 101         | DD                 |                                        | x               | *            | X        | 1              | х    | Х            | 0              | -                                            | 5           | 20          |                 |
|                 |                                 | 11 001 011         | СВ                 | Z←(IX+d)b                              |                 |              |          |                |      |              |                |                                              |             |             |                 |
|                 |                                 | dd ddd ddd         | d                  |                                        |                 |              |          |                |      |              | 1              |                                              |             |             |                 |
|                 |                                 | 01 bbb 110         | 46+b×8             |                                        |                 |              | ļ        |                |      |              | ļ              |                                              |             |             | 1               |
|                 | BIT b,(IY+d)                    | 11 111 101         | FD                 |                                        | X               | *            | х        | 1              | х    | х            | 0              | -                                            | 5.          | 20          | 1               |
| +               |                                 |                    | CB                 | Z←(IY+d)b                              |                 |              |          |                |      |              | 1              |                                              |             |             |                 |
| s               |                                 |                    | 0                  |                                        |                 |              |          |                |      |              |                |                                              |             |             |                 |
| ⊢               | CET b c                         | 11 001 011         | 40+D X 0           | n. +1                                  | <b> </b>        |              |          |                |      |              | <u>.</u>       |                                              |             |             |                 |
|                 | 321 0,1                         | 11 001 011         | COTPAGE            | 10-1                                   | -               | -            | ^        | -              | ^    | -            | -              | -                                            | 2           | 8           | 8 000           |
|                 | SET 5 (HL)                      | 11 001 011         | CB                 | (HL)++1                                | ·····           | · · · · ·    |          | ·····          | v    |              | <u>.</u>       | · · _ · ·                                    |             | 15          | C 001           |
| Z               | 521 0,(12)                      | 11 bbb 110         | C6+b x 8           | (10) B. 1                              |                 |              | <u> </u> |                | î.   |              |                |                                              | 7           | 10          | D 010           |
| L               | SET b.(IX+d)                    | 11 011 101         | DD                 | (IX+d) <sub>b</sub> ←1                 | - 1             | -            | x        |                | x    | _            |                |                                              | 6           | 23          | E 011           |
| +               |                                 | 11 001 011         | СВ                 | (                                      |                 |              | , î      |                |      |              |                |                                              | Ŭ           | 20          | H 100           |
| ш               |                                 | dd ddd ddd         | d                  |                                        |                 |              |          |                |      |              | 1              |                                              |             |             | L 101           |
| ŝ               | l                               | 11 bbb 110         | C6+b×8             |                                        |                 |              |          |                |      |              | 1              |                                              |             |             | A 111           |
| ά               | SET b,(IY+d)                    | 11 111 101         | FD                 | (IY+d)b←1                              | -               | -            | X        | -              | Х    | -            |                | -                                            | 6           | 23          |                 |
|                 |                                 | 11 001 011         | СВ                 |                                        |                 |              |          |                |      |              |                |                                              |             |             | b bbb           |
| .⊢              |                                 | dd ddd ddd         | d                  |                                        | 1               |              |          |                |      |              |                |                                              |             |             | 0 000           |
| ш<br>(А         |                                 | 11 bbb 110         | C6+b×8             |                                        |                 |              |          |                |      |              |                |                                              |             |             | 1 001           |
| l "             | RES b,r                         | 11 001 011         | СВ                 | r <sub>b</sub> ←0                      | -               | -            | Х        | -              | Х    | -            | -              | -                                            | 2           | 8           | 2 010           |
| ⊢ ⊢             |                                 | 10 bbb rrr         | 80+b×8+r           |                                        | l               |              | [<br>    |                |      |              | <u>.</u>       | <u>.</u>                                     |             |             | 3 011           |
| -               | RES b,(HL)                      | 11 001 011         | СВ                 | (HL) <sub>b</sub> ←0                   | -               | -            | Х        | -              | Х    | -            | -              | -                                            | 4           | 15          | 4 100           |
| ~               |                                 | į                  | ļ                  |                                        |                 | 5 101        |          |                |      |              |                |                                              |             |             |                 |
|                 | RES b,(IX+d)                    | 11 011 101         | DD                 | (IX+d)b←0                              | -               | -            | Х        | -              | Х    | -            | -              | -                                            | 6           | 23          | 6 110           |
|                 |                                 | 11 001 011         | СВ                 |                                        |                 |              |          |                |      |              |                |                                              |             |             | 7 111           |
|                 |                                 | dd ddd ddd         | d                  |                                        |                 |              |          |                |      |              |                |                                              |             |             |                 |
|                 |                                 | 10 bbb 110         | 86+b×8             |                                        | <b> </b>        |              | ļ        |                |      |              | ļ              | <b>.</b>                                     |             |             |                 |
|                 | RES D,(IY+d)                    | 11 111 101         | FD                 | (1Y+d)b←0                              | -               | -            | х        | -              | х    | -            | -              | -                                            | 6           | 23          | 1               |
|                 |                                 |                    | CB                 |                                        |                 |              |          |                |      |              |                | 1                                            |             |             |                 |
|                 |                                 |                    | 0                  | 1                                      |                 |              |          |                |      |              | 1              | 1                                            |             |             |                 |
| <u> </u>        | 10 00                           | 10 000 011         | 80+0×8             | BC6mp                                  |                 |              | -        | <u>}</u>       | -    |              | <u> </u>       | <u> </u>                                     |             | 10          |                 |
| l               |                                 |                    | 0.0                | P C Call                               | -               | -            | ^        | -              | ^    | -            | -              | -                                            | 3           | 10          |                 |
|                 |                                 | mm mmm mmm         | m                  |                                        |                 |              |          |                |      |              |                |                                              |             |             | e represents th |
|                 | JP c.mn                         | 11 ccc 010         | C2+c×8             | PC←mn                                  | ·····           |              | Ŷ        | ÷              | Ŷ    | _            | †              | <u>:</u>                                     | 3           | 10          | extension in th |
|                 |                                 |                    | n                  | (Only when condition is met)           | 1               |              | 1        |                | n i  |              |                |                                              |             | 10          | relative        |
|                 |                                 |                    | m                  |                                        |                 |              |          |                |      |              |                |                                              |             |             | addressing      |
|                 | JR \$+e                         | 00 011 000         | 18                 | PC←\$+e                                | - 1             | -            | X        | -              | х    | _            | <u> </u>       | - 1                                          | 3           | 12          | mode, a = e - 2 |
| ٩               |                                 | aa aaa aaa         | a ·                |                                        |                 |              |          |                |      |              | 1              |                                              |             |             | e is a signed   |
| Σ               | JR C,\$+e                       | 00 111 000         | 38                 | If C=0, continue                       | - 1             | -            | Х        | -              | Х    | -            | -              | - 1                                          | 2           | 7           | two's           |
|                 |                                 | aa aaa aaa         | a                  | lfC≈1,PC←\$+e                          | - 1             | -            | X        | -              | Х    | -            | - 1            | -                                            | 3           | 12          | complement      |
|                 | JR NC,\$+e                      | 00 110 000         | 30                 | If C=0, PC←\$+e                        | <u> </u>        | -            | X        | -              | Х    | -            |                | -                                            | 3           | 12          | number in the   |
|                 |                                 | aa aaa aaa         | а                  | If C=1, continue                       | - 1             | -            | Х        | -              | Х    | -            | -              |                                              | 2           | 7           | range of        |
|                 | JR Z,\$+e                       | 00 101 000         | 28                 | If Z=0, continue                       | l               | -            | X        | -              | X    | -            | <u>.</u> – .   | <u>.                                    </u> | 2           | 7           | – 126≲e ≤ 12    |
|                 |                                 | aa aaa aaa         | a                  | If Z=1, PC←\$+e                        | -               | -            | X        |                | X    | -            | <u>.</u> – .   | -                                            | 3           | 12          | 1               |
| l               | JR NZ,\$+e                      | 00 100 000         | 20                 | If Z=0, PC←\$+e                        | l               |              | Х        |                | Х    |              | <u>i</u> .     |                                              | 3           | . 12        | 1               |
| I               | ļ                               | aa aaa aaa         | a                  | If Z=1, continue                       | . <del></del>   | <del>.</del> | X        |                | Х.,  | <del>-</del> | <del>.</del>   |                                              | 2           | 7           | ł               |
| 1               | DJNZ \$+e                       | 00 010 000         | 10                 | B←B−1, If B=0, continue                | l. <del>.</del> |              | X        | <del>.</del> . | X    | <del>.</del> | <del>.</del> . | <del>.</del>                                 | 2           | . 8         |                 |
|                 |                                 | aa aaa aaa         | a                  | B←B−1, If B<>0, continue               | <u> −</u>       | <del>.</del> | Х.       |                | . X. |              | ļ. <u>-</u> .  | ļ <del>.</del>                               | 3           | 13          | 1               |
| L               | JP (HL)                         | 11 101 001         | E 9                | PC←HL                                  | -               | -            | : X      | -              | : X  | -            | : -            |                                              | 1           | 4           | 1               |
|                 | No                              | Sin the Onice of   |                    |                                        |                 | 1.1          |          |                |      | Latar.       |                |                                              |             | : 00        | c Condition     |
|                 | NOTE: • a=e-2                   | an the Opcode pro  | ovides an effect   | ive address of PC + e as PC is increme | enteo<br>.+     | i by 2       | : pet    | ure t          | neac | artior       | OTE            |                                              | N           | z oc        | 10 Non-Zero     |
|                 | <ul> <li>&gt; indica</li> </ul> | rearing reletence. | lo line location ( | .ounter value of the cutterit segmen   | N               |              |          |                |      |              |                |                                              |             | 71.00       | 111 Zoro        |

• The notation (HL)<sub>b</sub>, (IX + d)<sub>b</sub> indicates bit  $_{\rm b}$  (0 to 7) within the contents of the register pair.

• The notation r<sub>b</sub> indicates bit <sub>b</sub> (0 to 7) withir, the r register.

• a = e-2 in the op-code provides effective address of PC + e as PC is incremented by 2 prior to the addition of e.

C 011 Carry P0 100 Odd Parity PE 101 Even Parity P 110 Sign Positive M 111 Sign Negative

270489

NC 010 No-carry

MPUZ80-614

### TMPZ84C015A Instruction Set (9/9)

| ITEM/<br>CLASSI | Assembler  | Object               | code         | -                                   |              |     |              | F                 | lag  |              |                   |                  | No.<br>Of   | No.<br>Of   |              |     |    |
|-----------------|------------|----------------------|--------------|-------------------------------------|--------------|-----|--------------|-------------------|------|--------------|-------------------|------------------|-------------|-------------|--------------|-----|----|
| -FICA-<br>TION  | mnemonic   | Binary<br>76 543 210 | Hex          | Function                            | s            | z   |              | н                 |      | P/V          | N                 | с                | CY-<br>CLES | STA-<br>TES |              |     |    |
| 4               | JP (IX)    | 11 011 101           | DD           | PC←(IX)                             | -            | -   | x            | -                 | х    | -            | -                 | -                | 2           | 8           |              |     |    |
|                 | JP (IY)    | 11 101 001           | FD           | PC+(IY)                             |              | -   | x            | -                 | х    | -            | -                 | -                | 2           | 8           |              |     |    |
|                 | CALL mn    | 11 001 101           | CD           | (SP-1)+PCH,(SP-2)+PCL               | -            | -   | X            | -                 | x    | -            | -                 | -                | 5           | 17          | j            | kkk |    |
| z               |            | nn nnn nnn           | n            | PC←mn                               |              |     |              |                   |      |              |                   |                  |             |             | 00H          | 000 |    |
| 5               | CALL c,mn  | 11 ccc 100           | C4+cX8       | If condition c is met, same as      |              | -   | x            | -                 | x    | -            | -                 | -                | 5           | 17          | 10H          | 010 |    |
| ш               |            | nn nnn nnn           | n            | CALL mn.                            |              |     | ļ            | ļ                 |      |              | ļ                 | ļ                |             |             | 18H          | 011 |    |
| ۳               | DET        | mm mmm mmm           | m<br>        | If condition c is not met, continue |              |     | Х.           | ļ. <del>.</del> . | Х.   | <del>.</del> | į. <u>-</u> .     | ļ <del>.</del>   | .3          | 10          | 20H          | 100 |    |
| Δ               | REI        | 11 001 001           | L9           | SP+SP+2                             | -            | -   | X            | -                 | x    | -            | -                 | -                | 3           | 10          | 28H<br>30H   | 110 |    |
| z               | RET C      | 11 ccc 000           | C0+c×8       | If condition c is met, same as RET. |              | -   | X            | <u>.</u> –        | x    | -            | <u> </u>          | <u> </u>         | 3           | 11          | 38H          | 111 |    |
|                 |            |                      |              | If condition c is not met, continue | <del>.</del> |     | <u>. x</u> . | ļ. <del>.</del> . | . X. | <u></u>      | ļ. <del>.</del> . | ļ <del>.</del> . | 1           | . 5         |              |     |    |
|                 | REII       |                      | 4D           | routine                             | -            | -   | X            | -                 | X    | -            | -                 | -                | 4           | 14          |              | 000 |    |
| ∢               | RETN       | 11 101 101           | ED           | Return from non-maskable            |              |     | χ            |                   | x    | :            | ÷                 | -                | 4           | 14          | c            | 001 |    |
| U               |            | 01 000 101           | 45           | interrupt Processing routine        |              |     | ļ            | ļ                 |      |              |                   | ļ                |             |             | D            | 010 |    |
|                 | RST j      | 11 kkk 111           | C7+k×8       | (SP-1)←PC <sub>H</sub> ,(SP-2)←PCL  | -            | -   | X            | -                 | x    | -            | -                 | -                | 3           | 11          | E            | 011 |    |
|                 | IN A,(n)   | 11 011 011           | DB           | A+(n)                               | -            | _   | ×            | <u>+</u> _        | x    | <u>-</u>     | <u>-</u>          | <u>-</u>         | 3           | 11          | Ľ            | 101 |    |
| ļ               |            | nn nnn nnn           | n            | n→A0~A7,A→A8~A15                    |              |     | <u>.</u>     | <u>.</u>          |      |              | <u>.</u>          | ļ                |             |             | Α            | 111 |    |
|                 | IN r,(C)   | 11 101 101           | ED           | r←(C) if r=110, only the flags      | •            | *   | Х            | •                 | Х    | P            | 0                 | -                | 3           | 12          |              |     | 1  |
| ⊢ ⊢             | TNT        | 01 rrr 000           | 40+rx8       | will be affected.                   |              | ļ   | ļ            |                   | ļ    | ļ            |                   | ¦                |             |             |              |     |    |
| ⊃               | INI        | 10 100 010           | A2           | (nc)+(c), b+b+1, nc+nc+1            | ^            | тм  |              | : *               |      |              | 1                 |                  | 4           | 16          |              |     |    |
| - L             | INIR       | 11 101 101           | ED           | (HL)+(C),B+B−1,HL+HL+1              | x            | 1   | x            | X                 | x    | x            | 1                 | X                | 5           | 21          | <b>←[</b> B< | >0] |    |
|                 |            | 10 110 010           | B2           | Repeat until B=0                    |              |     | ļ            | į                 |      | ļ            | į                 | į                | . 4         | 16          | ←[B=         | 0]  | *  |
|                 | IND        | 11 101 101           | ED           | (HL)+(C),B+B-1,HL+HL-1              | х            | *м  | X            | X                 | х    | x            | 1                 | X                | 4           | 16          |              |     |    |
|                 | INDR       | 11 101 101           | ED           | (HL)+(C).B+B-1.HL+HL-1              | <br>¥        | 1   | Y            | <br>¥             | Y    | Y Y          | <br>1             | <br>Y            | 5           | 21          | ÷ГВ∢         | 207 |    |
| 4               |            | 10 111 010           | BA           | Repeat until B=0                    | Â            | 1   | Ê            | í.                | î    | , î          | 1                 | 1                | 4           | 16          | +[B=         | 0]  |    |
|                 | OUT (n),A  | 11 010 011           | D3           | (n)←A                               | -            | -   | X            | -                 | х    | -            | - 1               | -                | 3           | 11          |              |     | 1  |
| 5               | 0117 (6) - | nn nnn nnn           | n            | n→A0~A7,A→A8~A15                    |              |     |              | <u>.</u>          |      |              | <u>.</u>          |                  |             |             |              |     | -  |
| ۵.              | 001 (C),r  |                      | LU<br>A1+cY8 | (c)er                               | -            | -   | X            | -                 | X    | -            | -                 | -                | 3           | 12          |              |     |    |
| Z<br>-          | OUTI       | 11 101 101           | ED           |                                     | <br>X        | *м  | x            | x                 | x    | x            | 1                 | x                | 4           |             |              |     |    |
|                 |            | 10 100 011           | A3           |                                     |              |     |              |                   |      |              |                   |                  |             |             |              |     |    |
|                 | OTIR       | 11 101 101           | ED           | (C)+(HL),B+B-1,HL+HL+1              | Х            | 1   | X            | X                 | Х    | X            | 1                 | X                | 5           | 21          | +B[<         | >0] | ١. |
|                 |            | 10 110 011           | B3           | Repeat until B=0                    |              |     |              |                   |      |              |                   |                  | . 4         | 16          | +[8=         | 0]  |    |
|                 | 0010       | 10 101 011           | AB           | (v) (nc), b+b-1, nc+nc=1            | X            | тM  |              | ^                 | ^    | ^            | 1                 | ^                | 4           | 10          |              |     |    |
|                 | OTDR       | 11 101 101           | ED           | (C)←(HL),B←B−1,HL←HL−1              | X            | 1   | x            | Х                 | x    | X            | 1                 | x                | 5           | 21          | +[B<         | >0] |    |
|                 |            | 10 111 010           | BB           | Repeat until B=0                    |              |     |              |                   |      |              |                   |                  | 4           | 16          | +[B=         | 0]  | J  |
|                 |            |                      |              |                                     |              | 1 0 | ·            | 0                 |      |              | 0.00              | · C              | onditi      | 0.0         |              |     |    |

Note : • \*M If the result of B – 1 is zero, the Z flag is set, otherwise it is reset. • A0 through A15 indicate the address bus.

• [ ] indicates the total condition of the number of cycles and states indicated by arrow.



120489

## TMPZ84C015A Instruction Map (1/7)

| L<br>H | 0             | 1             | 2             | 3             | 4              | 5             | 6              | 7             | 8           | 9            | A             | В            | с              | D           | E              | F           |
|--------|---------------|---------------|---------------|---------------|----------------|---------------|----------------|---------------|-------------|--------------|---------------|--------------|----------------|-------------|----------------|-------------|
| 0      | NOP           | LD<br>BC, mn  | LD<br>(BC), A | INC<br>BC     | INC<br>B       | DEC<br>B      | LD<br>B, n     | RLCA          | EX<br>AF,AF | ADD<br>HC,BC | LD<br>A, (BC) | DEC<br>BC    | INC<br>C       | DEC<br>C    | LD<br>C, n     | RRCA        |
| 1      | DJNZ<br>e     | LD<br>DE, mn  | LD<br>(DE), A | INC<br>DE     | INC<br>D       | DEC<br>D      | LD<br>D,N      | RLA           | JE          | ADD<br>HL,DE | LD<br>A, (DE) | DEC<br>DE    | INC<br>E       | DEC<br>E    | LD<br>E, n     | RRA         |
| 2      | JR NZ,<br>e   | LD<br>HL, mn  | LD<br>(mn),HL | INC<br>HL     | INC<br>D       | DEC<br>H      | LD<br>H, n     | DAA           | JR Z<br>e   | ADD<br>HL,HL | LD<br>HL,(mn) | DEC<br>HL    | INC<br>L       | DEC<br>L    | LD<br>L, n     | CPL         |
| 3      | JR NC,<br>e   | LD<br>SP, mn  | LD<br>(mn),A  | INC<br>SP     | INC<br>(HL)    | DEC<br>(HL)   | LD<br>(HL), n  | SCF           | JR C<br>e   | ADD<br>HL,SP | LD<br>A,(mn)  | DEC<br>SP    | INC<br>A       | DEC<br>A    | LD<br>A, n     | CCF         |
| 4      | LD<br>B, B    | LD<br>B, C    | LD<br>B, D    | LD<br>B, E    | LD<br>B, H     | LD<br>B, L    | LD<br>B, (HL)  | LD<br>B, A    | LD<br>C, B  | LD<br>C, C   | LD<br>C, D    | LD<br>C, E   | LD<br>C, H     | LD<br>C, L  | LD<br>C, (HL)  | LD<br>C, A  |
| 5      | LD<br>D, B    | LD<br>D, C    | LD<br>D, D    | LD<br>D, E    | LD<br>D, H     | LD<br>D, L    | LD<br>D, (HL)  | LD<br>D, A    | LD<br>E, B  | LD<br>E, C   | LD<br>E, D    | LD<br>E, E   | LD<br>E, H     | LD<br>E, L  | LD<br>E, (HL)  | LD<br>E, A  |
| 6      | LD<br>H, B    | LD<br>H, C    | LD<br>H, D    | LD<br>H, E    | LD<br>H, H     | LD<br>H, L    | LD<br>H, (HL)  | LD<br>H, A    | LD<br>L, B  | LD<br>L, C   | LD<br>L, D    | LD<br>L, E   | LD<br>L, H     | LD<br>L, L  | LD<br>L, (HL)  | LD<br>L, A  |
| 7      | LD<br>(HL), B | LD<br>(HL), C | LD<br>(HL), D | LD<br>(HL), E | LD<br>(HL), H  | LD<br>(HL), L | HALT           | LD<br>(HL), A | LD<br>A, B  | LD<br>A, C   | LD<br>A, D    | LD<br>A, E   | LD<br>A, H     | LD<br>A, L  | LD<br>A, (HL)  | LD<br>A, A  |
| 8      | ADD<br>A, B   | ADD<br>A, C   | ADD<br>A, D   | ADD<br>A, E   | ADD<br>A, H    | ADD<br>A, L   | ADD<br>A, (HL) | ADD<br>A, A   | ADC<br>A, B | ADC<br>A, C  | ADC<br>A, D   | ADC<br>A, E  | ADC<br>A, H    | ADC<br>A, L | ADC<br>A, (HL) | ADC<br>A, A |
| 9      | SUB<br>B      | SUB<br>C      | SUB<br>D      | SUB<br>E      | SUB<br>H       | SUB<br>L      | SUB<br>(HL)    | SUB<br>A      | SBC<br>A, B | SBC<br>A, C  | SBC<br>A, D   | SBC<br>A, E  | SBC<br>A, H    | SBC<br>A, L | SBC<br>A, (HL) | SBC<br>A, A |
| A      | AND<br>B      | AND<br>C      | AND<br>D      | AND<br>E      | AND<br>H       | AND<br>L      | AND<br>(HL)    | AND<br>A      | XOR<br>B    | XOR<br>C     | XOR<br>D      | XOR<br>E     | XOR<br>H       | XOR<br>L    | XOR<br>(HL)    | XOR<br>A    |
| В      | OR<br>B       | OR<br>C       | OR<br>D       | OR<br>E       | OR<br>H        | OR<br>L       | OR<br>(HL)     | OR<br>A       | CP<br>B     | CP<br>C      | CP<br>D       | CP<br>E      | СР<br>Н        | CP<br>L     | CP<br>(HL)     | XOR<br>A    |
| с      | RET<br>NZ     | POP<br>BC     | JP NZ,<br>mn  | JP<br>mn      | CALL<br>NZ, mn | PUSH<br>BC    | ADD<br>A, n    | RST<br>00H    | RET<br>C    | RET          | JP Z,<br>mn   | 1            | CALL<br>Z, mn  | CALL<br>mn  | ADC<br>A, n    | RST<br>08H  |
| D      | RET<br>NC     | POP<br>DE     | JP NC,<br>mn  | OUT<br>(n), A | CALL<br>NC, mn | PUSH<br>DE    | SUB<br>n       | RST<br>10H    | RET<br>C    | EXX          | JP C,<br>mn   | IN<br>A, (n) | CALL<br>C, mn  | 3           | SBC<br>A, n    | RST<br>18H  |
| E      | RET<br>PO     | POP<br>HL     | JP PO,<br>mn  | EX<br>(SP),HL | CALL<br>PO, mn | PUSH<br>HL    | AND<br>n       | RST<br>20H    | RET<br>PE   | JP<br>(HL)   | JP PE,<br>mn  | EX<br>DE,HL  | CALL<br>Pl, mn | 0           | XOR<br>n       | RST<br>28H  |
| F      | RET<br>P      | POP<br>AF     | JP P,<br>mn   | DI            | CALL<br>P, mn  | PUSH<br>AF    | OR<br>n        | RST<br>30H    | RET<br>M    | LD<br>SP, HL | JP M,<br>mn   | El           | CALL<br>M, mn  | 4           | CP<br>n        | RST<br>38H  |

MPU Instruction Table (I)

Note ①~④: Multi-Opcode Instructions (ref. Table (II )~(VI))

## TMPZ84C015A Instruction Map (2/7)

# ① Byte 1 "CB"

## Instruction Table ( II ) (Byte 2 of 2-byte Opcode)

| L<br>H | 0       | 1       | 2       | 3       | 4       | 5    | 6          | 7       | 8        | 9        | А        | в        | с        | D        | E           | F        |
|--------|---------|---------|---------|---------|---------|------|------------|---------|----------|----------|----------|----------|----------|----------|-------------|----------|
| 0      | RLC     | RLC     | RLC     | RLC     | RLC     | RLC  | RLC        | RLC     | RRC         | RRC      |
|        | B       | C       | D       | E       | H       | L    | (HL)       | A       | B        | C        | D        | E        | H        | L        | (HL)        | A        |
| 1      | RL<br>B | RL<br>C | RL<br>D | RL<br>E | RL<br>H | RL   | RL<br>(HL) | RL<br>A | RR<br>B  | RR<br>C  | RR<br>D  | RR<br>E  | RR<br>H  | RR<br>L  | RR<br>(HL)  | RR<br>A  |
| 2      | SLA     | SLA     | SLA     | SLA     | SLA     | SLA  | SLA        | SLA     | SRA         | SRA      |
|        | B       | C       | D       | E       | H       | L    | (HL)       | A       | B        | C        | D        | E        | H        | L        | (HL)        | A        |
| 3      |         |         |         |         |         |      |            |         | SRL<br>B | SRL<br>C | SRL<br>D | SRL<br>E | SRL<br>H | SRL<br>L | SRL<br>(HL) | SRL<br>A |
| 4      | ВІТ     | ВІТ     | BIT     | ВІТ     | віт     | BIT  | BIT        | BIT     | BIT      | ВІТ      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 0, В    | 0, С    | 0, D    | 0, Е    | 0, н    | O, L | 0,(HL)     | 0, A    | 1, B     | 1, С     | 1, D     | 1, E     | 1, Н     | 1, L     | 1, (HL)     | 1, A     |
| 5      | BIT     | BIT     | BIT     | BIT     | ВІТТ    | BIT  | BIT        | BIT     | BIT      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 2, B    | 2, C    | 2, D    | 2, E    | 2, Н    | 2, L | 2, (HL)    | 2, A    | 3, B     | 3, C     | 3, D     | 3, E     | 3, Н     | 3, L     | 3, (HL)     | 3, A     |
| 6      | BIT     | ВІТ     | BIT     | BIT     | ВІТ     | BIT  | BIT        | BIT     | BIT      | BIT      | BIT      | BIT      | ВІТ      | BIT      | BIT         | BIT      |
|        | 4, B    | 4, С    | 4, D    | 4, E    | 4, Н    | 4, L | 4, (HL)    | 4, A    | 5, B     | 5, C     | 5, D     | 5, E     | 5, Н     | 5, L     | 5, (HL)     | 5, A     |
| 7      | BIT     | BIT     | BIT     | BIT     | ВІТ     | BIT  | BIT        | BIT     | ВІТ      | ВІТ      | BIT      | BIT      | ВІТ      | BIT      | BIT         | ВІТ      |
|        | 6, B    | 6, C    | 6, D    | 6, E    | 6, Н    | 6, L | 6, (HL)    | 6, A    | 7, В     | 7, С     | 7, D     | 7, E     | 7, Н     | 7, L     | 7, (HL)     | 7, А     |
| 8      | RES     | RES     | RES     | RES     | RES     | RES  | RES        | RES     | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 0, B    | 0, C    | 0, D    | 0, E    | 0, H    | 0, L | 0, (HL)    | 0, A    | 1, B     | 1, C     | 1, D     | 1, E     | 1, H     | 1, L     | 1, (HL)     | 1, A     |
| 9      | RES     | RES     | RES     | RES     | RES     | RES  | RE\$       | RES     | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 2, B    | 2, C    | 2, D    | 2, E    | 2, H    | 2, L | 2, (HL)    | 2, A    | 3, B     | 3, C     | 3, D     | 3, E     | 3, H     | 3, L     | 3, (HL)     | 3, A     |
| A      | RES     | RES     | RES     | RES     | RES     | RES  | RES        | RES     | RES      | RES      | RES      | RES      | RES      | RES      | RES         | RES      |
|        | 4, B    | 4, C    | 4, D    | 4, E    | 4, H    | 4, L | 4, (HL)    | 4, A    | 5, B     | 5, C     | 5, D     | 5, E     | 5, H     | 5, L     | 5, (HL)     | 5, A     |
| В      | RES     | RES     | RES     | RES     | RES     | RES  | RES        | RES     | RES      | RES      | RES      | RE\$     | RES      | RES      | RES         | RES      |
|        | 6, B    | 6, C    | 6, D    | 6, E    | 6, H    | 6, L | 6, (HL)    | 6, A    | 7, B     | 7, C     | 7, D     | 7, E     | 7, H     | 7, L     | 7, (HL)     | 7, A     |
| С      | SET     | SET     | SET     | SET     | SET     | SET  | SET        | SET     | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | O, B    | 0, C    | 0, D    | 0, E    | 0, H    | 0, L | 0, (HL)    | 0, A    | 1, B     | 1, C     | 1, D     | 1, E     | 1, Н     | 1, L     | 1, (HL)     | 1, A     |
| D      | SET     | SET     | SET     | SET     | SET     | SET  | SET        | SE⊤     | SET         | SET      |
|        | 2, B    | 2, C    | 2, D    | 2, E    | 2, H    | 2, L | 2, (HL)    | 2, A    | 3, B     | 3, C     | 3, D     | 3, E     | 3, Н     | 3, L     | 3, (HL)     | 3, A     |
| E      | SET     | SET     | SET     | SET     | SET     | SET  | SET        | SET     | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | 4, B    | 4, C    | 4, D    | 4, E    | 4, H    | 4, L | 4, (HL)    | 4, A    | 5, B     | 5, C     | 5, D     | 5, E     | 5, H     | 5, L     | 5, (HL)     | 5, A     |
| F      | SET     | SET     | SET     | SET     | SET     | SET  | SET        | SET     | SET      | SET      | SET      | SET      | SET      | SET      | SET         | SET      |
|        | 6, B    | 6, C    | 6, D    | 6, E    | 6, H    | 6, L | 6, (HL)    | 6, A    | 7, B     | 7, C     | 7, D     | 7, E     | 7, Н     | 7, L     | 7, (HL)     | 7, A     |

# TMPZ84C015A Instruction Map (3/7)

② Byte 1 "ED"

## Instruction Table ( III ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0            | 1             | 2            | 3             | 4   | 5    | 6   | 7          | 8            | 9             | А            | В             | с | D    | E   | F          |
|--------|--------------|---------------|--------------|---------------|-----|------|-----|------------|--------------|---------------|--------------|---------------|---|------|-----|------------|
| 0      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 1      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 2      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 3      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 4      | IN<br>B, (C) | ОUТ<br>(С), В | SBC<br>HL,BC | LD<br>(mn),BC | NEG | RETN | 1M0 | LD<br>I, A | IN<br>C, (C) | OUT<br>(C), C | ADC<br>HL,BC | LD<br>BC,(mn) |   | RETI |     | LD<br>R, A |
| 5      | IN<br>D, (C) | OUT<br>(C), D | SBC<br>HL,DE | LD<br>(mn),DE |     |      | IM1 | LD<br>A, I | IN<br>E, (C) | OUT<br>(C), E | ADC<br>HL,DE | LD<br>DE,(mn) |   |      | IM2 | LD<br>A, R |
| 6      | IN<br>H, (C) | ОUТ<br>(С), Н | SBC<br>HL,HL | LD<br>(mn),HL |     |      |     | RRD        | IN<br>L, (C) | OUT<br>(C), L | ADC<br>HL,HL | LD<br>HL,(mn) |   |      |     | RLD        |
| 7      |              |               | SBC<br>HL,SP | LD<br>(mn),SP |     |      |     |            | IN<br>A, (C) | OUT<br>(C), A | ADC<br>HL,SP | LD<br>SP,(mn) |   |      |     |            |
| 8      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| 9      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| A      | LDI          | СЫ            | INI          | ουτι          |     |      |     |            | LDD          | CPD           | IND          | OUTD          |   |      |     |            |
| В      | LDIR         | CPIR          | INIR         | OTIR          |     |      |     |            | LDDR         | CPDR          | INDR         | OTDR          |   |      |     |            |
| с      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| D      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| E      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |
| F      |              |               |              |               |     |      |     |            |              |               |              |               |   |      |     |            |

## TMPZ84C015A Instruction Map (4/7)

## ③ Byte 1 "DD"

## Instruction Table ( ${ m IV}$ ) (Byte 2 of 2-byte Opcode )

| L<br>H | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | А             | В         | с | D | E                  | F |
|--------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|---------------|-----------|---|---|--------------------|---|
| 0      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,BC  |               |           |   |   |                    |   |
| 1      |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IX,DE  |               |           |   |   |                    |   |
| 2      |                       | LD<br>IX, mn          | LD<br>(mn), IX        | INC<br>IX             |                       |                       |                       |                       |   | ADD<br>IX, IX | LD<br>IX,(mn) | DEC<br>IX |   |   |                    |   |
| 3      |                       |                       |                       |                       | INC<br>(IX + d)       | DEC<br>(IX + d)       | LD<br>(IX + d)<br>, n |                       |   | ADD<br>IX, SP |               |           |   |   |                    |   |
| 4      |                       |                       |                       |                       |                       |                       | LD B,<br>(IX + d)     |                       |   |               |               |           |   |   | LD C,<br>(IX + d)  |   |
| 5      |                       |                       |                       |                       |                       |                       | LD D,<br>(IX + d)     |                       |   |               |               |           |   |   | LD E,<br>(IX + d)  |   |
| 6      |                       |                       |                       |                       |                       |                       | LD H,<br>(IX + d)     |                       |   |               |               |           |   |   | LD L,<br>(IX + d)  |   |
| 7      | LD<br>(IX + d)<br>, B | LD<br>(IX + d)<br>, C | LD<br>(IX + d)<br>, D | LD<br>(IX + d)<br>, E | LD<br>(IX + d)<br>, H | LD<br>(IX + d)<br>, L |                       | LD<br>(IX + d)<br>, A |   |               |               |           |   |   | LD A,<br>(IX + d)  |   |
| 8      |                       |                       |                       |                       |                       |                       | ADD<br>(IX + d)       |                       |   |               |               |           |   |   | ADC 1,<br>(IX + d) |   |
| 9      |                       |                       |                       |                       |                       |                       | SUB<br>(IX + d)       |                       |   |               |               |           |   |   | SBC A,<br>(IX + d) |   |
| 8      |                       |                       |                       |                       |                       |                       | AND<br>(IX + d)       |                       |   |               |               |           |   |   | XOR<br>(IX + d)    |   |
| 9      |                       |                       |                       |                       |                       |                       | OR<br>(IX + d)        |                       |   |               |               |           |   |   | CP<br>(IX + d)     |   |
| С      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               | 5         |   |   |                    |   |
| D      |                       |                       |                       |                       |                       |                       |                       |                       |   |               |               |           |   |   |                    |   |
| E      |                       | POP<br>IX             |                       | EX<br>(SP), IX        |                       | PUSH<br>IX            |                       |                       |   | JP<br>(XI)    |               |           |   |   |                    |   |
| F      |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IX  |               |           |   |   |                    |   |

120489

Note (5): Special 2 byte Opcode Instructions (ref. Table (VI ))

## TMPZ84C015A Instruction Map (5/7)

## ④ Byte 1 "FD"

# Instruction Table (V) (Byte 2 of 2-byte Opcode)

| н   | 0                     | 1                     | 2                     | 3                     | 4                     | 5                     | 6                     | 7                     | 8 | 9             | A              | В         | с | D | E                      | F |
|-----|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|-----------------------|---|---------------|----------------|-----------|---|---|------------------------|---|
| 0   |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,BC  |                |           |   |   |                        |   |
| 1   |                       |                       |                       |                       |                       |                       |                       |                       |   | ADD<br>IY,DE  |                |           |   |   |                        |   |
| 2   |                       | LD<br>IY, nn          | ID<br>(mn), IY        | INC<br>IY             |                       |                       |                       |                       |   | ADD<br>IY, IY | LD<br>IY, (mn) | DEC<br>IY |   |   |                        |   |
| 3   |                       |                       |                       |                       | INC<br>(IY + d)       | DEC<br>(IY + d)       | LD<br>(IY + d)<br>, n |                       |   | ADD<br>IY, SP |                |           |   |   |                        |   |
| 4   |                       |                       |                       |                       |                       |                       | LD B,<br>(IY + d)     |                       |   |               |                |           |   |   | LD C,<br>(IY + d)      |   |
| 5   |                       |                       |                       |                       |                       |                       | LD D,<br>(IY + d)     |                       |   |               |                |           |   |   | LD E,<br>(IY + d)      |   |
| 6   |                       |                       |                       |                       |                       |                       | LD H,<br>(IY + d)     |                       |   |               |                |           |   |   | LD L,<br>(IY + d)      |   |
| 7 ( | LD<br>(IY + d)<br>, B | LD<br>(IY + d)<br>, C | LD<br>(IY + d)<br>, D | LD<br>(IY + d)<br>, E | LD<br>(IY + d)<br>, H | LD<br>(IY + d)<br>, L |                       | LD<br>(IY + d)<br>, A |   |               |                |           |   |   | LD A,<br>(IY + d)      |   |
| 8   |                       |                       |                       |                       |                       |                       | ADD<br>(IY + d)       |                       |   |               |                |           |   |   | ADDC<br>A,<br>(IY + d) |   |
| 9   |                       |                       |                       |                       |                       |                       | SUB<br>(IY + d)       |                       |   |               |                |           |   |   | SUBC<br>A,<br>(IY + d) |   |
| 8   |                       |                       |                       |                       |                       |                       | AND<br>(IY + d)       |                       |   |               |                |           |   |   | XOR<br>(IY + d)        |   |
| 9   |                       |                       |                       |                       |                       |                       | OR<br>(IY + d)        |                       |   |               |                |           |   |   | CP<br>(IY + d)         |   |
| с   |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                | 6         |   |   |                        |   |
| D   |                       |                       |                       |                       |                       |                       |                       |                       |   |               |                |           |   |   |                        |   |
| E   |                       | POP<br>IY             |                       | EX<br>(SP), IY        |                       | PUSH<br>IY            |                       |                       |   | JP<br>(IY)    |                |           |   |   |                        |   |
| F   |                       |                       |                       |                       |                       |                       |                       |                       |   | LD<br>SP, IY  |                |           |   |   |                        |   |

Note ©: Special 2 byte Opcode Instructions (ref. Table (VII))

### TMPZ84C015A Instruction Map (6/7)

## ⑤ Byte 1 "DD"

Byte 2 "CB"

## Instruction Table (VI) (Special case of 2-byte Opcode : Byte 3)

| L<br>H | 0 | 1 | 2 | 3 | 4 | 5 | 6                  | 7 | 8 | 9 | А | в | с | D | E                  | F |
|--------|---|---|---|---|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0      |   |   |   |   |   |   | RLC<br>(IX + d)    |   |   |   |   |   |   |   | RRC<br>(IX + d)    |   |
| 1      |   |   |   |   |   |   | RL<br>(IX + d)     |   |   |   |   |   |   |   | RR<br>(IX + d)     |   |
| 2      |   |   |   |   |   |   | SLA<br>(IX + d)    |   |   |   |   |   |   |   | SRA<br>(IX + d)    |   |
| 3      |   |   |   |   |   |   |                    |   |   |   |   |   |   |   | SRL<br>(IX + d)    |   |
| 4      |   |   |   |   |   |   | BIT 0,<br>(IX + d) |   |   |   |   |   |   |   | BIT 1,<br>(IX + d) |   |
| 5      |   |   |   |   |   |   | BIT 2,<br>(IX + d) |   |   |   |   |   |   |   | BIT 3,<br>(IX + d) |   |
| 6      |   |   |   |   |   |   | BIT 4,<br>(IX + d) |   |   |   |   |   |   |   | BIT 5,<br>(IX + d) |   |
| 7      |   |   |   |   |   |   | BIT 6,<br>(IX + d) |   |   |   |   |   |   |   | BIT 7,<br>(IX + d) |   |
| 8      |   |   |   |   |   |   | RES 0,<br>(IX + d) |   |   |   |   |   |   |   | RES 1,<br>(IX + d) |   |
| 9      |   |   |   |   |   |   | RES 2,<br>(IX + d) |   |   |   |   |   |   |   | RES 3,<br>(IX + d) |   |
| A      |   |   |   |   |   |   | RES 4,<br>(IX + d) |   |   |   |   |   |   |   | RES 5,<br>(IX + d) |   |
| в      |   |   |   |   |   |   | RES 6,<br>(IX + d) |   |   |   |   |   |   |   | RES 7,<br>(IX + d) |   |
| с      |   |   |   |   |   |   | SET 0,<br>(IX + d) |   |   |   |   |   |   |   | SET 1,<br>(IX + d) |   |
| D      |   |   |   |   |   |   | SET 2,<br>(IX + d) |   |   |   |   |   |   |   | SET 3,<br>(IX + d) |   |
| E      |   |   |   |   |   |   | SET 4,<br>(IX + d) |   |   |   |   |   |   |   | SET 5,<br>(IX + d) |   |
| F      |   |   |   |   |   |   | SET 6,<br>(IX + d) |   |   |   |   |   |   |   | SET 7,<br>(IX + d) |   |

# TOSHIBA

## TMPZ84C015A Instruction Map (7/7)

6 Byte 1 "FD"

Byte 2 "CB"

# Instruction Table (VII) (Special case of 2-byte Opcode : Byte 3)

| L<br>H | 0 | 1 | 2 | 3 | 4 | 5 | 6                  | 7 | 8 | 9 | A | В | с | D | E                  | F |
|--------|---|---|---|---|---|---|--------------------|---|---|---|---|---|---|---|--------------------|---|
| 0      |   |   |   |   |   |   | RLC<br>(IY + d)    |   |   |   |   |   |   |   | RRC<br>(IY + d)    |   |
| 1      |   |   |   |   | - |   | RL<br>(IY + d)     |   |   |   |   |   |   |   | RR<br>(IY + d)     |   |
| 2      |   |   |   |   |   |   | SLA<br>(IY + d)    |   |   |   |   |   |   |   | SRA<br>(IY + d)    |   |
| 3      |   |   |   |   |   |   |                    |   |   |   |   |   |   |   | SRL<br>(IY + d)    |   |
| 4      |   |   |   |   |   |   | BIT 0,<br>(IY + d) |   |   |   |   |   |   |   | BIT 1,<br>(IY + d) |   |
| 5      |   |   |   |   |   |   | BIT 2,<br>(IY + d) |   |   |   |   |   |   |   | BIT 3,<br>(IY + d) |   |
| 6      |   |   |   |   |   |   | BIT 4,<br>(IY + d) |   |   |   |   |   |   |   | BIT 5,<br>(IY + d) |   |
| 7      |   |   |   |   |   |   | BIT 6,<br>(IY + d) |   |   |   |   |   |   |   | BIT 7,<br>(IY + d) |   |
| 8      |   |   |   |   |   |   | RES 0,<br>(IY + d) |   |   |   |   |   |   |   | RES 1,<br>(IY + d) |   |
| 9      |   |   |   |   |   |   | RES 2,<br>(IY + d) |   |   |   |   |   |   |   | RES 3,<br>(IY + d) |   |
| A      |   |   |   |   |   |   | RES 4,<br>(IY + d) |   |   |   |   |   |   |   | RES 5,<br>(IY + d) |   |
| В      |   |   |   |   |   |   | RES 6,<br>(IY + d) |   |   | - |   |   |   |   | RES 7,<br>(IY + d) |   |
| с      |   |   |   |   |   |   | SET 0,<br>(IY + d) |   |   |   |   |   |   |   | SET 1,<br>(IY + d) |   |
| D      |   |   |   |   |   |   | SET 2,<br>(IY + d) |   |   |   |   |   |   |   | SET 3,<br>(IY + d) |   |
| E      |   |   |   |   |   |   | SET 4,<br>(IY + d) |   |   |   |   |   |   |   | SET 5,<br>(IY + d) |   |
| F      |   |   |   |   |   |   | SET 6,<br>(IY + d) |   |   |   |   |   |   |   | SET 7,<br>(IY + d) |   |

#### 3.3 CGC OPERATIONS

This subsection describes the system configuration, functions, and basic operations of the clock generator/controller (CGC).

#### 3.3.1 Block Diagram

Figure 3.3.1 shows the block diagram of CGC.



Figure 3.3.1 Block Diagram

#### 3.3.2 CGC System Configuration

The internal configuration of the CGC is shown in Figure 3.3.1. The waveform from the external oscillator oscillated by the internal oscillator and divided by the divider is converted into the square wave for clock. The clock is controlled by the control circuit and the counter to be sent to the outside the CGC. The following describes the CGC's main components and their functions.

- (1) Clock Generation
- (2) Operation Modes

### TOSHIBA

#### [1] Clock Generation

The CGC contains an oscillation circuit. By connecting oscillator to external pins (XTAL1 and XTAL2), the required clock can be generated easily. The CGC provides the clock whose frequency is 1/2 of the oscillation frequency. Figure 3.3.2 shows an example of oscillator connection.





Figure 3.3.2 (a) Example of Crystal Connection

Figure 3.3.2 (b) Oscillator Equivalent Circuit

 For the quartz crystal oscillator, use the MR8000-C20 (oscillation frequency 8 MHz) or MR12000-C20 (oscillation frequency 12 MHz) manufactured by Tokyo Denpa Company Ltd., or the equivalent;

170489

| Product No. | Holder  | Frequency | Cin  | Cout | Quai<br>Para        | rtz Crysta<br>meter (1 | al<br>Typ.)        | Drive Level | Condition<br>Load   |
|-------------|---------|-----------|------|------|---------------------|------------------------|--------------------|-------------|---------------------|
|             | Type    | (IVIHZ)   | (p+) | (pF) | C <sub>1</sub> (pF) | C <sub>0</sub> (pF)    | R <sub>1</sub> (Ω) | (mvv)       | Capacitance<br>(pF) |
| MR8000-C20  |         | 8         | 22   | 33   |                     | 4.00                   | 30.0               |             | _                   |
| MR8000-C14  | HC-49   | 8         | 20   | 20   | 0.0189              | 3.87                   | 6.0                | 0.5         | 12.67               |
| MR12000-C20 | -0      | 12        | 33   | 33   |                     | 4.00                   | 25.0               | _           |                     |
| MR12000-C14 | (TR-49) | 12        | 20   | 20   | 0.0190              | 3.81                   | 6.9                | 0.5         | 12.55               |
| MR16000-C14 |         | 16        | 20   | 20   | 0.0197              | 4.00                   | 5.7                | 0.5         | 12.20               |
|             |         |           |      |      |                     |                        |                    |             | 100590              |

Note: The load capacitance in the condition does not include any stray capacitance.

(2) For the ceramic resonater, use the CSA8.00MT, CST8.00MT (oscillation frequency 8 MHz) or CSA12.00MT, CST12.00MT (osillation frequency 12 MHz) manufactured by Murata MFG Co., Ltd.

| Product No. | Frequency (MHz) | Cin (pF) | Cout (pF) |
|-------------|-----------------|----------|-----------|
| CSA8.00MT   | 8               | 30       | 30        |
| CST8.00MT   | 8               |          |           |
| CSA12.0MT   | 12              | 30       | 30        |
| CST12.0MT   | 12              |          |           |
|             |                 |          | 190589    |

Note: The CST8.00MT and CST12.0MT need no outer capacitance.

#### [2] Operation Modes

The CGC has the capability to control 4 operation modes; Run, Idle 1, Idle 2, and Stop. Any one of them can be selected through the mode setting register (#F0: bit4, bit3: HALTMR). These modes become valid when the MPU executes a HALT instruction. Fetching a HALT instruction, the MPU sets the HALT signal to "0", indicating that it has been put in the halt state. After the execution of the HALT instruction, the CGC performs the operation in the specified mode. Table 3.3.1 shows the operations in each mode.

| Halt mode se<br>(#F0:H/ | Halt mode setting register<br>(#F0:HALTMR) |            | Description                                                                                                                                                                                           |  |  |  |  |  |
|-------------------------|--------------------------------------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| Bit 4                   | Bit 3                                      | Iviode     |                                                                                                                                                                                                       |  |  |  |  |  |
| 0                       | 0                                          | IDLE1 Mode | Only the internal oscillator operates, stopping the supply of clock outside. The clock output (CLKOUT) is held at "0".                                                                                |  |  |  |  |  |
| 0                       | 1                                          | IDLE2 Mode | The internal oscillator continues operating with the supply of clock outside (CLKOUT) continued. When pins CLKOUT and CLKIN are connected, only the supply of clock (CLKOUT) to the CTC is continued. |  |  |  |  |  |
| 1                       | 0                                          | STOP Mode  | All internal operations are stopped. The clock output (CLK) is held at "0".                                                                                                                           |  |  |  |  |  |
| 1                       | 1                                          | RUN Mode   | The supply of clock outside is continued.                                                                                                                                                             |  |  |  |  |  |

| rable 3.3.1 CGC Operation Modes | Table 3.3.1 | CGC C | peration | Modes |
|---------------------------------|-------------|-------|----------|-------|
|---------------------------------|-------------|-------|----------|-------|

170489

The restart from the clock stop state in Idle 1, Idle 2 (these two modes are referred to as Idle mode hereafter), or Stop mode is performed by reset ( $\overline{\text{RESET}}$  signal) or acknowledge of maskable interrupt ( $\overline{\text{INT}}$  signal) or non-maskable interrupt ( $\overline{\text{NMI}}$  signal).
### TMPZ84C015A

# TOSHIBA

### [3] Warm-up Time for Restart (from Stop mode)

Releasing the halt state by interrupt acknowledge, the MPU begins executing interrupt processing. Therefore, when restarting the clock by the  $\overline{\rm NMI}$  or  $\overline{\rm INT}$  restart signal in the Stop mode, the oscillation must be fully stabilized before supplied outside. The CGC provides, by means of the internal counter, the warm-up time enough for the clock to stabilize frequency. The warm-up ends on the rising edge of the internal counter output dividing the oscillation frequency to start clock output. The warm-up time is equal to the time derived by dividing the frequency of the externally attached oscillator by  $2^{14}$ .

Figure 3.3.3 shows the block diagram of the internal counter. Table 3.3.2 shows the relationship between the oscillation frequency and the warm-up time.

In the restart by the  $\overline{\text{RESET}}$  signal, no warm-up is performed for the quick operation at power-on. Therefore, expand the width of the  $\overline{\text{RESET}}$  signal adequately to provide the warm-up time.



Figure 3.3.3 Block Diagram of Internal Counter

| Table 3.3.2 | Warm-up | Time |
|-------------|---------|------|
|-------------|---------|------|

| Counter output | Warm-up Time |               |              |  |
|----------------|--------------|---------------|--------------|--|
| 215            | 214.45-      | fXTAL = 12MHz | fXTAL = 8MHz |  |
| 215 214/tc     |              | 2.7 ms        | 4 ms         |  |

170489

\*  $fc = f_{XTAL} / 2$ 

# 3.3.3 CGC Status Transition Diagram and Basic Timing

The following describes the status transition and basic timing to be provided when the CGC operates.

# [1] Status Transition Diagram





### [2] Basic Timing

The following describes the CGC basic timing when the CGC clock output pin (CLKOUT) and clock input pin (CLKIN) are connected.

(1) Operation at execution of HALT instruction

The following describes the basic timing in each mode to be provided when the MPU executes a HALT instruction. The MPU sets the HALT signal to "0" synchronized with the falling edge of clock state T4 of the HALT Instruction Opcode fetch cycle (M1). This signal indicates to the CGC that the MPU is going to enter into the halt state.

## (a) Run mode (#F0: bit 4 = 1, bit 3 = 1: HALTMR)

Figure 3.3.5 shows the basic timing in the Run mode. In the Run mode, the CGC continues supplying the clock to the outside even when the MPU is in the halt state. Therefore, the MPU continues executing NOPs during the halt state. The systems which need memory address refresh use this mode.



Figure 3.3.5 Basic Timing in Run Mode

(b) Idle 1 mode (#F0: bit 4 = 0, bit 3 = 0: HALTMR), idle 2 mode (#F0: bit 4 = 0, bit 3 = 1: HALTMR), and Stop mode (#F0: bit 4 = 1, bit 3 = 0)

Figure 3.3.6 shows the basic timing in the Idle modes and Stop mode. In these modes, the clock output is stopped with clock state T4 being "0" by the  $\overline{\text{HALT}}$  signal and the  $\overline{\text{M1}}$  signal which follows the HALT instruction.

However, in the Stop mode, the CGC's internal oscillator also stops.



Figure 3.3.6 Basic Timing in Idle and Stop Modes

(2) Clock output restart from each mode

The clock stopped state in the Idle or Stop mode is cleared by setting any of the following signals to "0" (for the system restart operation, see Subsection 3.3.4):

- **INT** (level trigger input)
- <u>NMI</u> (edge trigger input)
- RESET (level trigger input)
- (a) Clock output restart from Idle mode

Figure 3.3.7 (a) shows the basic timing for the sequence of the output restart from the clock stopped state in the Idle 1 mode. In the restart in the Idle 1 mode, the clock output is restarted in a relatively short delay time because the internal oscillator operates even in the clock stopped state.



### (b) Clock output restart from Stop mode

Figure 3.3.8 shows the basic timing for the sequence of the restart from the clock stopped state in the Stop mode. When restarting by setting the INT or NMI signal to "0", the warm-up time is automatically created by the internal counter. In the restart by the **RESET** signal, oscillation restarts without warm-up.





# 3.3.4 Relationship with MPU

The following describes the relationship between the CGC and the MPU mainly in terms of the halt clear operation.

[1] RESET Signal

Figure 3.3.9 shows an example of the timing for the restart from the Stop mode on the TMPZ84C015A using  $\overrightarrow{\text{RESET}}$  signal for both the MPU and CGC. To reset the MPU, the  $\overrightarrow{\text{RESET}}$  signal must be set to "0" for at least 3 stable clocks. When the  $\overrightarrow{\text{RESET}}$  signal goes "1", the MPU releases the halt state after a dummy cycle of 2T clock states to start executing instructions from address 0000H.

To restart the clock output by the  $\overline{\text{RESET}}$  signal in the Stop mode, the internal counter to determine the warm-up time does not operate.

Therefore, if the MPU does not restart correctly due to the unstable clock output immediately after the restart of the internal oscillator, or the unstability of the crystal at power-on, the  $\overline{\text{RESET}}$  signal must be held at "0" for a time long enough for the MPU to be reset securely.



Figure 3.3.9 Example of clock Restart Timing by RESET Signal

# [2] Releasing Halt State by Interrupt Signal

The CGC restarts the clock output from the Idle or Stop mode by the input of  $\overline{\text{INT}}$  or  $\overline{\text{NMI}}$  signal. By this clock, the MPU starts operating. However, when the CGC restarts the clock output, the MPU is still in the halt state executing NOPs. To clear the halt state, the interrupt signal must be entered into the MPU (in the case of the  $\overline{\text{INT}}$  signal) for at least one instruction. The MPU interrupt is detected on the rising edge of the last clock of each instruction (NOP for the halt state).

(1) When using non-maskable interrupt (NMI)

MPU's non-maskable interrupt is edge trigger input. The MPU contains the flip-flop to detect an interrupt. The state of this internal NMI flip-flop is sampled on the rising edge of the last clock of each instruction. Therefore, when a short active low ("0") pulse has been inserted before the interrupt detection timing, the interrupt is acknowledged. The  $\overline{\rm NMI}$  input of the TMPZ84C015A is connected to the  $\overline{\rm NMI}$  input of the MPU via the CGC, performing the same operations as above. (See Figure 3.3.11)

(2) When using maskable interrupt (INT)

With a maskable interrupt, the maskable interrupt enable flip-flop (IFF) must be set to "1" by program before the  $\overline{\text{INT}}$  input signal is detected "0". Even if the CGC accepts the  $\overline{\text{INT}}$  signal to restart supply of the clock, no interrupt is acknowledged unless the  $\overline{\text{INT}}$  signal is kept inserted until one instruction (NOP) has been executed. Figure 3.3.10 shows the timing for clearing the halt state by the interrupt signal.



Figure 3.3.10 Timing for Clearing Halt State by Interrupt Signal

# [3] Connecting CGC to MPU on TMPZ84C015A

Figure 3.3.11 shows the connection between the CGC and the MPU on the  $\mathrm{TMPZ84C015A}$ 



Figure 3.3.11 Connection Between CGC and MPU

# 3.4 CTC OPERATIONAL DESCRIPTION

The CTC has 4 independent channels. To these channels, addresses are allocated on the TMPZ84C015A's I/O map, permitting the read/write of the channels in the MPU's I/O cycle. (See Figure 3.4.1) This subsection mainly describes the CTC operation to be performed after accessed.

# 3.4.1 CTC Block Diagram

Figure 3.4.1 shows the block diagram of the CTC.



Figure 3.4.1 Block Diagram of CTC

3.4.2 CTC System Configuration

The CTC system consists of the following 4 logic circuits:

- (1) MPU bus I/O logic circuit
- (2) Internal control logic circuit
- (3) Interrupt control logic circuit
- (4) Four independent counter/timer channel logic circuits
- [1] MPU Bus I/O Logic Circuit

This circuit transfers data between the MPU and the CTC.

[2] Internal Control Logic Circuit

This circuit controls the CTC operational functions such as the CTC selecting chip enable, reset, and read/write circuits.

[3] Interrupt Control Logic Circuit

This circuit performs the MPU interrupt related processing such as priority determination. The order of priority with other LSIs is determined according to the physical location in daisy chain connection.

[4] Counter/Timer Channel Logic Circuit

This circuit consists of the following 2 registers and 2 counters. Figure 3.4.2 shows the configuration of this circuit.

- Time-constant register (8 bits)
- Channel control register (8 bits)
- Down-counter (8 bits)
- Prescaler (8 bits)



Figure 3.4.2 Configuration of Counter/Timer Channel Logic Circuit

(1) Time-constant register

This register holds the time constant to be written in the down counter. When the CTC is initialized or the down-counter has reached zero, the time constant is loaded into down-counter. The time constant is set immediately after the MPU has written the channel control word in the channel control register. For a time constant, an integer from 1 to 256 can be used.

(2) Channel control register

This register is used to choose the channel mode or condition according to the channel control word sent from the MPU.

### (3) Down-counter

The contents of the time-constant register are loaded into the down counter. In the counter mode, these contents are decremented for each edge of the external clock; in the timer mode, they are decremented for each prescaler clock output. The contents of the time-constant register are loaded at initialization or when the down-counter has reached zero.

The contents of the down-counter can be read any time. Also, the system can be programmed so that an interrupt request is generated each time the down-counter has reached zero.

## (4) Prescaler

The prescaler, used only in the timer mode, divides the system clock by 16 or 256. The dividing number is programmed by channel control word. The output of the prescaler becomes the clock input to the down-counter.

# 3.4.3 CTC Basic Operations

[1] Reset

The state of the CTC is unstable after it is powered on. To initialize the CTC, the low level signal needs to be applied to the  $\overline{\text{RESET}}$  pin. On any channel, the channel control word and time-constant data must be written to be started before it is started in the counter or timer mode. To program the system to enable interrupts, the interrupt vector word must be written in the interrupt controller. When these data have been written in the CTC, it is ready to start.

### [2] Interrupt

The CTC can cause an interrupt when the MPU is operating in the mode 2. The CTC interrupt can be programmed for each channel. Each time the channel's down-counter has reached zero, the CTC outputs the interrupt request signal ( $\overline{INT}$ ). When the MPU accepts the CTC's interrupt request, the CTC outputs the interrupt vector. Based on this interrupt vector, the MPU specifies the start address of the interrupt processing routine and calls it to start interrupt processing.

The MPU specifies the start address of the interrupt processing routine by the interrupt vector output from the CTC, so that the user can change the vector value to call any desired address.

The interrupt processing is terminated when the MPU executes an RETI instruction. The CTC has the circuit which decodes the RETI instruction. By constantly monitoring the data bus the CTC can detect the termination of the interrupt processing. The order of interrupt priority with the Z80 peripheral LSIs is determined by the daisy chain connection. That is, the peripheral LSIs are connected one after another and the one physically near the MPU is given a higher priority. The priority of the Z80 peripheral LSIs (CTC, PIO, and SIO) contained in the TMPZ84C015A is determined by the contents of the interrupt priority register (#F4: bits 2 through 0). Inside the CTC, channel 0 is given the highest priority, followed by channels 1, 2 and 3 in this order.

The CTC and other peripheral LSIs on the TMPZ84C015A have the signal lines IEO and IEI. Connect the IEO of a higher peripheral LSI to the IEI of a lower perpheral LSI. Connect the IEI of the highest peripheral LSI to VCC. Leave the IEO of the peripheral LSI unused. In this connection, the CTC interrupt is caused under the following conditions:

- When both IEI and IEO are high, no interrupt is caused. At this time, the INT signal is high. An interrupt can be requested in this state.
- When the CTC outputs the interrupt request signal (INT), the IEO of the CTC becomes low. When the MPU accepts the interrupt, the INT goes high again.
- When the IEI goes low, the IEO also goes low.
- While the IEI is low, no interrupt can be requested.
- When the IEI goes low while an interrupt is being serviced, the interrupt processing is aborted.
- [3] Operation Modes

The CTC operates in either the counter mode or the timer mode. Mode is selected by writing the channel control word.

(1) Counter mode

In the counter mode, the number of edge of the pulses applied to the channel's CLK/TRG pin is counted. When pulses have been input, the contents of the down-counter are decremented synchronizing with the rising edge of the next system clock. The pulse's rising edge or falling edge to be counted can be specified by the channel control word.

When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin. When the interrupt is enabled by the channel control word, the INT pin goes low and an interrupt is requested. When the contents of the down-counter has reached zero, the time constant data written in the time constant register is automatically loaded into the down-counter. To load a new time constant value into the down-counter, write the data to the time constant register, and it is loaded into the down-counter after the current count operation is terminated.

### (2) Timer mode

In the timer mode, the time intervals which are integral multiples of the system clock period. A timer interval is measured according to the system clock. The system clock is supplied to the prescaler which divides it by a factor of 16 or 256. The output of the prescaler provides the clock to decrement the down-counter by 1. The time constant data is automatically loaded into the down-counter each time it has reached zero as in the counter mode. When the contents of the down-counter has reached zero, the high level pulse is output from the ZC/TO pin.

This pulse period is given by the following expression:

tc\*P\*TC

| Where, | tc | <ul> <li>System clock period</li> </ul>              |  |  |
|--------|----|------------------------------------------------------|--|--|
|        | Р  | = Prescaler value (16 or 256)                        |  |  |
|        | TC | = Time constant data $(256 \text{ for } 00\text{H})$ |  |  |

The user can select, by means of the channel control word, to start the timer automatically or to start the timer on the edge of the pulse at CLK/TRG pin. In case the user select the CLK/TRG pin, the user can also select the rising edge or falling edge of the pulse.

# 3.4.4 CTC Status Transition Diagram and Basic Timing

## [1] Transition Diagram

Figure 3.4.3 shows the CTC status transition diagram.





170489



Figure 3.4.3 (b) CTC Transition Diagram (b)

## [2] Basic Timing

(1) Write cycle

The write cycle is used to write a channel control word, an interrupt vector, or a time constant. The C MPU drives the  $\overline{IORQ}$  pin of the CTC low in the subsequent system clock cycle T2 to start the write cycle.

It is required to make the  $\overline{\rm M1}$  pin of the CTC high to indicate that the write cycle is on.

At the start of the cycle, the channel is specified by CS1 (A1) or CS0 (A0) of the CTC. Thus, the CTC's internal registers are ready to accept data in system clock T3. Tw is the state to be automatically inserted by the MPU.



# (2) Read cycle

The read cycle is used to read the contents of the down-counter. During clock cycle T2, the MPU initiates a read cycle by driving the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins low. It is required to make the  $\overline{\text{M1}}$  pin high to indicate that the read cycle is on. At the start of the read cycle, the channel is specified by CS<sub>1</sub> (A<sub>1</sub>) or CS<sub>0</sub> (A<sub>0</sub>) of the CTC. At the rising edge of system clock TW, the contents of the down-counter at the time

At the rising edge of system clock TW, the contents of the down-counter at the time of the rising edge of T2 are put on the data bus. TW is the wait state to be automatically inserted by the MPU.





### [3] Counter mode

In the counter mode, the down-counter is decremented synchronizing with the system clock, at the edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the down-counter is decremented one system clock later. When the down-counter has reached zero, a high level pulse is output from the ZC/TO pin.



### [4] Timer mode

The timer starts operating at the second rising edge of the system clock from the rising edge of the pulse applied from the external circuit connected to the CLK/TRG pin. The period of the pulse to be applied to the CLK/TRG pin must be greater than 2 times the system clock period. Also, it is required to insert the setup time between the active edge of the CLK/TRG pin signal and the rising edge of the succeeding system clock. When the interval between these pulses is short, the timer starts one system clock cycle later.



Figure 3.4.7 Timer Mode Timing

#### [5] Interrupt acknowledge cycle

Having received the interrupt request signal (INT) from the CTC, the MPU drives the CTC's  $\overline{\text{M1}}$  pin and  $\overline{\text{IORQ}}$  pin low to provide the acknowledge signal. The  $\overline{\text{IORQ}}$  pin goes low 2.5 system clocks later than the  $\overline{\text{M1}}$  pin. To stabilize the signal lines (IEI and IEO) in daisy chain connection, the interrupt request cannot be changed on each channel while the  $\overline{M1}$  pin is low. The  $\overline{RD}$  pin is held high to make distinction between the instruction fetch cycle and the interrupt acknowledge cycle. While the  $\overline{\text{RD}}$  pin is high, the CTC's interrupt control circuit determines the interrupt-requesting channel of highest priority. When the CTC's IEI is high and the  $\overline{M1}$  pin and  $\overline{IORQ}$  pin go low, the interrupt vector is output from the interrupt requesting channel of highest priority. At this time, 2 system clock cycles are automatically inserted by the MPU as a wait state to maintain the stabilization of the daisy chain connection.



Figure 3.4.8 Interrupt Acknowledge Timing

170489

# [6] Return from interrupt processing

Return from the interrupt processing is performed when the MPU executes the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When this instruction is executed by the MPU, the CTC's IEI and IEO return to the state active before the interrupt has been serviced.

The RETI instruction is a 2-byte instruction. Its code is EDH 4DH. The CTC decodes this instruction to check if there is the next interrupt request channel.

In the daisy chain structure, the interrupting LSI's IEI and IEO are held high and low respectively at the time the instruction code EDH has been decoded.

The code following EDH is 4DH, only the peripheral LSI which has sent the last interrupt vector (that is, the LSI whose IEI is high and IEO is low) returns from the interrupt processing. This restarts the processing of the suspended interrupt of the peripheral LSI of the next higher priority.



Figure 3.4.9 Interrupt Return Timing

# 3.4.5 CTC Operational Procedure

To operate the CTC in the counter mode or the timer mode, the channel control word and time-constant data must be written in the CTC. To enable interrupts by the channel control word, the interrupt vector must be written in the CTC.

## [1] I/O Address and Channel Control Word

To write the channel control word in the CTC, the channel must be specified by the corresponding channel I/O address.

| Channel | I/O address |  |  |
|---------|-------------|--|--|
| 0       | #10         |  |  |
| 1       | #11         |  |  |
| 2       | #12         |  |  |
| 3       | #13         |  |  |
|         | 170489      |  |  |

Table 3.4.1 Channel I/O Addresses

The channel control word to be written in the CTC consists of 8 bits. The system data bus D0 through D7 correspond to bit 0 through 7 respectively. Figure 3.4.10 shows the meaning of each bit. Table 3.4.2 shows the function of each bit.

| D7        | D6                | D5        | D4   | D3      | D2               | D1    | D0     |
|-----------|-------------------|-----------|------|---------|------------------|-------|--------|
| interrupt | Counter/<br>timer | Prescaler | Edge | Trigger | Time<br>constant | Reset | 1      |
|           |                   | -         |      |         |                  |       | 170489 |

Figure 3.4.10 Channel Control Word

For the channel control word, D0 must always be 1.

Table 3.4.2 Meanings and Function of Channel Control Words (1/3)

| Di+           | Meaning and function       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |  |  |
|---------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| ы             | 0                          | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| Bit 7<br>(D7) | Disables channel interrupt | Enables channel interrupt. In either<br>counter or timer mode, the interrupt is<br>requested every time the down-counter<br>has reached zero. When this bit is set to<br>"1", the interrupt vector must be written<br>in the CTC before the down-counter<br>starts. When the channel control word<br>whose D7 bit is "1" is written in an already<br>operating channel, the interrupt occurs<br>only when the down-counter has reached<br>zero for the first time after the writing of<br>the new channel control word. |  |  |

170489

|               |                                                                                                                                                                                                                                                                                                                                                                                                       | (2/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Ri+           | Neaning and function                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|               | 0                                                                                                                                                                                                                                                                                                                                                                                                     | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| Bit 6<br>(D6) | Puts the channel in the timer mode. Puts<br>the system clock into the prescaler and<br>outputs the divided signal to the down-<br>counter.                                                                                                                                                                                                                                                            | Puts the channel in the counter mode.<br>The down-counter is decremented for<br>each edge trigger applied to the CLK/TRG<br>pin. In the counter mode, the prescaler is<br>not used.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
| Bit 5<br>(D5) | Used only in the timer mode. The prescaler is set to divide the system clock by 16.                                                                                                                                                                                                                                                                                                                   | Used only in the timer mode. The prescaler is set to divide the system clock by 256.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| Bit 4<br>(D4) | In the timer mode, the timer operation<br>starts on the falling edge of the trigger<br>PULSE (CLK/TRG). In the counter mode,<br>the down-counter is decremented at the<br>falling edge of the external clock pulse<br>(CLK/TRG)                                                                                                                                                                       | In the timer mode, the timer operation<br>starts on the rising edge of the trigger<br>pulse (CLK/TRG). In the counter mode, the<br>down-counter is decremented at the<br>rising edge of the trigger pulse (CLK<br>/TRG).                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
| Bit 3<br>(D3) | Used only in the timer mode.<br>The timer oparation starts on the rising<br>edge of the trigger pulse clocks after a<br>time constant is loaded onto the down-<br>counter.                                                                                                                                                                                                                            | Used only in the timer mode. The timer operation is started at the leading edge of the external trigger pulse that inputs 2 system clocks after a time constant is loaded onto the down counter. when a time lag between the system clock and trigger pulse satisfies a setup time, the prescaler starts to operate from the second leading edge of the trigger pulse. If a time lag between the system clock and trigger pulse dose not satisfy the setup time, the prescaler starts to operate at the leading edge of the trigger pulse after 3 system clocks. If the trigger pulse is input before loading of a time constant, the operation is the same as that when Bit $3=0$ . |  |  |
| Bit 2<br>(D2) | This bit (0) indicates that there is no time<br>constant written after channel control<br>word. However, when the channel is in<br>the reset state and this bit cannot be<br>changed to "0" in the channel control<br>word which is given first after the channel<br>reset. To change other state without<br>changing a time constant, input a<br>channel control word with this bit<br>changed to 0. | This bit (1) indicates that there is a time<br>constant written immediately after a<br>channel control word. If a time constant is<br>written while the downcounter is<br>operating, a new time constant is set in<br>the time constant register. The counting<br>which is in progress is carried out<br>continuously when the downcounter<br>becomes zero, and a new time constant is<br>loaded onto the downcounter.                                                                                                                                                                                                                                                               |  |  |

170489

12/21

|               |                                         | . (3/3)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |
|---------------|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Bit           | Meaning and function                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|               | 0                                       | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
| Bit 1<br>(D1) | Continues the current channel operation | Stops the down-counter operation.<br>When this bit is set to "1", the channel<br>operation stops but all the channel<br>control register bits remain unchanged.<br>When bit $2 =$ "1" and bit $1 =$ "1", the<br>channel operation remains stopped until<br>a new time constant is written. Channel<br>restart is set up after the new time<br>constant is programmed. The channel is<br>restarted according to the state of bit 3.<br>When bit $2 =$ "0" and bit $1 =$ "1", the<br>channel operation does not start until a<br>new channel control word is written. |  |  |

170489

### [2] Time-Constant Data

In either the time mode or the counter mode, the time-constant data must be loaded into the time constant register. When bit 2 (D2) of the channel control word is "1", the time constant is loaded into the time constant register immediately after the channel control word is written. A time-constant value must be an integer in a range of 1 to 256. When the 8 bits of a time constant are all "0"s, such a time constant is assumed to be 256. Figure 3.4.11 shows the bit configuration of time-constant data.



Figure 3.4.11 Time-Constant Data

### [3] Interrupt Vector

In interrupt in the MPU mode-2, the interrupting channel must give an interrupt vector to the MPU. An interrupt vector is written in the channel-0 interrupt vector register with bit 0 (D0) = "0". The vector is written in the same way as the channel control word is written on channel 0. However, bit 0 (D0) of the vector should always be "0". Bit 7 (D7) through bit 3 (D3) are user-defined values. Bit 2 (D2) and bit 1 (D1) are automatically given and contain the code of the interrupt-requesting channel having the highest priority. Table 3.4.3 shows the channel codes. Figure 3.4.12 shows the interrupt vector bit configuration.

| Bit 2 (D2) | Bit 1 (D1) | Channel number | Interrupt priority |
|------------|------------|----------------|--------------------|
| 0          | 0          | 0              | (High)             |
| 0          | 1          | 1              | 1                  |
| 1          | 0          | 2              | ↓                  |
| 1          | 1          | 3              | (Low)              |

Table 3.4.3 Channel Codes

170489



Figure 3.4.12 Interrupt Vector

# 3.4.6 Using CTC

# [1] Counter Mode

The following describes how to use the CTC by referring to a program using channel 0 with interrupt disabled.

(a) The counter programming procedure is shown in Figure 3.4.13





(b) The block diagram for converting the 100 kHz system clock into the 10 kHz equivalent is shown in Figure 3.4.14.





(c) The channel control word configuration is shown in Figure 3.4.15





- [2] Timer Mode
  - (a) The timer programming procedure without using interrupt is shown in Figure 3.4.16.



170489

Figure 3.4.16 Timer Programming Procedure

(b) The block diagram for converting the 4 MHz system clock into the 1 kHz equivalent is shown in Figure 3.4.17.





(c) The channel control word is shown in Figure 3.4.18.





### 3.5 PIO OPERATIONAL DESCRIPTION

The PIO has two independent, programmable 8-bit ports. These ports are assigned addresses on the TMPZ84C015A's I/O map and therefore can be read/written in the MPU's I/O cycle. This subsection mainly describes the operations that take place after accessing the PIO.

### 3.5.1 PIO Block Diagram

Figure 3.5.1 shows the PIO block diagram



Figure 3.5.1 PIO Block Diagaram

### 3.5.2 PIO System Configuration

The PIO system consists of the four logic circuits:

- (1) MPU bus I/O logic circuit
- (2) Internal control logic circuit
- (3) Interrupt control logic circuit
- (4) Port I/O logic circuit
- [1] MPU Bus I/O Logic circuit

The MPU bus I/O logic circuit transfers data between the MPU and the PIO.

[2] Internal Control Logic circuit

The internal control logic circuit controls the PIO operating functions like the PIO selecting chip enable and the read/write circuits.

# [3] Interrupt Control Logic circuit

The interrupt control logic circuit performs the MPU interrupt-associated processing such as determining interrupt priorities. The priorities with other LSI peripherals are determined by the physical location in daisy chain connection.

[4] Port I/O Logic Circuit

The port I/O logic circuits are used to directly connect to peripheral devices. Each consists of the following 7 registers and 1 flip-flop. Data are written in the registers by the MPU as specified in the program. Figure 3.5.2 shows the internal configuration of the ports

- Data output register (8 bits)
- Data input register (8 bits)
- Mode control register (2 bits)
- Interrupt vector register (8 bits)
- Interrupt control register (2 bits)
- Mask control register (8 bits)
- Data I/O control register (8 bits)
- Handshake control logic circuit



Figure 3.5.2 Port Internal Configuration

(1) Data Output register

This register holds the data to be transferred from the MPU to peripheral devices.

(2) Data input register

This register latches the data to be transferred from peripheral devices to the MPU.

The input data to the MPU is read through this register

(3) Mode control register

This register specifies the operation mode. The operation mode is set by MPU control.

(4) Interrupt vector register

This register holds the vector which makes up the address of the table storing the start address of the interrupt processing routine.

This register is used only for interrupt processing.

(5) Interrupt control register

This register specifies how the I/O ports are to be monitored. This register is used only in the PIO mode 3.

(6) Mask control register

This register specifies which I/O port pin is to be monitored. This register is used only in the PIO mode 3.

(7) Data I/O control register

This register specifies whether each port pin is to be used as output or input. This register is used only in PIO mode 3.

(8) Handshake control logic

This circuit controls the data transfer to the peripheral devices connected to the 8-bit I/O ports.

### 3.5.3 PIO Basic Operations

[1] Reset

The PIO provides the following two reset capabilities:

(1) Power-on reset

The PIO contains the circuit which automatically resets the PIO at the time of power-on.

(2) Hardware reset

Making the  $\overline{\text{RESET}}$  pin low for 2 system clock periods with the  $\overline{\text{RD}}$  and  $\overline{\text{IORQ}}$  pins being high resets the PIO on the rising edge of the  $\overline{\text{RESET}}$  pin. This hardware reset inside the TMPZ84C015A by external pin is possible because the output of the AND circuit between the  $\overline{\text{RESET}}$  and  $\overline{\text{M1}}$  pins is put on the  $\overline{\text{M1}}$  signal of the PIO.

### Reset state

- (a) The operation mode is set to mode 1 for both ports.
- (b) Interrupt is disabled
- (c) All the bits of the data I/O register of each port are reset.
- (d) All the bits of the mask control register of each port are set and masked.
- (e) The port I/O lines of each port are put in the high-impedance state (floating).
- (f) The RDY pin of each port goes low.

The reset state is held until the control word is written. For the function of the control word, see Subsection 3.5.5 "Operational Procedure".

### [2] Interrupt

The PIO can cause an interrupt when the MPU is operating in mode 2. The interrupt request signal ( $\overline{\text{INT}}$ ) from the PIO is accepted when the MPU is in the interrupt enabled state (caused after the execution of E1 instruction). Receiving the  $\overline{\text{INT}}$  signal, the MPU latches the interrupt vector (8-bit data) sent from the PIO, specifies the start address of the interrupt processing routine based on the vector, and calls the routine to start the processing.

Thus, since the start address of the interrupt processing routine can be specified by the interrupt vector sent from the PIO, the user can change the vector value to call any desired address.

Interrupt processing is terminated when the MPU executes the RETI instruction. The PIO has the circuit to decode the RETI instruction to detect the termination of interrupt processing by constantly monitoring the data bus.

The interrupt priority among the Z80 peripheral LSIs is determined by the daisy chain structure. In daisy chain, the peripheral LSIs are connected one after another as shown in Figure 3.5.3. The more a peripheral LSI is physically located near the MPU, the higher the priority of the peripheral is. Actually, the priority of the Z80 peripheral LSIs (CTC, PIO, and SIO) on the TMPZ84C015A is specified by the contents of the interrupt priority register (# F4 bits 2 through 0). Within the PIO, port A is given higher priority than port B.

The TMPZ84C015A's PIO and peripheral LSIs have the signal lines IEO and IEI connected to the IEO of a higher peripheral LSIs and the IEI of a lower peripheral LSI respectively. However, the IEI of the highest peripheral LSI is connected to the IEI pin and the IEO of the lowest peripheral LSI is connected to the IEO pin. In this state, the PIO interrupt follows the conditions:

- When both IEI and IEO are high, no interrupt has occurred. This time, the interrupt request signal (INT) is high. In this state, the PIO can request interrupt.
- When the PIO sends the INT signal, it sets the IEO line to the low level. When the interrupt request is accepted by the MPU, INT goes back to the low level.
- When the IEI goes low, the IEO also goes low.
- When the IEI is low, the PIO cannot request an interrupt.
- If the IEI goes low during interrupt occurrence, the interrupt processing is suspended.

The operations of the 4 Z80 peripheral LSIs (the states of IEI, IEO and INT signal) daisy-chained as shown in Figure 3.5.3 are as follows:

(1) Before interrupt occurrence



### (2) Interrupt request from LSI-2 to the MPU



(3) The MPU acknowledges (enables) the interrupt. Interrupt processing for LSI-2 is performed.



(4) Interrupt request from LSI-1 to the MPU. The interrupt processing for LSI-2 is suspended.



(5) The MPU acknowledges (enables) the interrupt. Interrupt processing for LSI-1 is performed.



(6) Interrupt processing for LSI-1 terminates (upon execution of the RETI instruction). Interrupt processing for LSI-2 is restarted.



170489

(7) Interrupt processing for LSI-2 terminates (upon execution of the RETI instruction).



Interrupt priority is given to LSI-1, LSI-2, LSI-3 and LSI-4 in this order.

Figure 3.5.3 Signal States in Daisy Chain Structure

### [3] Operation Modes

The PIO operates in one of the 4 operation modes. The mode is selected by writing the mode control word.

- Mode 0 (byte output mode)
- Mode 1 (byte input mode)
- Mode 2 (byte I/O mode)
- Mode 3 (bit mode)
- (1) Mode 0 (byte output mode)

In mode 0, the PIO sends the data received from the MPU to the external device through the port data output register. The contents of this register can be rewritten by using an output instruction. If the data on the bus change, the register contents remain unchanged until the next output instruction is executed. When the MPU executes an output instruction, the write signal is generated in the PIO in the write cycle. Using the signal, the data on the data bus can be latched in the data output register.

(2) Mode 1 (byte input mode)

In this mode, the PIO sends the data received from the external device to the MPU through the port data input register. The data transfer to the MPU is suspended until the MPU has read the current data.

(3) Mode 2 (byte I/O mode)

Mode 2 is a combination of mode 0 and mode 1. This mode is used only for port A. In this mode, all 4 handshake control lines are used. Port A's handshake control lines are used for data output and the port B's handshake control lines are used for data input. For data transfer, port A is used. Port B is set in mode 3 (bit mode) in which no handshake control line is used.

In this mode, the interrupt timing occurs almost at the same time in mode 0 and mode 1. In an input operation, the port B's handshake control lines are used, so that the interrupt vector written in port B is transferred. Therefore, the interrupts in input and output can be controlled by different vectors.

(4) Mode 3 (bit mode)

In mode 3, the 8-bit port I/O lines are controlled for each bit. Since no handshake control lines are used, ordinary read/write operations can be performed. I/O operations can be performed on the port as well. In a write operation, the data sent from the MPU to the PIO are latched in the data output register corresponding to the bit set for output in the same timing as in mode 0.

An interrupt occurs in the interrupt enabled state and when the bit set for input satisfies the condition specified in the interrupt control word. However, if port A is operating in mode 2, port B cannot cause an interrupt in the bit mode. Note that, to use the interrupt capability, the mask control register bit corresponding to the bit set for output must be set to "1" to disable its interrupt.

# 3.5.4 PIO Transition and Basic Timing

[1] Statis Transition

Figure 3.5.4 shows the pio status transition diagram.



170489





Figure 3.5.4 (b) PIO Status Transition

### [2] Write Cycle

The  $\overline{IORQ}$ ,  $\overline{RD}$ ,  $C/\overline{D}$  (A0),  $B/\overline{A}$  (A1), and  $\overline{CE}$  (A7 through A2) signals generate the write signal ( $\overline{WR}$ ) inside the PIO.

The MPU sets the PIO's  $\overline{IORQ}$  signal to the low level at system clock T2, to start the write cycle. At this time, to indicate that this cycle is a write cycle, the PIO's  $\overline{M1}$  signal must be set to the high level. At the same time, the MPU sends signals to the PIO's  $B/\overline{A}$  (A1) and  $C/\overline{D}$  (A0) to specify the port or select control signal or the data. This allows the port data output register of the PIO's selected port to latch the data at system clock T3. TW is a wait state automatically inserted by the MPU.



[3] Read Cycle

The MPU sets the PIO's,  $\overline{\text{RD}}$  pin,  $\overline{\text{CE}}$  signal, and  $\overline{\text{IORQ}}$  pin to the low level at system clock T2 to start the read cycle. At this time, to indicate that this cycle is a read cycle, the PIO's M1 pin must be set to the high level. The PIO outputs data in the  $\overline{\text{CE}}$ ,  $\overline{\text{IORQ}}$ , and RD signals. TW is a wait state automatically inserted by the MPU.



### [4] Mode 0 (Byte Output Mode)

The mode 0 output cycle starts when the MPU executes an output instruction. When an output instruction is executed, the write signal ( $*\overline{WR}$ ) is generated in the PIO in the write cycle. This signal latches the data on the data bus to the data output register of the selected port. The RDY pin goes high on the first falling edge of the system clock after the rise of the write signal ( $*\overline{WR}$ ). This indicates that the data in the data output register are already on the port I/O pin. The peripheral device sets the RDY pin to the low level on the first falling edge of the system clock after the rise of the  $\overline{STB}$  pin to be input to the PIO to indicate that the peripheral device has received the data from the port I/O pin, waiting for the next output instruction. If, at this time, the PIO is enabled for interrupts, it sets the  $\overline{INT}$  pin to the low level on the rising edge of the STB signal to output the interrupt request signal to the MPU. Figure 3.5.7 shows the timing chart of mode 0.

[5] Mode 1 (Byte Input Mode)

The input cycle starts when the MPU has completed the previous data read operation. The peripheral device sets the PIO's  $\overline{\text{STB}}$  pin to the lower level, putting data on the port I/O line. The RDY pin is driven low on the first falling edge of the system clock after the rise of the  $\overline{\text{STB}}$  pin, disabling the peripheral device to send the next data. If at this time, the PIO is enabled for interrupts, it sets the  $\overline{\text{INT}}$  pin to the low level on the rising edge of the  $\overline{\text{STB}}$  pin, making an interrupt request to the MPU. When the MPU executes the input instruction in the interrupt processing routine, the read signal (\* $\overline{\text{RD}}$ ) is generated
in the PIO in the read cycle. This signal puts the data in the data input register of the selected port on the data bus. The MPU receives this data. The PIO sets the RDY pin to the high level on the first falling edge of the system clock after the rise of the read signal ( $\overline{\text{RD}}$ ) to wait for the input of the next data. Figure 3.5.8 shows the mode 1 timing chart.



Figure 3.5.7 Mode 0 Timing Chart





## [6] Mode 2 (Byte I/O Mode)

Mode 2 is a combination of mode O and mode 1. The timing for output operation is generally the same as in mode 0 except that, in mode 2, data is output only when the  $\overline{\text{ASTB}}$  pin is low while, in mode 0, data is always on the port I/O line. The peripheral device can receive data on the rising edge of the  $\overline{\text{ASTB}}$  signal being used as the latch signal.

The input timing is the same as in mode 1.

The port A handshake line is used as output control and the port B handshake line is as input control.

The value of the interrupt vector generated by the BSTB signal during a port A input operation is the same as the value of the interrupt vector generated when port B is used in mode 3. Hence, all port B bits are masked by setting the mask control word to disable port B for the interrupt capability.





## [7] Mode 3 (Bit Mode)

In this mode, no handshake line is used. Therefore, the ordinary port read/write operations can be performed, permitting access to the ports any time. The write data from the MPU is latched to the data output register corresponding to the bit set for output in the same timing as in mode 0. Except when port B is used in mode 2, the STB pin of the port operating in mode 3 is fixed to the low level. The transfer data consists of the data in the data output register and in the data input register. That is, the data of the bit set for output and the data of the bit set for input make up the transfer data.

An interrupt occurs when the interrupt enabled state is on and the bits set for input satisfy the condition specified by the mask control word, etc. However, if port A is operating in mode 2, port B is disabled for interrupt in the bit mode. Note that, to use the interrupt capability, the bit of the mask register corresponding to the bit set for output must be set to "1" to disable it for interrupts.

An interrupt request occurs when the logic condition becomes true. If the logic condition becomes true immediately before the  $\overline{M1}$  pin becomes low or while  $\overline{M1}$  pin is low, an interrupt request occurs on the rising edge of the  $\overline{M1}$  pin.



Figure 3.5.10 Mode 3 Timng Chart

#### [8] Interrupt Acknowledge Cycle

Outputting the interrupt request signal (INT), the PIO sets the IEO signal to the low level, disabling the low-priority peripheral LSIs for interrupt requests.

Receiving the interrupt request signal ( $\overline{INT}$ ) from the PIO, the MPU sets the PIO's  $\overline{M1}$  and  $\overline{IORQ}$  pins to the low level to indicate that the MPU has acknowledged the interrupt request. The  $\overline{IORQ}$  pin goes low 2.5 system clocks later than the  $\overline{M1}$  pin. To stabilize the daisy-chained signal lines (IEI and IEO), the ports and peripheral LSIs cannot change the interrupt request.

The  $\overline{\text{RD}}$  pin remains high to make distinction between the instruction fetch and interrupt acknowledge cycles. While the  $\overline{\text{RD}}$  pin is high, the interrupt control logic in the PIO determines the interrupt requesting port of the highest priority. When the  $\overline{\text{IORQ}}$  pin goes low with the IEI pin being high, the interrupt vector is put on the data bus from the interrupt requesting port. At the same time, two system clocks are automatically inserted by the MPU as a wait state to stabilize the daisy chain structure.





# [9] Return from Interrupt Cycle

Return from interrupt processing is performed when the MPU executes the RETI instruction. This RETI instruction must be used at the end of the interrupt processing routine. When the MPU executes this instruction, the PIO's IEI and IEO return to the states active before interrupt processing.

The RETI instruction consists of two bytes and its code are EDH and 4DH. The PIO decodes the RETI instruction to determine whether there is any interrupt requesting port. In the daisy chain structure, the IEI and IEO of the interrupting LSI remain high and low respectively at the time the instruction code EDH has been decoded. If the code following EDH is 4DH, only the peripheral LSI which has sent an interrupt vector immediately before, that is, the LSI whose IEI is high and IEO is low, returns from interrupt processing. This restarts the interrupt processing of the suspended peripheral LSI of lower interrupt priority.

# TOSHIBA





# 3.5.5 PIO Operational Procedure

To operate the PIO the control words shown below must be written in it as the initial settings. They must be written in the PIO's ports, A and B, separately. Specify the I/O address listed in Table 3.5.1 to write control words and data in the PIO.

| Table 3.5.1 | I/OAddresses |
|-------------|--------------|
| /O function | I/O address  |

| I/O function   | I/O address |
|----------------|-------------|
| Port A data    | #1C         |
| Port A command | #1D         |
| Port B data    | #1E         |
| Port B command | #1F         |
|                | 170489      |

#### (1) Interrupt vector word



- Using this vector and the contents of the address indicated by the MPU's I register, the MPU generates the start address of the interrupt processing routine.
- D0 through D7 are written in the interrupt vector register.
- This word is not needed when the interrupt capability is not used.

# TOSHIBA

# (2) Mode control word



- This word specifies an operation mode.
- D7 and D6 are written in the mode control register.
- (3) Data I/O control word



- This word is needed only in mode 3.
- When mode 3 is specified by the mode control word, the data I/O control word is written after it.
- Each port is specified for output or input.
- D0 through D7 are written in the data I/O register.

## (4) Interrupt control word



- This word is for interrupt control such as interrupt condition setting.
- D4, D5, and D6 are used only in mode 3.
- With D6=0, interrupt occurs when one of the bits not masked (the bit to be monitored) by the mask control word goes active.
- With D6=1, interrupt occurs when all bits not masked (the bits to be monitored) by the mask control word go active.
- With D4=1, the suspended interrupts are all reset regardless of the mode.
- D5 and D6 are written in the control register.
- (5) Mask control word



- This word is needed only in mode 3.
- When D4=1 is set by the interrupt control word, the mask control word must be written after it.
- This word specifies whether to monitor the port I/O line specified for input by the data I/O control word.
- When the bit is set to 0, the corresponding input line is monitored and regarded as the input associated with interrupt occurrence.

- When the bit is set to 1, the corresponding input line is masked to provide the input not related to interrupt occurrence.
- The PIO checks only the input line with the bit being 0 to see if the interrupt condition is satisfied. If the condition is satisfied, the PIO requests an interrupt.
- D0 through D7 are written in the mask control register.

When port A is put in mode 2, all 4 handshake lines are used, so that port B must be set in mode 3 which uses no handshake lines. At the same time, all mask control word bits must be set to 1 (masked).

Note: Only interrupt enable/disable can be set by the following control word:



## 3.5.6 Using PIO

The following is a programming example to operate the PIO's port in mode 3. This program is followed by the main routine and the interrupt processing program.

- The MPU is used in the mode 2 interrupt.
- The table storing the start address of the interrupt processing routine is 0802H.
- Interrupts occur when both PIO's port input lines A6 and A5 go high.
- The I/O addresses of the PIO are the addresses listed in Table 3.5.1.





| ORG | 100H      |       |                                             |
|-----|-----------|-------|---------------------------------------------|
| LD  | SP, 100H  | ••••• | Sets the stack pointer.                     |
| LM  | 2         | ••••• | Sets for MPU mode 2 interrupt.              |
| LD  | A, 08H    | ••••• | Writes data in MPU I register.              |
| LD  | I, A      |       |                                             |
| ;   |           |       |                                             |
| LD  | A, 02H    | ••••• | Writes the interrupt vector word.           |
| OUT | (1DH) , A |       |                                             |
| LD  | A, OCFH   | ••••• | Writes the mode control word.               |
| OUT | (1DH) , A |       |                                             |
| LD  | A, 62H    | ••••• | Writes the data I/O control word, Sets PIO. |
| OUT | (1DH) , A |       |                                             |
| LD  | A, OF7H   | ••••• | Writes interrupt control word.              |
| OUT | (1DH) , A |       |                                             |
| LD  | A, 9FH    | ••••• | Writes the mask control word.               |
| OUT | (1DH) , A |       |                                             |
| ;   |           |       |                                             |
| ΕI  |           | ••••• | Sets interrupt enable.                      |

#### 3.6 SIO OPERATIONAL DESCRIPTION

The SIO has two independent, programmable full-duplex serial ports. These ports are assigned addresses on the TMPZ84C015A's I/O map. This subsection mainly describes the operations that take place after accessing the SIO.

## 3.6.1 SIO Block Diagram





# 3.6.2 SIO System Configuration

As shown in Figure 3.6.1, the SIO consists of the MPU bus interface, the internal controller, the interrupt controller, and two independently operating full-duplex channels. Each channel has the read register, the write register, and the external controller which controls the connection with peripheral LSIs or external devices.

The TMPZ84C015A contains all the functions and pins of the 40-pin, DIP-type TMPZ84C40A (SIO/0), TMPZ84C41A (SIO/1), and TMPZ84C42A (SIO/2). However, when using the SIO of the TMPZ84C015A, the SIO/0, SIO/1, or SIO/2 must be used alone. The pin assignments are as shown in Figure 3.6.2.



Table 3.6.1 shows the types and functions of the SIO registers. Each channel has 8 write registers and 3 read registers.

(1) Communication data path

Figure 3.6.2 shows the communication path of each channel's transfer data.

1 Receive operation

The receiver has an 8-bit receive register and a 3-stage 8-bit buffer register in FIFO configuration. This saves time in high-speed data block transfers. The receivers also have the receive error FIFO which holds the status information such as parity and framing errors. The receive data follow different paths according to the operation mode and character length as shown in Figure 3.6.3.

| Table 3.6.1 (a) | Write Regosters |
|-----------------|-----------------|
|-----------------|-----------------|

| Register        |       | Function                                                         |
|-----------------|-------|------------------------------------------------------------------|
| Write register0 | (WR0) | Resets CRC. Sets pointers of registers, and commands.            |
| Write register1 | (WR1) | Sets the interrupt mode.                                         |
| Write register2 | (WR2) | Sets the vector to be transmitted at interrupt.                  |
| Write register3 | (WR3) | Provides the parameters to control the receiver.                 |
| Write register4 | (WR4) | Provides the parameters to control the receiver and transmitter. |
| Write register5 | (WR5) | Controls the transmitter.                                        |
| Write register6 | (WR6) | Sets the sync character or the SDLC address field.               |
| Write register7 | (WR7) | Sets the sync character or the SDLC flag                         |

170489

| Table | e 3.6 | .1 (b | ) Read | Regosters |
|-------|-------|-------|--------|-----------|
|-------|-------|-------|--------|-----------|

| Register       |       | Function                                                       |
|----------------|-------|----------------------------------------------------------------|
| Read register0 | (RR0) | Indicates the receive/transmit buffer state and the pin state. |
| Read register1 | (RR1) | Indicates the error status and the end-of-frame code.          |
| Read register2 | (RR2) | Indicates the interrupt vector contents. (Channel B only)      |



Figure 3.6.3 Transfer Data Path (Channel A)

Asynchronous mode

In the asynchronous mode, the receive data enters the 3-bit buffer if the character length is 7 or 8 bits or the 8-bit receive shift register if the character length is 5 or 6 bits.

Synchronous mode

In the synchronous mode, the data path depends on the receive processing phase at the time. The receiver operation starts from the hunt phase. In this mode, the receiver searches the receiver data for the bit pattern which matches the specified sync character. If the SIO is set in the monosync mode, the receiver searches for the bit pattern which matches the sync character set in WR7; if the SIO is set in the bisync mode, the receiver searches for the bit pattern which matches two consecutive sync characters set in WR6 and WR7. When synchronization has been established, the subsequent data enter the 3-bit buffer by bypassing the sync register.

SDLC mode

In the SDLC mode, the sync register constantly monitors the receive data performing zero deletion as required. When the sync register detects 5 "1"s consecutively in the receive data, the following bit is deleted if it is "0". If it is "1", the bit that follows is checked. If it is "0", it is assumed as a flag, if it is "1", it is assumed an abort sequence (7 consecutive "1"s).

The reformatted data are put in the receive shift register via the 3-bit buffer. When synchronization has been established, the subsequent data follow the same path regardless of the character length.

2 Transmission

The transmitter has an 8-bit transmit data register and a 20-bit transmit shift register. The 20-bit transmit shift register holds the data from the WR6, WR7, and transmit data register.

Asynchronous mode

In the asynchronous mode, the data in the 20-bit transmit shift register are added with the start and stop bits to be sent to the transmit multiplexer.

Synchronous mode

In the synchronous mode, the WR6 and WR7 hold the sync character. The contents of these registers are sent to the 20-bit transmit register as the sync character at the transmission of data blocks or as the idle sync character if a transmitter underrun occurs in data block transmission.

• SDLC mode

In the SDLC mode, the WR6 holds the station address and the WR7 holds the flag. The flag (WR7) is sent to the 20-bit transmit register at the start and end of each frame. For each of the other data fields, one "0" follows five consecutive "1"s.

# (2) I/O functions

To transfer data from the MPU, the SIO must be set in the polling, interrupt, or block transfer mode.

Polling

To operate the SIO in the polling mode, all interrupts mode must be disabled. In the polling mode, the MPU reads the status bits D0 and D2 in each channel's RR0 to check for reception or transmission.

• Interrupts

There are 3 types of SIO interrupt: transmit interrupt, receive interrupt, and external/status interrupt. These interrupts can be enabled by program. The receive interrupt is further divided into the following three:

- Interrupt on the first received character
- Interrupt on all received characters
- Interrupt on special receive conditions

Higher priority is given to channel A than channel B. On the same channel, higher priority is given to reception, transmission, and external/status in this order.

The SIO provides the daisy-chained interrupt priority control feature and the interrupt vector generating feature. Further, it provides the "status affected vector" feature. This feature outputs 4 interrupts depending on the interrupt source.

• Block transfer

The SIO has the block transfer mode to adapt to the MPU's block transfer and the DMA controller. For block transfer, the  $\overline{W/RDY}$  line is used. For the MPU's block transfer, this line is used as the wait line; for the DMA block transfer, it is used as the ready line. The SIO's ready output indicates to the DMA controller that the data is ready to transfer. The SIO's wait output indicates to the MPU that the SIO is not ready for data transfer and therefore requesting the extension of the output cycle.

#### 3.6.3 SIO Basic Operations

#### (1) Asynchronous mode

For data transfer in the asynchronous mode, the character length, clock rate, and interrupt mode must be set. These parameters are written in the write registers. Note that WR4 must be set before the other registers are set.

Data transfer does not start until the transmit enable bit is set. When the auto enable bit is set, the SIO starts transmission upon the  $\overline{\text{CTS}}$  pin's going "0", allowing the programmer to send a message to the SIO without waiting for the  $\overline{\text{CTS}}$  signal. Figure 3.6.4 shows the data format of the asynchronous mode.



Figure 3.6.4 Data Format of Asynchronous Mode

### 1 Transmission

Serial data are output from the TxD pin. Its transfer clock rate can be set to one of 1, 1/16, 1/32, and 1/64 times the clock rate of be supplied to the trandmit clock input  $(\overline{\text{TxC}})$ . The serial data are output on the falling edge of  $\overline{\text{TxC}}$ .

#### 2 Reception

The receiver operation in the asynchronous mode starts when the receive enable bit (D0 of WR3) is set. When the receive data input RxD is set to "0" for the duration of at least 1/2 bit time, the SIO interprets it as the start bit, sampling the input data at the middle of the bit time. The sampling is performed on the rising edge of the  $\overline{\text{RxC}}$  signal.

When the receiver receives the data whose character length is not 8 bits, it converts the data into the one composed of the necessary bits, the parity bit and the unused bit set to "1".

```
Example : a 6-bit character
```

| 1 P D5 D4 D3 D2 D1 D0 |
|-----------------------|
|-----------------------|

When the external/status interrupt is enabled and a break state is detected in the receive data, the interrupt is generated and the break/abort status bit (D7 of RR0) is set and the SIO monitors the transmit data until the break state is cleared. The interrupt is also generated when the  $\overline{\text{DCD}}$  signal is in the inactive state for more than the specified pulse width. The DCD status bit is set to "1".

In the polling mode, the MPU must refer the receive character valid bit (D0 of RR0) to read the data. This bit is automatically reset when the receive buffer is read. In the polling mode, the transmit buffer status must be checked before writing data in the transmitter to avoid overwrite.

### (2) Synchronous mode

There are 3 kinds of character synchronization : monosync, bisync, and external sync. In each of these synchronous modes, the times 1 clock rate is used for both transmission and reception. The receive data is sampled on the rising edge of the receive clock input  $(\overline{RxC})$ . The transmit data changes on the falling edge of the transmit clock input.



170489

#### Figure 3.6.5 Data Format of Synchronous Mode

#### 1 Monosync

In this mode, synchronization is established when a match with the sync character (8 bits) set to WR7 is found, enabling data transfer.

#### 2 Bisync

In this mode, synchronization is established when a match with 2 consecutive sync characters set to WR6 and WR7 is found, enabling data transfer. In this mode as well as the monosync mode  $\overline{\text{SYNC}}$  is active during the receive clock period in which the sync character is being detected.

#### 3 External sync

In this mode, synchronization is performed externally. When synchronization is established, it is indicated by the  $\overline{\text{SYNC}}$  pin. The  $\overline{\text{SYNC}}$  input must be kept to "0" until the character synchronization is lost. Character assembly starts from the rising edge of the  $\overline{\text{RxC}}$  after the falling of the  $\overline{\text{SYNC}}$ .

After reset, the SIO enters the hunt phase to search for the sync character. If synchronization is lost, the SIO sets the enter-hunt-phase-bit (D4 of WR3) to reenter the hunt phase.

• Transmission

### (a) Data transfer using interrupt

When the transmit interrupt is enabled, the interrupt is caused upon the transmit buffer's being emptied. For the interrupt processing, other data are written in the transmitter. If these data are not ready for some reason, the transmit underrun condition occurs.

#### (b) Bisync mode

In the bisync mode, if the transmitter runs out of data during transmission, supply characters are inserted. This is done in two methods. In one method, sync characters are inserted. In the other, characters generated so far are transmitted followed by sync characters. Either of these methods can be selected by the reset transmit underrun/EOM command in WR0.

#### (c) End of transmission

Break can be performed by setting bit D4 of WR5. When break is performed, the data in the transmit buffer and the shift register are lost. When the external/status interrupt is enabled, the SIO generates the interrupt depending on the transmitter state and outputs the vector. This mode can be used for block transfer.

- Reception
- (a) Interrupt on the first received character

This mode is used for ordinary block transfer. In this mode, the SIO generates the interrupt only for the first character; subsequently, it does not generate the interrupt unless special receive conditions are satisfied.

To initialize these settings, command 4 of WR0 (to be enabled by the next receive interrupt) must be set in advance.

(b) Interrupt on all received characters

In this mode, the SIO generates the interrupt for all characters coming into the receive buffer. When the status affect vector has been set, a special vector is generated on a special receive condition.

(c) Special receive condition interrupt

This interrupt occurs when any of the above interrupts is selected. The special receive conditions include parity error, receive overrun error, framing error, and end-of-frame (SDLC). These error status bits are latched, so that they must be reset after they are read. They can be reset by command 6 of WR0 (error reset).

(3) SDLC mode

The SIO supports both the SDLC and HDLC protocols. They resemble each other, so that only the SDLC mode is explained here.

Figure 3.6.6 shows the data format in the SDLC mode. In the SDLC mode, one data block is called a frame and the message in it is put between the open flag and the close. The address field in the frame contains the address of a secondary station. Checking this address, the SIO receives or ignores the frame.



Figure 3.6.6 Data Format in SDLC Mode

- Transmission
- (a) Data transfer using interrupt

When the transmit interrupt has been set, the interrupt occurs each time the transmit buffer becomes empty. In the SDLC mode, data are sent to the SIO by this interrupt.

(b) Data transfer using wait/ready

The wait function in the wait/ready capability is used to make the MPU extend the output cycle when the SIO's transmit buffer is not empty. The ready function indicates to the DMA that the SIO's transmit buffer is empty and therefore ready to receive data. If no data has been written in the transmit shift register before transmission, the SIO goes in the underrun state. This capability permits data transfer to the SIO.

### (c) Transmit underrun/EOM

The SIO automatically ends the SDLC frame if there is no data to be transmitted to the transmit data buffer. To implement this, the SIO sends a 2-byte CRC when there is no data to send, then the SIO transmits one or more flags. After reset, the transmit underrun/EOM status bit is set to prevent the CRC character from being inserted when there is no data to be sent. Using this function, the SIO starts frame transmission. Here, the transmit underrun/EOM reset command must be set in advance between the transmission of the first data and the data end. Thus, the SIO goes in the reset state at the end of each message with the CRC character being sent automatically.

(d) CRC generation

For CRC calculation, the CRC generator must be reset before transmission (bits D6 and D7 of WR0). CRC calculation starts when the address field is written in the SIO (WR6). The transmit CRC enable bit (D0 of WR5) must be set before the address field is written.

(e) End of transmission

When the transmitter is disabled during transmission, the data currently transmitted is all transmitted to its end. The subsequent data is put in the marking state. When the transmitter is disabled, characters remain in the buffer. However, the abort sequence is made active when the abort command is written in the command register, deleting all data.

# Reception

As in the transmit mode, several parameters must be preset in the receive mode. The address field is written in WR7 and the flag character in WR7. Receiving the open flag, the receiver compares the contents of the following address field with the address set in WR6 or the global address ("1111 1111"). If the contents of the address field in frame matches either of these address, the SIO starts reception.

# (a) Interrupt on the first received character

This mode is generally used for the block transfer using the wait/ready capability. In this mode, the SIO generates the interrupt only on the first character. The status flag of this interrupt is latched, so that command 4 (to be enabled by the next received character) of WR0 must be preset for re-initialization. When the external/status interrupt is set, an interrupt occurs every time the  $\overline{\text{DCD}}$  changes. This interrupt also occurs when the special receive condition is satisfied.

# (b) Interrupt on all received characters

In this mode, the SIO generates an interrupt on all received characters. When the status affect vector has been set, the SIO generates a special vector on the special receive condition interrupt.

# (c) Special receive condition interrupt

Using the special receive condition, the interrupt on the first received character or the interrupt on all received characters must be selected in advance. The receive overrun status of the special receive condition interrupt is latched. The status bit can be reset by the error reset command (WR0 command).

# (d) CRC check

The receive CRC check is reset when the open flag at the head of a frame is received. CRC calculation is performed on the subsequent characters up to the close flag. In the SDLC mode, the transmit CRC is inverted, so that a special check sequence is used. The check must end with "0001 1101 0000 1111." Since SIO handles the CRC character as a data, the MPU must discard it after reading it.

# (e) End of transmission

When the SIO receives the close flag, the end-of-frame-bit is set to indicate that the close flag has been received. When the status affect vector has been set, the special receive condition interrupt occurs and the interrupt vector is output. Any frame can be aborted by abort transmission. When the external/status interrupt has been set, the interrupt occurs and the break/abort bit in RR0 is set.

- 3.6.4 SIO Status Transition Diagram and Basic Timing
- [1] Status Transition Diagram

Figure 3.6.7 shows the SIO status transition diagram.



Figure 3.6.7 (a) SIO Status Transition Diagram



Figure 3.6.7 (c) State Transition Diagram



Figure 3.6.7 (d) SIO Status Transition Diagram





## [2] Basic Timing

Figure 3.6.8 shows the timing in which data or a command is written from the MPU to the SIO. Figure 3.6.9 shows the timing in which data is read from the SIO to the MPU. Figure 3.6.10 shows the interrupt acknowledge timing in which the MPU gives an interrupt response to the SIO's interrupt request to set the  $\overline{IORQ}$  pin to "0" several clocks after setting the  $\overline{M1}$  pin to "0" as the acknowledge signal. To maintain the interrupt serviced state in daisy chain structure, the interrupt request state cannot be changed while  $\overline{M1}$  is active.

Figure 3.6.11 shows the timing in which the return from interrupt is performed.

Figure 3.6.12 shows how the daisy chain structure works. First, suppose that the SIO is servicing interrupt. When the PIO issues an interrupt request immediately before the first byte "EDH" of the RETI instruction is decoded with  $\overline{\text{M1}}$  being active, "IEO" of the PIO goes "0". However, when "EDH" is decoded, the PIO's interrupt request is not acknowledged. Therefore, the PIO's "IEO" returns to "1". When the second byte "4DH" is decoded, the SIO's "IEO" of each peripheral LSI at this point of time all go "1", or out of the interrupt serviced state. The PIO keeps the  $\overline{\text{INT}}$  pin at "0" until this state is set. Then, the interrupt is serviced starting with the peripheral device of the higher priority.





# TOSHIBA

TMPZ84C015A









Figure 3.6.10 Interrupt Acknowledge Timing



Figure 3.6.11 Return Timing from Interrupt

1 The SIO has made an interrupt request



2 The SIO is servicing the interrupt.



3 The PIO has made an interrupt request immediately before "EDH" is decoded by the SIO. By the PIO's interrupt request, PIO's IEO is set to "0".



4 Because "EDH" has been decoded, the PIO's interrupt request is not acknowledged. Therefore, PIO's IEO returns to "1".



5 Because "4DH" has been decoded, the SIO's IEO is set to "1".



6 The PIO's interrupt request is acknowledged and the PIO's IEO is set to "0".



Figure 3.6.12 Daisy Chain at Execution of RETI Instruction

# TOSHIBA

# 3.6.5 SIO Operational Procedure

The following mainly describes the meaning of each bit of the write and read registers. Special attention should be directed to the fact that the parameters of the write register (WR4) should be set before the others.

Some registers can use only a signal channel. The I/O addresses listed in Table 3.6.2 must be specified to write the control word and read/write data on the SIO.

| I/O function      | I / O address |
|-------------------|---------------|
| Channel A data    | #18           |
| Channel A command | #19           |
| Channel B data    | #1A           |
| Channel B command | #1B           |
|                   | 170489        |

#### Table 3.6.2 I/O Addresses

[I] Write Registers

1 WR 0; Write register 0

| Table 3.6.3 | Configuration | of Write Register 0 |
|-------------|---------------|---------------------|
|             |               |                     |

| D7      | D6      | D5                  | D4 | D3  | D2            | D1    | D0 |
|---------|---------|---------------------|----|-----|---------------|-------|----|
| CRC res | et code | Primary command bit |    | Reg | ister pointer | · bit |    |
|         | L       |                     |    |     |               |       |    |

170489

## Bits D0 through D2: Register pointer bits

These bits specify the register on which read/write is performed by the next byte. When read/write is completed, the register pointer points to WR0.

Bits D3 through D5: Basic command bits

• Command 0 (=000): No operation

This command only sets the register pointer without making the SIO operate. It is used to invalidate the command in the command chain for the SIO or hold the location at which a command is inserted in the command chain if required.

• Command 1 (=001): Abort sequence generation

This command is used to generate the abort sequence (7 or more consecutive "1"s). Note that command 1 is used only in the SDLC.

• Command 2 (=010): External/status interrupt reset

Once an external interrupt or a status interrupt has occurred, the status bit of RR0 is latched. This command is issued to enable the RR0's status bit in order to enable the interrupt again.

• Command 3 (=011): Channel reset

This command performs generally the same operation as when the  $\overrightarrow{\text{RESET}}$  pin is set. The difference is that reset is performed only on a single channel. The command for channel A resets the interrupt priority circuit as well.

• Command 4 (=100): Enable the interrupt at the next character reception.

This command is used to enable an interrupt when the end of block a data block has been detected followed by the reception of the next block.

• Command 5 (=101): Reset transmit interrupt pending

If the transmit buffer becomes empty in the transmit interrupt enable mode, an interrupt occurs. This command is used to disable the transmit interrupt when there is no data in the transmit buffer.

• Command 6 (=110): Error reset

The error (parity or overrun error) caused in block transfer is latched in bits D4 and D5 of RR1. This commands is used to clear these bits.

• Command 7 (=111): Return from interrupt

This command performs the same operation as the operation required to execute the RETI instruction on the SIO's data bus. Therefore, non-Z80 MPUs (that is, systems using no RETI instruction) can use the daisy chain in the SIO. This command is available only on channel A.

### Bits D6 and D7: CRC reset code

These 2 bits allow the programmer to select between the receive CRC checker reset, the transmit CRC generator reset, and the transmit underrun/EOM reset.

| Reset command                     | D7 | D6     |
|-----------------------------------|----|--------|
| No operation                      | 0  | 0      |
| Reset the receive CRC checker     | Ò  | 1      |
| Reset the transmit CRC generator  | 1  | 0      |
| Reset the transmit underrun / EOM | 1  | 1      |
|                                   |    | 170489 |

| Table 3.6.4 | List of Reset | Command | Codes |
|-------------|---------------|---------|-------|
|-------------|---------------|---------|-------|

| 2 | WR | 1; | Write | register 1 |  |
|---|----|----|-------|------------|--|
|---|----|----|-------|------------|--|

## Table 3.6.5 Configuration of Write Register 1

| D7          | D6                                 | D5                                    | D4                  | D3                 | D2                         | D1                                       | D0                                          |
|-------------|------------------------------------|---------------------------------------|---------------------|--------------------|----------------------------|------------------------------------------|---------------------------------------------|
| V<br>Enable | Vait / ready<br>Select<br>function | Select<br>receiving /<br>transmission | Rece<br>inter<br>mo | ving<br>rupt<br>de | Status<br>affect<br>vector | Enable<br>trans-<br>mission<br>interrupt | Enable<br>external /<br>status<br>interrupt |
|             |                                    |                                       |                     |                    |                            |                                          | 170489                                      |

#### Bit D0: External/status interrupt enable

When this bit is set, an interrupt is generated at the start of sync character transmission even if the execution is terminated upon detection of break/abort, the  $\overline{DCD}$ ,  $\overline{CTS}$  or  $\overline{SYNC}$  signal has changed, or the transmit underrun/EOM latch is set.

#### Bit D1: Transmit interrupt enable

When this bit is set, a transmit interrupt is generated upon the transmit buffer becoming empty.

#### Bit D2: Status affect vector

When this bit is set, bits D1 through D3 (V1 through V3) of WR2 is changed. When this bit is not set, the same interrupt vector as the contents of WR2 issued. Note that this bit is available only on channel B.

## Bits D3 and D4: Receive interrupt mode

These bits are used to select a receive interrupt mode.

#### Bits D5 through D7: Selection wait/ready functions

These 3 bits are used to select a  $\overline{W/RDY}$  pin function. The wait or the ready function is selected by program and they are not used simultaneously. The meaning of these bits are:

- When D5 is set to "1", it indicates that the W/RDY pin responds to the receive buffer; when D5 is reset to "0", it indicates that the pin responds to the transmit buffer.
- When D6 is set to "1", the W/RDY pin functions as the READY pin; when D6 is reset to "0", the pin functions as the WAIT pin.

• When D7 is set to "1", the wait/ready function is enabled; when D7 is reset to "0", the function is disabled.

For example, when D7, D6, and D5 are "1", "1", and "0" respectively, and the transmit buffer is full, the <u>READY</u> pin goes "1", when the transmit buffer is empty, the pin goes "0".

Table 3.6.6 shows the summary of the above description of bits D3 and D4 and D5 through D7.

| Receive interrupt mode                                                                      | D4 | D3 |
|---------------------------------------------------------------------------------------------|----|----|
| Receive interrupt disable                                                                   | 0  | 0  |
| Interrupt on first received character or special receive condition*                         | 0  | 1  |
| Interrupt on received character or special receive condition*                               | 1  | 0  |
| Interrupt on received character or special receive condition<br>* (except for parity error) | 1  | 1  |

 Table 3.6.6
 List of Receive Interrupt Mode Codes

170489

\*Special receive conditions:

- End of frame (in SDLC mode only)
- Receive overrun error
- Parity error
- Framing error

# Table 3.6.7 Wait / Ready Select Function (D5 through D7)

| Pin state |         | e          | Pufforstato                                                          | D7 | DG | DE |
|-----------|---------|------------|----------------------------------------------------------------------|----|----|----|
| Pin (Fu   | nction) | Pin output | Bullerstate                                                          | 07 | 00 | 05 |
| DISABLE   | WAIT    | Floating   | -                                                                    | 0  | 0  | _  |
|           | READY   | High       | -                                                                    |    | 1  |    |
|           | WAIT    | Low        | The transmit buffer is full and the SIO data port is selected.       |    | 0  |    |
|           |         | Floating   | The transmit buffer is empty.                                        |    |    | 0  |
|           | READY   | High       | The transmit buffer is full.                                         |    | 1  |    |
| ENABLE    | READT   | Low        | The transmit buffer is empty.                                        | 1  | 1  |    |
|           |         | Floating   | The receive buffer is full.                                          |    |    |    |
|           | WAIT    | Low        | The receive buffer is empty<br>and the SIO data port is<br>selected. |    | 0  | 1  |
|           | READY   | Low        | The receive buffer is full.                                          |    | 1  |    |
|           | READY   | High       | The receive buffer is empty.                                         |    | 1  |    |

| 3 WR | 2; Write regi | ster 2 |          |                                              |                                                |                           |        |
|------|---------------|--------|----------|----------------------------------------------|------------------------------------------------|---------------------------|--------|
|      |               | Table  | 3.6.8 Co | onfiguratio                                  | on of Write                                    | Register 2                |        |
| D7   | D6            | D5     | D4       | D3                                           | D2                                             | D1                        | D0     |
|      |               |        |          |                                              |                                                |                           |        |
| V7   | V6            | V5     | V4       | V3                                           | V2                                             | V1                        | VO     |
|      |               |        |          | Subject to c<br>interrupt cc<br>affect vecto | hange unde<br>onditions if t<br>or bit is set. | r different<br>ne status- | 170489 |

This write register is the interrupt vector register. When bit D2 of WR1 (B channel) is not set, the interrupt vector is issued. When bit D2 of WR1 (B channel) is set, bits D1 through D3 (V1 through V3) are changed depending on the interrupt generation condition. This time, the contents of WR2 remain unchanged. Because WR2 is available only on channel B, WR2 must be programmed even if only channel A of the SIO is used.

Table 3.6.9 shows the WR2 bit states in the interrupt condition with the status affect vector being set.

| Channel | Interrupt condition                    | V3 | V2 | V1    |
|---------|----------------------------------------|----|----|-------|
|         | Transmit buffer empty                  | 0  | 0  | 0     |
| P       | Change of external / status            | 0  | 0  | 1     |
| Ы       | Received character condition available | 0  | 1  | 0     |
|         | Special receive condition*             | 0  | 1  | 1     |
|         | Transmit buffer empty                  | 1  | 0  | 0     |
| А       | Change of external / status            | 1  | 0  | 1     |
|         | Received character available           | 1  | 1  | 0     |
|         | Special receive condition*             | 1  | 1  | 1     |
|         |                                        |    |    | 17048 |

|  | Table 3.6.9 | Channel In | terrupt C | Condition | Codes |
|--|-------------|------------|-----------|-----------|-------|
|--|-------------|------------|-----------|-----------|-------|

\*Special receive conditions:

- End of frame (in SDLC mode only)
- Receive overrun error
- Parity error
- Framing error

# 4 WR 3; Write register 3

| Table 3.6.10 | Configuration | of Write Register 3  |
|--------------|---------------|----------------------|
| 10010 0.0.10 | connigaration | of third hegic to be |

| D7               | D6                | D5             | D4                     | D3                         | D2                        | D1                                                | D0                  |
|------------------|-------------------|----------------|------------------------|----------------------------|---------------------------|---------------------------------------------------|---------------------|
| Receiv<br>/ char | ing bit<br>racter | Auto<br>enable | Enter<br>hunt<br>phase | Enable<br>receiving<br>CRC | Address<br>search<br>mode | Prohibit<br>synchro-<br>nous<br>character<br>load | Enable<br>receiving |
|                  |                   |                |                        |                            |                           |                                                   | 170489              |

# Bit D0: Receive enable

When this bit is set, the receive operation starts. Because this bit is used to start the receive operation, it must be set after the receive-associated programming has been all completed.

## Bit D1: Sync character load inhibit

When this bit is set in the sync mode, the sync character is not loaded into the receive buffer. This bit is used to remove the sync character and idle sync from the received characters.

## Bit D2: Address search mode

When this bit is set in the SDLC mode, any message having a programmed address or an address other than the global address (FFH) is not received by WR6. Therefore, the receive interrupt does not occur unless an address match occurs.

## Bit D3: Receive CRC enable

When this bit is set, CRC calculation starts at the start of the last data transfer from the receive shift register to the receiver buffer.

## Bit D4: Enter hunt Phase

When the establishment of synchronization is required, set this bit to enter the SIO into the hunt phase. The hunt phase is automatically cleared upon establishment of synchronization.

## Bit D5: Auto enable

When this bit is set, the transmitter is enabled at the time the  $\overline{\text{CTS}}$  pin is "0". When the  $\overline{\text{DCD}}$  pin is "0", the receiver is enabled.

# Bits D6 and D7: Receive character length

These bits are used to specify the number of receive bits which make up one character (character length). Table 3.6.11 shows the number of bits per character.

| Bits / character | D7 | D6     |
|------------------|----|--------|
| 5                | 0  | 0      |
| 7                | 0  | 1      |
| 6                | 1  | 0      |
| 8                | 1  | 1      |
|                  |    | 170489 |

Table 3.6.11 Receive Character Length Codes

5 WR 4; Write register 4

| Гable 3.6.12 | Configuration | of Write Register 4 |
|--------------|---------------|---------------------|
|              |               |                     |

| D7              | D6 | D5                    | D4 | D3       | D2 | D1          | D0     |
|-----------------|----|-----------------------|----|----------|----|-------------|--------|
| l<br>Clock mode |    | l<br>Synchronous mode |    | Stop bit |    | l<br>Parity |        |
|                 |    |                       |    |          | L  | Even / Odd  | Enable |

170489

# Bit D0: Parity enable

When this bit is set, 1-bit transmit data is added to the number of bits specified by D6 and D7 of WR3 and the data is received in the resulting number of bits. If a character length other than 8 bits is selected, the added parity bit is set to the MSB side to be transferred to the receive data FIFO. When the 8-bit character length is selected, the parity bit is not transferred to the receive data FIFO.

## Bit D1: Parity even/odd

This bit is used to determine whether to perform transfer and check in even or odd parity. (Even parity = "1", odd parity = "0")

## Bit D2 and D3: Stop bit length

These bits are used to select the stop bit length in the asynchronous mode. In the synchronous mode, both D2 and D3 must be set to "0".

| Stop bit                  | D3 | D2     |
|---------------------------|----|--------|
| Sync mode                 | 0  | 0      |
| 1 stop bit / character    | 0  | 1      |
| 1.5 stop bits / character | 1  | 0      |
| 2 stop bits / character   | 1  | 1      |
|                           |    | 170489 |

Table 3.6.13 Stop Bit Length Codes

#### Bits D4 and D5: Sync mode

These bits are used to select the sync mode.

| Sync mode                        | D5 | D4     |
|----------------------------------|----|--------|
| 8-bit sync mode                  | 0  | 0      |
| 16-bit sync mode (bisync mode)   | 0  | 1      |
| SDLC mode (flag character ; 7EH) | 1  | 0      |
| External sync mode               | 1  | 1      |
|                                  |    | 170489 |

# Table 3.6.14 Sync Mode Codes

# Bits D6 and D7: Clock mode

These bits are used to select the factor between the transmit/receive clock and the data transfer rate. In the synchronous mode, the  $\times 1$  clock mode must be set. In the asynchronous mode, the transmit side and the receive side must have the same factor.

| Clock mode<br>(data transfer rate) | D7 | D6 |
|------------------------------------|----|----|
| × 1 data transfer rate             | 0  | 0  |
| × 16 data transfer rate            | 0  | 1  |
| × 32 data transfer rate            | 1  | 0  |
| × 64 data transfer rate            | 1  | 1  |

Table 3.6.15 Clock Mode Codes
## 6 WR5; Write register 5

| Table 3.0.10 Configuration of Write Register | Table 3.6.16 | Configuration | of Write Register | 5 |
|----------------------------------------------|--------------|---------------|-------------------|---|
|----------------------------------------------|--------------|---------------|-------------------|---|

| D7  | D6               | D5                | D4                         | D3                          | D2               | D1  | D0                              |
|-----|------------------|-------------------|----------------------------|-----------------------------|------------------|-----|---------------------------------|
| DTR | Transr<br>/ char | nit bit<br>racter | Break<br>trans-<br>mission | Enable<br>trans-<br>mission | CRC-16<br>/ SDLC | RTS | Enable<br>CRC trans-<br>mission |

#### Bit D0: Transmit CRC enable

When this bit is set at the time the transmit data is loaded from the transmit data buffer into the transmit shift register, the CRC calculation is performed on that data. If this bit is not set, the CRC calculation and transmission are not performed in the transmit underrun state in the synchronous or SDLC mode.

#### Bit D1: Request to send

When this bit is set, the RTS pin goes "0". When this bit is not set, the RTS pin goes "1". In the asynchronous mode, the RTS pin goes "1" when the transmit buffer becomes empty. In the synchronous or SDLC mode, this bit state is followed by the RTS pin state.

#### Bit D2: CRC-16/SDLC

When this bit is set, the CRC-16 polynomial  $(X^{16} + X^{15} + X^2 + 1)$  is selected. When this bit is reset to "0", the CRC-CCITT polynomial  $(X^{16} + X^{12} + X^5 + 1)$  is selected.

#### Bit D3: Transmit enable

When this bit is set, the transmitter is enabled. Even if this bit is reset to "0" after the start of transmission, the sync character and the data being transmitted are transmitted to the last.

#### Bit D4: Transmit break

When this bit is set, transmitting any data forcibly puts the transmit data line (TxD pin) in the space state. When this bit is reset to "0", the TxD pin is put in the marking state.

#### Bits D5 and D6: Transmit character length

These bits indicate the character length of transmit data.

| Table 5.6.17 Transmit enare | Letter Lettig | th coucs |
|-----------------------------|---------------|----------|
| Bits / character            | D6            | D5       |
| Less than 5 bits            | 0             | 0        |
| 7 bits                      | 0             | 1        |
| 6 bits                      | 1             | 0        |
| 8 bits                      | 1             | 1        |
|                             |               | 170489   |

Table 3.6.17 Transmit Character Length Codes

As shown in Table 3.6.17, for the transmission of less than 5 bits (4 bits or 3 bits) per character, D6 and D5 are "0" and "0", which do not indicate how many bits the transmit data consists of. To solve this problem, the data characters must be processed by the format shown in Table 3.6.18. Note that D indicates data.

Table 3.6.18 Data Transfer Format with Transmit Data Consisting of Less than 5 bits

| Transmit bits / character | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |
|---------------------------|----|----|----|----|----|----|----|----|
| 1                         | 1  | 1  | 1  | 1  | 0  | 0  | 0  | D  |
| 2                         | 1  | 1  | 1  | 0  | 0  | 0  | D  | D  |
| 3                         | 1  | 1  | 0  | 0  | 0  | D  | D  | D  |
| 4                         | 1  | 0  | 0  | 0  | D  | D. | D  | D  |
| 5                         | 0  | 0  | 0  | D  | D  | D  | D  | D  |

170489

### Bit D7: Data terminal ready

This bit indicates the  $\overline{\text{DTR}}$  pin state. When this bit is set, the  $\overline{\text{DTR}}$  pin goes "0", when it is reset, the  $\overline{\text{DTR}}$  pin goes "1".

7 WR6; Write register 6

| Table 3.6.19 | Configuration | of Write Register 6 |
|--------------|---------------|---------------------|
|              |               |                     |

| D7   | D6 | D5 | D4 | D3 | D2 | D1 | D0 |  |
|------|----|----|----|----|----|----|----|--|
| SYNC |    |    |    |    |    |    |    |  |
| 7    | 6  | 5  | 4  | 3  | 2  | 1  | 0  |  |
|      |    |    |    |    |    |    |    |  |

.

This register is programmed as follows:

- In the external sync mode : Transmit sync character
- In the monosync mode : Transmit sync character
  - In the bisync mode : First sync character
- In the SDLC mode : Slave station address

## 8 WR7; Write register 7

| Table 3.6.20 | Configuration | of Write Register 7 |
|--------------|---------------|---------------------|
|              |               |                     |

| D7        | D6        | D5        | D4        | D3        | D2        | D1       | D0       |  |
|-----------|-----------|-----------|-----------|-----------|-----------|----------|----------|--|
| SYNC      |           |           |           |           |           |          |          |  |
| 15<br>(7) | 14<br>(6) | 13<br>(5) | 12<br>(4) | 11<br>(3) | 10<br>(2) | 9<br>(1) | 8<br>(0) |  |

170489

This register is programmed as follows:

- In the monosync mode : Receive sync character
- In the bisync mode : Second sync character
- In the SDLC mode : Flag character (7EH)

This register is not used in the external sync mode.

- [2] Read Registers
  - 1 RR 0; READ REGISTER 0

## Table 3.6.21 Configuration of Read Register 0

| D7              | D6                              | D5  | D4                        | D3  | D2                             | D1                   | D0                                  |
|-----------------|---------------------------------|-----|---------------------------|-----|--------------------------------|----------------------|-------------------------------------|
| Break/<br>Abort | Trasmission<br>underrun<br>/EOM | CTS | Synchro-<br>nize<br>/Hunt | DCD | Trasmission<br>buffer<br>empty | Interrupt<br>pending | Receiving<br>character<br>effective |
|                 |                                 |     |                           |     |                                |                      |                                     |

Used with the external / status interrupt

### Bit D0: Receive character available

This bit is set when the receive buffer holds characters of 1 byte or more. This bit is reset when the buffer becomes empty.

#### Bit D1: Interrupt pending

This bit is set when an interrupt occurs in the SIO regardless of the interrupt condition type. This bit is available only on channel A.

#### Bit D2: Transmit buffer empty

This bit is set when the transmit data buffer becomes empty or the SIO is reset. However, in the sync and SDLC modes where the CRC character is being transmitted, bit D2 is reset.

#### Bit D3: Data carrier detect

This bit indicates the  $\overline{\text{DCD}}$  pin input state. This bit is latched when the external/status interrupt occurs.

#### Bit D4: Sync/hunt

The meaning of this bit depends on the operation mode:

(i) Asynchronous mode

Bit D4 indicates the SIO's <u>SYNC</u> pin state. When the <u>SYNC</u> pin state changes, the external/status interrupt occurs.

(ii) External sync mode

When synchronization has been established by the detection of external synchronization, the last bit of the sync character must be set to "0" at the second  $\overline{\text{RxC}}$  falling edge from the rising edge of the received  $\overline{\text{RxC}}$ . That is, to set the  $\overline{\text{SYNC}}$  input to "0" by the external circuit after the detection of synchronization, full 2 receive cycle clocks must be awaited.

When the  $\overline{\text{SYNC}}$  input goes "0", the sync hunt bit is set. When synchronization is lost or the end of message is detected, the enter hunt phase bit is set.

(iii) Internal sync mode

In the monosync and bisync modes, bit D4 is initialized to "1" by the enter hunt phase command (D4 of WR3). This bit is reset when the SIO detects the sync character.

#### (iv) SDLC mode

Bit D4 is set when the receiver is disabled or the enter hunt phase command is issued. Then, when the frame open flag is detected, this bit is reset.

## Bit D5: Clear to send

This bit indicates the opposite of the  $\overline{\text{CTS}}$  pin input state.

## Bit D6: Transmit underrun/EOM

This bit is set when the SIO is reset (including channel reset). Only the reset transmitter underrun/EOM latch command (WR0 bits D7, D6 = "1", "1") can reset this bit. When the transmit underrun state occurs, the external/status interrupt is generated. Bit D5 is also used to control transmission in the sync or SDLC mode.

## Bit D7: Break/abort

In the asynchronous mode in reception, this bit indicates the break state detection. When the break state is detected, this bit is set, generating the external/status interrupt. This bit is reset by the external/status interrupt reset command.

After break, the external/status interrupt is generated again. In the SDLC mode, bit D7 is set when the abort sequence is detected, generating the external/status interrupt.

2 RR 1; READ REGISTER 1

| Table 3.6.22 | Configuration of | Read Register 1 |
|--------------|------------------|-----------------|
|--------------|------------------|-----------------|

| D7              | D6               | D5                            | D4              | D3 | D2       | D1 | D0                        |
|-----------------|------------------|-------------------------------|-----------------|----|----------|----|---------------------------|
| End of<br>frame | framing<br>error | Receiving<br>overrun<br>error | Parity<br>error |    | Fraction |    | Feed<br>all<br>characters |
|                 |                  |                               |                 |    |          |    | 170/99                    |

### Bit D0: All sent

In the asynchronous mode, this bit is set when all characters are sent from the transmitter or there is no transmit data in the SIO. In the synchronous mode, this bit is always set.

### Bits D1 through D3: Fraction codes

Normally, I field is an integral multiple of character length. If it is not, these bits show the number of fraction bits. These codes are effective only for the transmission for which the end of frame bit is set in the SDLC mode.

Example: Figure 3.6.13 shows examples of fractions in which the number of bits/character at the end of I field is 8 bits (1) and 4 bits (2).



Figure 3.6.13 Examples of Fraction Bits Field

Table 3.6.23 (a) shows the fraction codes for the receive character whose character length is 8 bits.

| Number of fraction | bits at end of I field | 202 | 2  | D1     |
|--------------------|------------------------|-----|----|--------|
| 1 byte before      | 2 bytes before         | 03  | DZ | DI     |
| 0                  | 3                      | 1   | 0  | 0      |
| 0                  | 4                      | 0   | 1  | 0      |
| 0                  | 5                      | . 1 | 1  | 0      |
| 0                  | 6                      | 0   | 0  | 1      |
| 0                  | 7                      | 1   | 0  | 1      |
| 0                  | 8                      | 0   | 1  | 1      |
| 1                  | 8                      | 1   | 1  | 1      |
| 2 8                |                        | 0   | 0  | 0      |
|                    |                        |     |    | 170489 |

Table 3.6.23 (a) Bit Patterns by Fraction Bits at End of I Field

The same table can also be provided for each character length when the receive character length of I field is other than 8 bits.

Table 3.6.23 (b) Bit Patterns by Number of Bit / Character (No Fractions)

| Bits / character   | D3 | D2 | D1 |
|--------------------|----|----|----|
| 5 bits / Character | 0  | 0  | 1  |
| 6 bits / Character | 0  | 1  | 0  |
| 7 bits / Character | 0  | 0  | 0  |
| 8 bits / Character | 0  | 1  | 1  |

#### Bit D4: Parity error

This bit is latched when the parity select bit (D0 of WR4) is set and a parity error is detected in the receive data. Latch can be cleared by the error reset command (WR0 bits D5, D4, D3 = "1", "1", "0").

#### Bit D5: Receive overrun error

The receive data FIFO holds up to 3 characters. When more characters are received without read out by the MPU, the excess character is set to the receive FIFO. When this character is read by the MPU, this receive overrun error is set. Once set, bit D5 latches that state. When the error reset command (command 6 of WR0 bits D3 through D5) is written, this bit is also reset.

#### Bit D6: CRC/framing error

In the asynchronous mode, this bit is set when a framing error is detected in the received character. Because this bit is not latched, it is always updated.

In the synchronous and SDLC modes, this bit indicates the transmitted CRC check result. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written.

#### Bit D7: End of frame

This bit is set when the end flag is detected in the receive data and the CRC check and the fraction code are found normal. This bit is reset when the error reset command (command 6 of WR0 bits D3 through D5) is written. This bit is used only in the SDLC mode and is updated when the first character of the next frame is received.

3 RR 2; Read register 2



Table 3.6.24 Configuration of Read Register 2

Subject to change under different interrupt conditions if the status-affect bit is set

When the status affect vector bit (D2 of WR1 (Channel B)) is set, bits V3 through V1 are changed depending on the interrupt condition at the time. The vector to be read is determined by the interrupt condition having the highest priority at the time of read. When the status affect vector bit is reset, the contents of this register are the same as those of WR2.

#### 3.6.6 Using SIO

The following describes some system examples using the SIO. Figure 3.6.14 shows an inter-processor communication system. In this example, the MPU on the left side controls the data transfer with the modules on the right side. Both diagrams shown in Figure 3.6.14 (a) and (b) are communication systems. As shown, the SIO is used to interface with external devices in data communication. The greatest advantage of the SIO is the smaller number of data lines than parallel communication.



Figure 3.6.14 (a) Example of Data Communication Between Processors



170489



MPUZ80-705

## TOSHIBA

#### 3.7 STANDBY CAPABILITY

When a HALT instruction is executed, the TMPZ84C015A is put in one of the Run, Idle-1, Idle-2, or Stop mode depending on the contents of the halt mode setting register (#F0:bit 4, bit 3:HALTMR). (However, the TMPZ84C015A is put in the Run mode immediately after the reset operation by the RESET pin.) The halt mode setting register is set as follows. For the description and timing of each mode, see Subsection 3.3 "CGC Operations."

The halt mode setting register is assigned to bits 4 and 3 of address F0 in the I/O address area. The halt mode is released by the interrupt (the nonmaskable interrupt by the  $\overline{\text{NMI}}$  pin or the maskable interrupt by the  $\overline{\text{INT}}$  pin) or by the reset through the RESET pin. A maskable interrupt is accepted when the MPU is in the EI state (in the state after the execution of EI instruction). A nonmaskable interrupt is accepted, the interrupt processing starts.

When the MPU is in the DI state (after the reset operation and the execution of DI instruction) with maskable interrupt, the TMPZ84C015A returns to the halt mode after executing a HALT instruction (actually a NOP instruction).

#### 3.7.1 Setting Halt Mode

Duplicate control is provided to prevent the stop of the watchdog timer operation which may be caused by the halt mode setting error due to program runaway.

The halt mode is set by the halt mode setting register (HALTMR) and the halt mode control register (#F1:bits 7 through 0:HALTMCR). Figure 3.7.1 shows the contents of the halt mode control register (HALTMCR). Figure 3.7.2 shows the contents of the halt mode setting register (HALTMR).

### MPUZ80-706



Figure 3.7.1 Halt Mode Control Register (HLTMCR)



(Note) \* : State after reset

170489

## Figure 3.7.2 Halt Mode Set Register

Figure 3.7.3 shows the device states in the halt state with the CLKOUT pin connected to the CLKIN pin.

| MODE  | CGC | MPU | СТС | PIO | SIO | Watchdog<br>Timer (WDT) | CLKOUT<br>PIN |
|-------|-----|-----|-----|-----|-----|-------------------------|---------------|
| IDLE1 | 0   | ×   | ×   | ×   | ×   | ×                       | ×             |
| IDLE2 | 0   | ×   | 0   | ×   | ×   | ×                       | 0             |
| STOP  | ×   | ×   | ×   | ×   | ×   | ×                       | ×             |
| RUN   | 0   | 0   | 0   | 0   | 0   | 0                       | 0             |

○ ····· Operating

× ····· Stop

Note : CLKOUT and CLKIN must be connected.

Figure 3.7.3 Device States in Halt State

For the halt mode in which the clock is supplied from the CLKIN pin (with the CGC oscillator unused), the Run mode must be used.

### 3.7.2 Halt Mode Setting procedure

After reset, the halt mode is changed to the Run mode. Figure 3.7.4 shows the procedure to set a new mode.



Figure 3.7.4 Setting Halt Mode

### 3.8 WATCHDOG TIMER

The watchdog timer (WDT) detects an operation error caused by the program runaway to return to the normal operation.

### 3.8.1 Block Diagram of Watchdog Timer

Figure 3.8.1 shows the block diagram of the watchdog timer.



Figure 3.8.1 Block Diagram of Watchdog Timer

## 3.8.2 Setting watchdog Timer

(1) Enabling the watchdog timer

The watchdog timer can be set by the watchdog timer enable register (#F0:bit 7:WDTER) and the watchdog timer periodic register (#F0:bit 6, bit 5:WDTPR).



Figure 3.8.2 Enabling Watching Timer

(2) Disabling the watchdog timer

The watchdog timer can be disabled by disabling the watchdog timer enable register (WDTER) then writing data "B1" in the watchdog timer control register (#F1:bit 7 through bit 0:WDTCR).

This function has a duplicate structure to prevent the watchdog timer setting error, which may lead to the watchdog timer operation stop, caused by program runaway.





## (3) Clearing the watchdog timer

The watchdog timer can be cleared by writing data "4E" in the watchdog timer control register (WDTCR).







Figure 3.8.5 Reading Watchdog Timer Setting Register

## 3.8.3 Watchdog Timer Output

When the enabled watchdog timer is used, the "0" level signal is output to the  $\overline{\text{WDTOUT}}$  pin after the duration of time specified in the watchdog timer periodic register (WDTPR). The output pulse width is one of the following two types depending on the  $\overline{\text{WDTOUT}}$  pin connection:

- (1) The WDTOUT connected to the RESET pin:The "0" level pulse of 5TcC (System clock) is output.
- (2) The WDTOUT connected to a pin other than RESET pin :The "0" level pulse is kept output until the watchdog timer is cleared by software or reset by the RESET pin.

### 3.9 INTERRUPT PRIORITY

The programmable interrupt priority register (#F4:bits 2 through 0:INTPR) is provided to determine the interrupt priority for the CTC, SIO, and PIO in the TMPZ84C015A.

## 3.9.1 Setting Interrupt Priority

Figure 3.9.1 shows the register to determine the daisy chain interrupt priority for the CTC, SIO, and PIO.



170489

Figure 3.9.1 Interrupt priority Register (INTPR)

Example:

When "101" is written in address F4 (INTPR), the daisy chain interrupt priority is given as shown in Figure 3.9.2.



Figure 3.9.2 Daisy Chain Interrupt Priority

# 4. ELECTRICAL CHARACTERISTICS

## 4.1 MAXIMUM RATINGS

| SYMBOL  | ITEI                                 | М                                                                        | RATING          |  |  |  |
|---------|--------------------------------------|--------------------------------------------------------------------------|-----------------|--|--|--|
| VCC     | Vcc Supply Voltage with resp         | pect to Vss                                                              | -0.5V to +7.0V  |  |  |  |
| VIN     | Input Voltage                        | t Voltage                                                                |                 |  |  |  |
| PD      | Power Dissipation (6MHz V<br>(8MHz V | wer Dissipation (6MHz VERSION : TA = 85°C)<br>(8MHz VERSION : TA = 70°C) |                 |  |  |  |
| TSOLDER | Soldering Temperature (Sold          | dering Time 10 sec)                                                      | 260°C           |  |  |  |
| TSTG    | Storage Temperature                  |                                                                          | – 55°C to 125°C |  |  |  |
| TOPP    | Operating Temperature                | 6MHz VERSION                                                             | – 40°C to 85°C  |  |  |  |
|         |                                      | 8MHz VERSION                                                             | – 10°C to 70°C  |  |  |  |

300389

(1/2)

## 4.2 DC Electrical Characteristics

6MHz VERSION: TOPR= $-40^{\circ}$ C to  $+85^{\circ}$ C, VCC= $5V \pm 10^{\circ}$ , VSS=0V 8MHz VERSION: TOPR= $-10^{\circ}$ C to  $+70^{\circ}$ C, VCC= $5V \pm 5^{\circ}$ , VSS=0V

|        |                                             |                  |           |      |           | (=)    |
|--------|---------------------------------------------|------------------|-----------|------|-----------|--------|
| SYMBOL | PARAMETER                                   | TEST CONDITION   | MIN.      | TYP. | MAX.      | UNIT.  |
| VILC   | Clock Input Low Voltage<br>(CLKIN)          |                  | - 0.3     |      | 0.6       | V      |
| VIHC   | Clock Input High Voltage<br>(CLKIN)         |                  | VCC – 0.6 | _    | VCC + 0.3 | v      |
| VIL    | Input Low Voltage<br>(except XTAL1. RESET)  |                  | - 0.5     | _    | 0.8       | v      |
| VIH    | Input High Voltage<br>(except XTAL1. RESET) |                  | 2.2       | _    | VCC       | v      |
| VILR   | Input Low Voltage<br>(RESET)                |                  | - 0.5     | -    | 0.45      | v      |
| VIHR   | Input High Voltage<br>(RESET)               |                  | VCC – 0.6 | _    | vcc       | V      |
| VOLC   | Output Low Voltage<br>(CLKOUT)              | IOL = 2.0mA      | _         | _    | 0.6       | v      |
| VOHC   | Output High Voltage<br>(CLKOUT)             | IOH = - 2.0mA    | VCC – 0.6 |      | _         | v      |
| VOL    | Output Low Voltage<br>(except CLKOUT)       | IOL = 2.0mA      | -         | —    | 0.4       | v      |
| VOH1   | Output High Voltage 1<br>(except CLKOUT)    | IOH = - 1.6mA    | 2.4       | _    | _         | v      |
| VOH2   | Output High Voltage 2<br>(except CLKOUT)    | IOH = -250µA     | VCC – 0.8 | _    |           | v      |
| ILI    | Input Leakage Current                       | Vss≦VIN≦Vcc      | -         | 1    | ± 10      | μA     |
| ILO    | 3-state Output Leakage<br>Current in Float  | Vss≦Vout<br>≦VCC |           | —    | ± 10      | μA     |
|        |                                             |                  |           |      |           | 300389 |

MPUZ80-713

|        |                                            |                                                                                            |               |      |      |      | (2/2)      |
|--------|--------------------------------------------|--------------------------------------------------------------------------------------------|---------------|------|------|------|------------|
| SYMBOL | PARAMETER                                  | TEST CONDITIO                                                                              | ЛС            | MIN. | TYP. | MAX. | UNIT.      |
| ICC1   | Power Supply Current                       | VCC = 5V<br>fCLK = ( 1)<br>VIHC = VIHR = VIH                                               | AF-6          | _    | 25   | 35   |            |
|        |                                            | = VCC-0.2V,<br>VILC = VILR<br>= VIL = 0.2V                                                 | AF-8          | —    | 35   | 45   | mA         |
| ICC2   | Stand-by Supply Current<br>(See Note (2) ) | VCC = 5V<br>fCLK = ( 1)<br>VIHC = VIH = VIHR<br>= VCC-0.2V,<br>VILC = VIL<br>= VILR = 0.2V | AF-6<br>/AF-8 | _    | 0.5  | 50   | μА         |
| ICC3   | Power Supply Current                       | VCC = 5V<br>fCLK = ( 1)<br>VIHC = VIH = VIHR                                               | AF-6          |      | 1.5  | 3    | mA         |
|        | (IDLE 1 Mode)                              | = VCC-0.2V,<br>VILC = VIL<br>= VILR = 0.2V                                                 | AF-8          |      | 2    | 4    | - <b>s</b> |
| ICC4   | Power Supply Current                       | VCC = 5V<br>fCLK = ( 1)<br>VIHC = VIH = VIHR                                               | AF-6          |      | 11   | 15   | mA         |
|        | (IDLE 2 Mode)                              | = VCC-0.2V,<br>VILC = VIL<br>= VILR = 0.2V                                                 | AF-8          |      | 15   | 20   | mA         |

Note 1: fCLK = 1/TcC (MIN)

Note 2: ICC2 Stand-by Supply Current is guaranteed only when the supplied clock is stopped at a low level during T4 state of the following machine Cycle (M1) next to OP code fetch Cycle of HALT instruction.

Except SYNCA = 0 or SYNCB = 0 state

# TOSHIBA

## 4.3 AC ELECTRICAL CHARACTERISTICS (1) (in Active State)

 $\begin{array}{l} 6 MHz \ VERSION \ : TA = -40^{\circ}C \sim 85^{\circ}C, \ VCC = 5V \pm 10\%, \ VSS = 0V \\ 8 MHz \ VERSION \ : TA = -10^{\circ}C \sim 70^{\circ}C, \ VCC = 5V \pm 5\%, \ VSS = 0V \\ (8 MHz \ Version \ guarantee \ AC \ characteristics \ in \ only \ Active \ State.) \end{array}$ 

## 4.3.1 AC Characteristics of MPU (in Active State)

|     |              |                                                        |      |                   |       |      |                   |       | (1/3) |
|-----|--------------|--------------------------------------------------------|------|-------------------|-------|------|-------------------|-------|-------|
| NO. | SYMBOL       | PARAMETER                                              | TMP  | Z84C01!<br>(6MHz) | 5AF-6 | TMPZ | 284C015<br>(8MHz) | 5AF-8 | UNIT  |
|     |              |                                                        | MIN. | TYP.              | MAX.  | MIN. | TYP.              | MAX.  |       |
| 1   | TcC          | Clock Cycle Time                                       | 162  | —                 | DC    | 125  |                   | DC    | ns    |
| 2   | TwCh         | Clock Pulse Width (High)                               | 65   | -                 | DC    | 50   | -                 | DC    | ns    |
| 3   | TwCl         | Clock Pulse Width (Low)                                | 65   | —                 | DC    | 50   |                   | DC    | ns    |
| 4   | TfC          | Clock Fall Time                                        | —    | -                 | 20    | —    | -                 | 15    | ns    |
| 5   | TrC          | Clock Rise Time                                        | —    |                   | 20    | —    | -                 | 15    | ns    |
| 6   | TdCr (A)     | Clock ↑ to Address Valid<br>Delay                      | -    |                   | 90    | —    |                   | 85    | ns    |
| 7   | TdA (MREQf)  | Address Valid to<br>MREQ ↓ Delay                       | 35   | -                 | _     | 20   | _                 | _     | ns    |
| 8   | TdCf (MREQf) | $Clock \downarrow to \overline{MREQ} \downarrow Delay$ |      | -                 | 70    | -    | _                 | 60    | ns    |
| 9   | TdCr (MREQr) | Clock ↑ to MREQ ↑ Delay                                | -    |                   | 70    | —    | —                 | 60    | ns    |
| 10  | TwMREQh      | MREQ Pulse Width (High)                                | 65   | -                 | -     | 45   | -                 | -     | ns    |
| 11  | TwMREQI      | MREQ Pulse Width (Low)                                 | 135  | -                 | -     | 100  | -                 | -     | ns    |
| 12  | TdCf (MREQr) | Clock $↓$ to $\overline{MREQ} \uparrow Delay$          | -    | -                 | 70    | -    | -                 | 60    | ns    |
| 13  | TdCf (RDf)   | $Clock \downarrow to \overline{RD} \downarrow Delay$   | -    | -                 | 80    | -    | -                 | 70    | ns    |
| 14  | TdCr (RDr)   | $Clock \uparrow to \overline{RD} \uparrow Delay$       |      | -                 | 70    | -    | -                 | 60    | ns    |
| 15  | TsD (Cr)     | Data Setup Time to Clock ↑                             | 30   | -                 | -     | 30   |                   | -     | ns    |
| 16  | ThD (RDr)    | Data Hold Time to RD↑                                  | 0    | -                 | -     | 0    | —                 |       | ns    |
| 17  | TsWAIT (Cf)  | WAIT Setup Time to Clock 🕽                             | 60   |                   | -     | 50   |                   |       | ns    |
| 18  | ThWAIT (Cf)  | WAIT Hold Time after<br>Clock↓                         | 10   | -                 | -     | 10   | ·                 |       | ns    |
| 19  | TdCr (M1f)   | Clock ↑ to M1 ↓ Delay                                  |      |                   | 80    | _    | -                 | 70    | ns    |
| 20  | TdCr (M1r)   | Clock ↑ to M1 ↑ Delay                                  | -    | -                 | 80    | -    | —                 | 70    | ns    |
| 21  | TdCr (RFSHf) | Clock↑to RFSH↓Delay                                    |      | -                 | 110   | -    | -                 | 95    | ns    |
| 22  | TdCr (RFSHr) | Clock ↑ to RFSH ↑ Delay                                |      | -                 | 100   | —    | -                 | 85    | ns    |
| 23  | TdCf (RDr)   | Clock↓to RD↑Delay                                      | —    |                   | 70    | _    | _                 | 60    | ns    |
| 24  | TdCr (RDf)   | Clock ↑ to RD ↓ Delay                                  | —    | _                 | 70    | -    | _                 | 60    | ns    |

# TOSHIBA

,

| NO.         SYMBOL         PARAMETER         TMP2st015-F-6 (SMH2)         TMP2st015-F-6 (SMH2)         IMP         MAX         MIN         TYP         MAX         MIN         TYP         MAX           25         TsD (Cf)         Data Setup to<br>Clock 1 during M2, M3, M4<br>or M5 Cycles         40         -         -         30         -         -         ns           26         TdA (lORQf)         Clock ↑ to TORQ ↓ Delay         -         -         65         -         -         55         ns           27         TdCr (lORQf)         Clock ↑ to TORQ ↓ Delay         -         -         70         -         -         60         ns           28         TdCf (lORQf)         Clock ↓ to TORQ ↑ Delay         -         -         70         -         -         60         ns           30         TdCf (WRf)         Data Stable Prior to WR ↓         2S         -         -         100         -         -         60         ns           31         TdWR         WR PulseWidth         135         -         -         105         -         -         ns           33         TdD(WRf)         Data Stable Frior WR ↑         30         -         -         -         -                                                                                                             |     |                |                                                                                                                                                                               |      |                   |       |      |                   |       | (2/3) |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|-------------------|-------|------|-------------------|-------|-------|
| MIN         TYP.         MAX.         MIN.         TYP.         MAX.         TYP.         MAX.           25         Tsb (Cf)         Data Setup to<br>Clock ↓ during M2, M3, M4<br>or MS Cycles         40           330           ns           26         TdA (IORQf)         Address Stable prior<br>IORQ ↓         110            55          ns           27         TdCr (IORQf)         Clock ↓ to IORQ ↓ Delay           70          5          ns           29         TdD (WRf)         Data Stable Prior to WR↓         25          7-         7-         60         ns           30         TdCf (WRf)         Clock ↓ to WR ↓ Delay          70           60         ns           31         TwWR         WR Pulse Width         135          7-         70           60         ns           33         TdD (WRf)         Data Stable Prior to WR ↓         -55          7-         160         ns           34         TdCr (WRf)         Data Stable Prior to WR ↓ <td< td=""><td>NO.</td><td>SYMBOL</td><td>PARAMETER</td><td>TMP2</td><td>284C01!<br/>(6MHz)</td><td>5AF-6</td><td>TMPZ</td><td>284C015<br/>(8MHz)</td><td>5AF-8</td><td>UNIT</td></td<>                                                                                                                                              | NO. | SYMBOL         | PARAMETER                                                                                                                                                                     | TMP2 | 284C01!<br>(6MHz) | 5AF-6 | TMPZ | 284C015<br>(8MHz) | 5AF-8 | UNIT  |
| 25       TsD (Cf)       Data Setup to<br>Clock J during M2, M3, M4<br>or M5 Cycles       40        30         ns         26       TdA (IORQf)       Address Stable prior<br>IORQ J       110         75         ns         27       TdCr (IORQf)       Clock $\uparrow$ to IORQ J Delay         65         55       ns         28       TdCf (IORQr)       Clock $\downarrow$ to IORQ $\uparrow$ Delay         70         60       ns         29       TdD (WRf)       Data Stable Prior to WR $\downarrow$ 25         70         60       ns         30       TdCf (WRf)       Clock $\downarrow$ to WR pleay         70         60       ns         31       TwWR       WR Pulse Width       135         155         ns         32       TdCf (WRf)       Data Stable Prior to WR $\downarrow$ 55         ns         33       TdD (WRf)       Data Stable Prior to WR $\downarrow$ 15        ns <td></td> <td></td> <td></td> <td>MIN.</td> <td>TYP.</td> <td>MAX.</td> <td>MIN.</td> <td>TYP.</td> <td>MAX.</td> <td></td>                                                                                                                                                                                                                                                                                          |     |                |                                                                                                                                                                               | MIN. | TYP.              | MAX.  | MIN. | TYP.              | MAX.  |       |
| 26       TdA (IORQf)       Address Stable prior<br>IORQ ↓       110         75         ns         27       TdCr (IORQf)       Clock ↑ to IORQ ↓ Delay         65         55       ns         28       TdCf (IORQr)       Clock ↓ to IORQ ↑ Delay         70         60       ns         29       TdD (WRf)       Data Stable Prior to WR ↓       25         100         ns         30       TdCf (WRf)       Clock ↓ to WR ↓ Delay         100         ns         31       TwWR       WR Pulse Width       135         100         ns         32       TdCf (WRf)       Data Stable Prior to WR ↓       -55         55         155       ns         33       TdD (WRf)       Data Stable Frior to WR ↓       -55         155         155       ns         34       TdCr (WRf)       Data Stable from WR ↑       30         155       ins                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 25  | TsD (Cf)       | Data Setup to<br>Clock ↓ during M2, M3, M4<br>or M5 Cycles                                                                                                                    | 40   | _                 | _     | 30   | -                 | _     | ns    |
| 27         1dcr (10RQf)         Clock ↑ to TORQ ↑ Delay          65           55         Instance           28         1dC (10RQr)         Clock ↓ to TORQ ↑ Delay          70          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50          50         50          50          50          50          50          50          50          50          50          50          50          50         <                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 26  | TdA (IORQf)    | Address Stable prior<br>IORQ ↓                                                                                                                                                | 110  |                   |       | 75   | _                 | _     | ns    |
| 28         TdCf (IORQr)         Clock \pp to ToRQ r Delay          7-         7-         7-         7-         7-         7-         7-         7-           29         TdD (WRf)         Data Stable Prior to WR \pp Leay          7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-         7-                                                                                                                                                                 | 27  | TdCr (IORQf)   | Clock ↑ to IORQ ↓ Delay                                                                                                                                                       | -    | -                 | 65    | -    | -                 | 55    | ns    |
| 29       TdD (WRf)       Data Stable Prior to WR↓       25       -       -       5       -       -       n         30       TdCf (WRf)       Clock↓ to WR↓Delay       -       -       70       -       -       600       ns         31       TwWR       WR Pulse Width       135       -       -       100       -       -       ns         32       TdCf (WRf)       Clock↓ to WR \Delay       -       -       70       -       -       600       ns         33       TdD (WRf)       Data Stable Prior to WR↓       -55       -       -       600       -       -       ns         34       TdCr (WRf)       Clock↑ to WR↓Delay       -       -       600       -       -       ns       ns         35       TdWR (D)       Data Stable from WR↑       30       -       -       15       -       ns       ns         36       TdCr (HALT)       Clock↑ to HALT or ↓       -       -       60       -       -       ns       ns         37       TwNMI       NMI plaseWidth       80       -       -       40       -       -       ns       ns         38       TsBUSRE                                                                                                                                                                                                                                              | 28  | TdCf (IORQr)   | Clock↓to <del>IORQ</del> ↑Delay                                                                                                                                               | -    | -                 | 70    | -    | —                 | 60    | ns    |
| 30         TdCf (WRf)         Clock ↓ to WR ↓ Delay         -         -         70         -         -         600         nms           31         TwWR         WR Pulse Width         135         -         -         100         -         -         100           32         TdCf (WRr)         Clock ↓ to WR ↑ Delay         -         -         70         -         55         -         -         -         50         -         -         55         -         -         -         50         -         -         -         50         -         -         55         -         -         -         50         -         -         -         50         -         -         50         -         -         50         -         -         50         -         -         -         50         -         -         50         -         -         50         -         10         -         -         50         -         10         -         -         10         -         -         10         -         -         10         -         -         10         -         10         -         10         -         10         -                                                                                                                                                                             | 29  | TdD (WRf)      | Data Stable Prior to ₩R↓                                                                                                                                                      | 25   | -                 | -     | 5    | -                 | -     | ns    |
| 31       TwWR       WR Pulse Width       135         100         ns         32       TdCf (WRr)       Clock 1 to WR 1 Delay         70         600       ns         33       TdD (WRf)       Data Stable Prior to WR 1 Delay         60         55       ns         34       TdCr (WRf)       Data Stable from WR 1 Delay         60         70        70        70       70        70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70       70                                                                                                                                                                                                                                                                                                                                                                                                | 30  | TdCf (WRf)     | Clock↓to WR↓Delay                                                                                                                                                             |      | -                 | 70    | _    | -                 | 60    | ns    |
| 32       TdCf (WRr)       Clock ↓ to WR ↑ Delay       -       -       70       -       -       60       ns         33       TdD (WRf)       Data Stable Prior to WR ↓       -S5       -       -       55       -       -       55       -       -       55       -       -       55       .       -       1s         34       TdCr (WRf)       Data Stable from WR ↑       30       -       -       15       -       -       1s       .       .       ns         35       TdWR (D)       Data Stable from WR ↑       30       -       -       15       -       .       ns         36       TdCf (HALT)       Clock ↓ to HALT ↑ or ↓       -       -       260       -       .       225       ns         37       TwNMI       NMI Pulse Width       80       -       -       80       -       .       .       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock ↑       50       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .       .                                                                                                                                                                                                                                                    | 31  | TwWR           | WR Pulse Width                                                                                                                                                                | 135  | -                 | -     | 100  | -                 | -     | ns    |
| 33       TdD (WRf)       Data Stable Prior to WR \       -55       -       -       55       -       -       ns         34       TdCr (WRf)       Clock $\uparrow$ to WR $\uparrow$ Delay       -       -       60       -       -       55       ns         35       TdWRr (D)       Data Stable from WR $\uparrow$ 30       -       -       15       -       -       ns         36       TdCf (HALT)       Clock $\downarrow$ to HALT $\uparrow$ or $\downarrow$ -       -       260       -       -       225       ns         37       TwNMI       NMT Pulse Width       80       -       -       80       -       -       0       0       -       ns       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock $\uparrow$ 50       -       -       90       -       -       80       ns         39       ThBUSREQ (Cr)       BUSREQ Hold Time after Clock $\uparrow$ 10       -       -       90       -       -       80       ns         40       TdCr (BUSACKr)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       90       -       -       80       ns         41       TdCr (Dz)      Clock $\uparrow$ to Adress Float       - <td>32</td> <td>TdCf (WRr)</td> <td>Clock↓to WR↑Delay</td> <td>-</td> <td>-</td> <td>70</td> <td>_</td> <td>-</td> <td>60</td> <td>ns</td> | 32  | TdCf (WRr)     | Clock↓to WR↑Delay                                                                                                                                                             | -    | -                 | 70    | _    | -                 | 60    | ns    |
| 34       TdCr (WRf)       Clock $\uparrow$ to $\overline{WR} \downarrow$ Delay       -       -       60       -       -       55       ns         35       TdWRr (D)       Data Stable from $\overline{WR} \uparrow$ 30       -       -       15       -       225       ns         36       TdCf (HALT)       Clock $\downarrow$ to HALT $\uparrow$ or $\downarrow$ 80       -       -       80       -       -       260       -       -       225       ns         37       TwNMI       NMI Pulse Width       80       -       -       80       -       -       80       -       -       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock $\uparrow$ 50       -       -       40       -       -       ns         40       TdCr (BUSACK)       Clock $\uparrow$ to BUSAEC $\downarrow$ Delay       -       -       90       -       -       80       ns         41       TdCr (Dz)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       90       -       -       80       ns         42       TdCr (Dz)       Clock $\uparrow$ to Data Float Delay       -       -       80       -       -       70       ns         43       TdCr (Az)       Clock $\uparrow$ to Adress Floa                                                                                                 | 33  | TdD (WRf)      | Data Stable Prior to ₩R↓                                                                                                                                                      | -55  | -                 | -     | 55   | -                 | -     | ns    |
| 35       TdWRr (D)       Data Stable from $\overline{WR} \uparrow$ 30       -       -       15       -       -       ns         36       TdCf (HALT)       Clock $\downarrow$ to HALT $\uparrow$ or $\downarrow$ -       -       260       -       -       225       ns         37       TwMMI       NMI Pulse Width       80       -       -       80       -       -       80       -       -       80       -       -       80       -       -       80       -       -       80       -       -       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock $\uparrow$ 50       -       -       40       -       -       ns         39       ThBUSREQ (Cr)       BUSREQ Hold Time after Clock $\uparrow$ 10       -       -       90       -       -       80       ns         40       TdCr (BUSACKf)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       90       -       -       80       ns         41       TdCr (Dz)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       80       ns       -       -       70       ns       -       -       60       ns       -       -       10       ns                                                                                                                                                              | 34  | TdCr (WRf)     | Clock ↑ to WR ↓ Delay                                                                                                                                                         | -    | -                 | 60    | -    | -                 | 55    | ns    |
| 36       TdCf (HALT)       Clock $\downarrow$ to HALT $\uparrow$ or $\downarrow$ -       -       260       -       -       225       ns         37       TwNMI       NMI Pulse Width       80       -       -       80       -       -       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock $\uparrow$ 50       -       -       40       -       -       ns         39       ThBUSREQ (Cr)       BUSREQ Hold Time after Clock $\uparrow$ 10       -       -       90       -       -       800       ns         40       TdCr (BUSACKf)       Clock $\uparrow$ to BUSACK $\downarrow$ Delay       -       -       90       -       -       80       ns         41       TdCr (BUSACKf)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       90       -       -       80       ns         42       TdCr (Dz)       Clock $\uparrow$ to Data Float Delay       -       -       90       -       -       80       ns         43       TdCr (Dz)       Clock $\uparrow$ to Adress Float       -       -       80       -       -       70       ns         44       TdCr (Az)       Clock $\uparrow$ to Adress Float       -       -       80       -       -                                                                                                                       | 35  | TdWRr (D)      | Data Stable from WR↑                                                                                                                                                          | 30   |                   | -     | 15   | -                 | -     | ns    |
| 37       TwNMI       NMI Pulse Width       80       -       -       80       -       -       ns         38       TsBUSREQ (Cr)       BUSREQ Setup Time to<br>Clock $\uparrow$ 50       -       -       40       -       -       ns         39       ThBUSREQ (Cr)       BUSREQ Hold Time after<br>Clock $\uparrow$ 10       -       -       10       -       -       80       ns         40       TdCr (BUSACKf)       Clock $\uparrow$ to BUSACK $\downarrow$ Delay       -       -       90       -       -       80       ns         41       TdCf (BUSACKf)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay       -       -       90       -       -       80       ns         42       TdCr (Dz)       Clock $\uparrow$ to Data Float Delay       -       -       80       -       -       70       ns         43       TdCr (CTz)       Clock $\uparrow$ to Control Outputs<br>float Delay       -       -       80       -       -       70       ns         44       TdCr (Az)       Clock $\uparrow$ to Adress Float<br>Delay       -       -       80       -       -       70       ns         45       TdCr (A)       MREQ $\uparrow$ IORQ $\uparrow$ RD $\uparrow$ ,<br>ime       35       -       -       45                                                                                           | 36  | TdCf (HALT)    | Clock↓to HALT↑or↓                                                                                                                                                             | -    | -                 | 260   |      | -                 | 225   | ns    |
| 38       TsBUSREQ (Cr)       BUSREQ Setup Time to Clock $\uparrow$ 50        40         ns         39       ThBUSREQ (Cr)       BUSREQ Hold Time after Clock $\uparrow$ 10        10        10        ns         40       TdCr (BUSACKf)       Clock $\uparrow$ to BUSACK $\downarrow$ Delay         90         80       ns         41       TdCf (BUSACKr)       Clock $\uparrow$ to BUSACK $\uparrow$ Delay         90         80       ns         42       TdCr (Dz)       Clock $\uparrow$ to Data Float Delay         80         80       ns         43       TdCr (CTz)       Clock $\uparrow$ to Control Outputs Float Delay (MREQ, IORQ, RD, and WR)         80         70       ns         44       TdCr (Az)       Clock $\uparrow$ to Adress Float         80         70       ns         45       TdCr (Az)       Clock $\uparrow$ to Address Hold         80         70       ns         45       TdCr (A)       MREQ $\uparrow$ IORQ $\uparrow$ IORQ $\uparrow$ RD $\uparrow$                                                                                                                                                                                                                                                                                                                            | 37  | TwNMI          | NMI Pulse Width                                                                                                                                                               | 80   | -                 | -     | 80   | -                 | -     | ns    |
| 39ThBUSREQ (Cr)BUSREQ Hold Time after<br>Clock ↑1010ns40TdCr (BUSACKf)Clock ↑ to BUSACK ↓ Delay9080ns41TdCf (BUSACKr)Clock ↓ to BUSACK ↓ Delay9080ns42TdCr (Dz)Clock ↑ to Data Float Delay8070ns43TdCr (CTz)Clock ↑ to Control Outputs<br>Float Delay<br>(MREQ, IORQ, RD, and WR)8060ns44TdCr (Az)Clock ↑ to Adress Float<br>Delay8070fo45TdCr (Az)Clock ↑ to Adress Float<br>Delay8070ns45TdCr (A)MREQ ↑ IORQ ↑ RD ↑ ,<br>and WR ↑ to Address Hold<br>Time3545ns46TsRESET (Cr)RESET to Clock ↑ Setup Time6045ns47ThRESET (Cr)RESET to Clock ↑ Setup Time1010ns48TsINTf (Cr)INT to Clock ↑ Setup Time705ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 38  | TsBUSREQ (Cr)  | BUSREQ Setup Time to<br>Clock↑                                                                                                                                                | 50   | _                 | -     | 40   | _                 | -     | ns    |
| 40       TdCr (BUSACKf)       Clock ↑ to BUSACK ↓ Delay        90         80       ns         41       TdCf (BUSACKr)       Clock ↓ to BUSACK ↑ Delay        90         80       ns         42       TdCr (Dz)       Clock ↑ to Data Float Delay        80        70       ns         43       TdCr (Cz)       Clock ↑ to Control Outputs<br>Float Delay        70        70       ns         44       TdCr (Az)       Clock ↑ to Adress Float<br>Delay        80         70       ns         45       TdCr (Az)       MREQ ↑ ,IORQ ↑ ,RD ↑, and WR        80         70       ns         46       TsRESET (Cr)       RESET to Clock ↑ to Address Hold<br>Time       35         45         ns         47       ThRESET (Cr)       RESET to Clock ↑ Setup Time       60         45        ns         48       TsINTf (Cr)       INT to Clock ↑ Setup Time       70         ns                                                                                                                                                                                                                                                                                                                                                                                                                                           | 39  | ThBUSREQ (Cr)  | BUSREQ Hold Time after<br>Clock ↑                                                                                                                                             | 10   | -                 | -     | 10   | —                 | -     | ns    |
| 41       TdCf (BUSACKr)       Clock \ to BUSACK \ Delay       -       -       90       -       -       80       ns         42       TdCr (Dz)       Clock \ to Data Float Delay       -       -       80       -       -       70       ns         43       TdCr (CTz)       Clock \ to Control Outputs<br>Float Delay<br>(MREQ, IORQ, RD, and WR)       -       70       70       -       -       60       ns         44       TdCr (Az)       Clock \ to Adress Float<br>Delay       -       -       80       -       -       70       ns         45       TdCr (Az)       Clock \ to Adress Float<br>Delay       -       -       80       -       -       70       ns         45       TdCr (A)       MREQ  IORQ  IORQ  RD  RD<br>and WR \ to Address Hold<br>Time       35       -       -       80       -       -       ns         46       TsRESET (Cr)       RESET to Clock \ Setup Time       60       -       -       45       -       -       ns         47       ThRESET (Cr)       RESET to Clock \ Hold Time       10       -       -       10       -       -       ns         48       TsINTf (Cr)       INT to Clock \ Setup Time       70       -                                                                                                                                                    | 40  | TdCr (BUSACKf) | Clock ↑ to BUSACK ↓ Delay                                                                                                                                                     | -    |                   | 90    | -    | -                 | 80    | ns    |
| 42TdCr (Dz)Clock ↑ to Data Float Delay8070ns43TdCr (CTz)Clock ↑ to Control Outputs<br>Float Delay<br>(MREQ, IDRQ, RD, and WR)701-1-060ns44TdCr (Az)Clock ↑ to Adress Float<br>Delay8070ns45TdCr (Az)Clock ↑ to Adress Float<br>Delay8070ns45TdCr (A)MREQ ↑, IORQ ↑, RD ↑,<br>and WR ↑ to Address Hold<br>Time3545-70ns46TsRESET (Cr)RESET to Clock ↑ Setup Time6045ns47ThRESET (Cr)RESET to Clock ↑ Betup Time1010ns48TsINTf (Cr)INT to Clock ↑ Setup Time7055ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 41  | TdCf (BUSACKr) | Clock↓to BUSACK↑Delay                                                                                                                                                         | -    | -                 | 90    | -    | -                 | 80    | ns    |
| 43TdCr (CTz)Clock ↑ to Control Outputs<br>Float Delay<br>(MREQ, IORQ, RD, and WR)7-7060ns44TdCr (Az)Clock ↑ to Adress Float<br>Delay8070ns45TdCr (A)MREQ ↑, IORQ ↑, RD ↑,<br>and WR ↑ to Address Hold<br>Time358070ns46TsRESET (Cr)RESET to Clock ↑ Setup Time6045ns47ThRESET (Cr)RESET to Clock ↑ Hold Time1010ns48TsINTf (Cr)INT to Clock ↑ Setup Time7055ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 42  | TdCr (Dz)      | Clock ↑ to Data Float Delay                                                                                                                                                   | -    | -                 | 80    | -    | -                 | 70    | ns    |
| 44TdCr (Az)Clock ↑ to Adress Float<br>Delay8070ns45TdCr (A)MREQ ↑, IORQ ↑, RD ↑,<br>and WR ↑ to Address Hold3520ns46TsRESET (Cr)RESET to Clock ↑ Setup Time6045ns47ThRESET (Cr)RESET to Clock ↑ Hold Time1010ns48TsINTf (Cr)INT to Clock ↑ Setup Time7055ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 43  | TdCr (CTz)     | Clock ↑ to Control Outputs<br>Float Delay<br>(MREQ, IORQ, RD, and WR)                                                                                                         |      |                   | 70    | —    | _                 | 60    | ns    |
| 45TdCr (A)MREQ  IORQ  RD  and WR \ to Address Hold<br>Time3520ns46TsRESET (Cr)RESET to Clock \ Setup Time6045ns47ThRESET (Cr)RESET to Clock \ Hold Time101010ns48TsINTf (Cr)INT to Clock \ Setup Time7055ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 44  | TdCr (Az)      | Clock ↑ to Adress Float<br>Delay                                                                                                                                              | -    | _                 | 80    | ·    | _                 | 70    | ns    |
| 46       TsRESET (Cr)       RESET to Clock ↑ Setup Time       60         45         ns         47       ThRESET (Cr)       RESET to Clock ↑ Hold Time       10         10         ns         48       TsINTf (Cr)       INT to Clock ↑ Setup Time       70         55         ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 45  | TdCr (A)       | $\begin{array}{c} \overline{MREQ}\uparrow,\overline{IORQ}\uparrow,\overline{RD}\uparrow,\\ \text{and}\overline{WR}\uparrow\text{to}AddressHold\\ \overline{Time} \end{array}$ | 35   | _                 | -     | 20   | _                 | _     | ns    |
| 47       ThRESET (Cr)       RESET to Clock ↑ Hold Time       10       -       -       10       -       -       ns         48       TsINTf (Cr)       INT to Clock ↑ Setup Time       70       -       -       55       -       -       ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 46  | TsRESET (Cr)   | RESET to Clock ↑ Setup Time                                                                                                                                                   | 60   | -                 | -     | 45   | -                 | -     | ns    |
| 48 TsINTf (Cr) INT to Clock↑Setup Time 70 55 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 47  | ThRESET (Cr)   | RESET to Clock ↑ Hold Time                                                                                                                                                    | 10   | _                 |       | 10   | _                 | _     | ns    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 48  | TsINTf (Cr)    | INT to Clock ↑ Setup Time                                                                                                                                                     | 70   | -                 | -     | 55   |                   | -     | ns    |

|     |               |                                                                |      |                   |       |      |                   |       | (3/3) |
|-----|---------------|----------------------------------------------------------------|------|-------------------|-------|------|-------------------|-------|-------|
| NO. | SYMBOL        | PARAMETER                                                      | TMPZ | 284C01!<br>(6MHz) | 5AF-6 | TMPZ | 284C01!<br>(8MHz) | 5AF-8 | UNIT  |
|     |               |                                                                | MIN. | TYP.              | MAX.  | MIN. | TYP.              | MAX.  |       |
| 49  | TsINTr (Cr)   | INT to Clock ↑ Hold Time                                       | 10   | -                 |       | 10   | -                 | —     | ns    |
| 50  | TdM1f (IORQf) | $\overline{M1}\downarrow$ to $\overline{IORQ}\downarrow$ Delay | 365  | -                 | -     | 270  | -                 |       | ns    |
| 51  | TdCf (IORQf)  | Clock↓to IORQ↓Delay                                            | -    | -                 | 70    | -    | -                 | 60    | ns    |
| 52  | TdCr (IORQr)  | Clock ↑ to <del>IORQ</del> ↑ Delay                             | -    | -                 | 70    | Ι    |                   | 60    | ns    |
| 53  | TdCf (D)      | Clock↓to Data Valid Delay                                      | -    |                   | 130   |      | -                 | 115   | ns    |

# 4.3.2 AC Characteristics of CGC (in Active State)

| NO. | SYMBOL         | PARAMETER                                                        | TMP  | Z84C015<br>(6MHz)           | 5AF-6 | TMP2 | Z84C015<br>(8MHz)           | 5AF-8 | UNIT |
|-----|----------------|------------------------------------------------------------------|------|-----------------------------|-------|------|-----------------------------|-------|------|
|     |                |                                                                  | MIN. | TYP.                        | MAX.  | MIN. | TYP.                        | MAX.  |      |
| 54  | TcC CLK        | Output-Clock Cycle                                               | -    | 162                         | -     | -    | 125                         | -     | ns   |
| 55  | TwCh CLK       | Output-Clock Width(High)                                         | -    | 70                          | -     | 50   | -                           | -     | ns   |
| 56  | TwCl CLK       | Output-Clock Width(Low)                                          | -    | 70                          | -     | 50   | -                           | -     | ns   |
| 57  | TfC CLK        | Output Clock fall time                                           | -    | 12                          | -     |      | -                           | 12    | ns   |
| 58  | TrC CLK        | Output Clock rise time                                           | -    | 12                          | -     |      | -                           | 12    | ns   |
| 59  | TRST (INT) S   | CLKOUT restart time by<br>INT (STOP Mode)                        | _    | 2 <sup>14</sup> +<br>2.5TcC | —     | _    | 2 <sup>14</sup> +<br>2.5TcC | _     | ns   |
| 60  | TRST (NMI) S   | CLKOUT restart time by $\overline{\text{NMI}}$ (STOP Mode)       | -    | 2 <sup>14</sup> +<br>2.5TcC | —     | _    | 2 <sup>14</sup> +<br>2.5TcC | -     | ns   |
| 61  | TRST (INT) I   | CLKOUT restart time by<br>INT (IDLE 1 / 2 Mode)                  |      | 2.5<br>*TcC                 | —     |      | 2.5<br>*TcC                 | _     | ns   |
| 62  | TRST (NMI) I   | CLKOUT restart time by $\overline{\text{NMI}}$ (IDLE 1 / 2 Mode) | _    | 2.5<br>*TcC                 | —     | _    | 2.5<br>*TcC                 |       | ns   |
| 63  | TRST (RESET) I | CLKOUT restart time by<br>RESET<br>(IDLE 1 / 2 Mode)             | _    | TcC                         |       |      | TcC                         | _     | ns   |

# 4.3.3 AC Characteristics of CTC (in Active State)

| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | NO.  | SYMBOL         | PARAMETER                                                                                                  | TMP2                            | 284C01!<br>(6MHz) | 5AF-6 | TMP2                            | 284C01!<br>(8MHz) | 5AF-8 | UNIT |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------|------------------------------------------------------------------------------------------------------------|---------------------------------|-------------------|-------|---------------------------------|-------------------|-------|------|
| $ \begin{array}{cccccccccccccccccccccccccccccccccccc$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |                |                                                                                                            | MIN.                            | TYP.              | MAX.  | MIN.                            | TYP.              | MAX.  |      |
| 65       TdlEl (IEOf)       Delay from IEI fall to IEO fall $  70$ $  50$ ns         66       TdlEl (IEOr)       Delay from IEI rise to IEO rise (after ED decode) $   150$ $  120$ ns $67$ ISCLK (INT) $CLK / TRG setup to TL \uparrow for detection of interrupt sCTR (c) Satisfied       TCC + 100 + T68 + T48   TCC + 100 + T68 + T48                                                                 -       <$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 64   | TdM1 (IEO)     | Delay from M1 fall to IEO<br>fall (in case of generating<br>only interrupt immediately<br>before M1 cycle) |                                 |                   | 160   |                                 | _                 | 130   | ns   |
| 66       TdIEI (IEOr)       Delay from IEI rise to IEO rise (after ED decode)       -       -       150       -       -       120       ns         66       TdIEI (IEOr) $CLK / TRG setup to TL \uparrow for detection of interrupt tsCTR (c) Satisfied       TCC + 120 + 160 + 168 + 148       -       -       +       -       +       -       -       +       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -       -$                                                                                                                                                                                                                                                                                                                                                                     | 65   | TdIEI (IEOf)   | Delay from IEI fall to IEO fall                                                                            | -                               | 1                 | 70    | -                               | _                 | 50    | ns   |
| 67       IscLk (INT)       CLK / TRG setup to TL $\uparrow$ for detection of interrupt tsCTR (c) Satisfied       TCC $\uparrow$ 120 $\uparrow$ T68 $\uparrow$ TCC $\uparrow$ 100 $\uparrow$ TCC $\uparrow$ 100 $\uparrow$ TCC $\uparrow$ 100 $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TCC $\uparrow$ TC | 66   | TdIEI (IEOr)   | Delay from IEI rise to IEO<br>rise<br>(after ED decode)                                                    | _                               |                   | 150   |                                 | -                 | 120   | ns   |
| 07       ISELK (INT)       tsCTR (c) not Satisfied       2TCC<br>+ 120<br>+ T68<br>+ T48       -       -       2TCC<br>+ 100<br>+ T68<br>+ T48       -       -       -       Its         68       TcCTR       CLK / TRG Frequency<br>(counter mode)       2TcC       -       -       2TcC       -       -       ns         69       TrCTR       CLK / TRG rising time       -       -       40       -       -       30       ns         70       TfCTR       CLK / TRG falling time       -       -       40       -       -       30       ns         71       TwCTR1       CLK / TRG Pulse Width (Low)       120       -       -       90       -       -       ns         73       TsCTR (Cs)       CLK/TRG ↑ to Clock ↑<br>Setup Time for Immediate<br>count<br>(counter mode)       150       -       -       110       -       -       ns         74       TsCTR (CT)       CLK/TRG ↑ to Clock ↑<br>Setup Time for enabling of<br>Prescaler on following<br>clock ↑<br>(timer mode)       150       -       -       110       -       ns         75       TdC (ZC / TOr)       Clock ↑ to ZC/TO ↑ Delay       -       -       140       -       110       ns                                                                                                                                                                                                                                                                            | . 67 |                | CLK / TRG setup to TL↑ for<br>detection of interrupt<br>tsCTR (c) Satisfied                                | TcC<br>+ 120<br>+ T68<br>+ T48  | _                 | _     | TcC<br>+ 100<br>+ T68<br>+ T48  | _                 | -     | 25   |
| 68       TcCTR       CLK / TRG Frequency<br>(counter mode)       2TcC       -       -       2TcC       -       -       ns         69       TrCTR       CLK / TRG rising time       -       -       40       -       -       30       ns         70       TfCTR       CLK / TRG falling time       -       -       40       -       -       30       ns         71       TwCTR1       CLK / TRG Pulse Width (Low)       120       -       -       90       -       -       ns         72       TwCTRh       CLK / TRG Pulse Width (Low)       120       -       -       90       -       -       ns         73       TsCTR (Cs)       CLK / TRG $\uparrow$ to Clock $\uparrow$<br>Setup Time for Immediate<br>count<br>(counter mode)       150       -       -       110       -       -       ns         74       TsCTR (Cs)       CLK/TRG $\uparrow$ to Clock $\uparrow$<br>Setup Time for enabling of<br>prescaler on following<br>clock $\uparrow$<br>(timer mode)       150       -       110       -       -       ns         75       TdC (ZC / TOr)       Clock $\uparrow$ to ZC/TO $\uparrow$ Delay       -       -       140       -       -       110       ns         76       TdC (ZC / TOf)       Clock $\downarrow$ to ZC/TO $\downarrow$ Delay       -                                                                                                                                                                         |      |                | tsCTR (c) not Satisfied                                                                                    | 2TcC<br>+ 120<br>+ T68<br>+ T48 |                   |       | 2TcC<br>+ 100<br>+ T68<br>+ T48 | _                 |       | 115  |
| 69       TrCTR       CLK / TRG rising time       -       -       40       -       -       30       ns         70       TfCTR       CLK / TRG falling time       -       -       40       -       -       30       ns         71       TwCTR1       CLK / TRG Pulse Width (Low)       120       -       -       90       -       -       ns         72       TwCTRh       CLK / TRG Pulse Width (High)       120       -       -       90       -       -       ns         73       TsCTR (Cs)       CLK / TRG ↑ to Clock ↑<br>Setup Time for Immediate<br>count<br>(counter mode)       150       -       -       110       -       -       -       ns         74       TsCTR (Cs)       CLK/TRG ↑ to Clock ↑<br>Setup Time for enabling of<br>Prescaler on following<br>clock ↑<br>(timer mode)       150       -       -       110       -       -       ns         75       TdC (ZC / TOr)       Clock ↑ to ZC/TO ↑ Delay       -       -       140       -       -       110       ns         76       TdC (ZC / TOf)       Clock ↓ to ZC/TO ↓ Delay       -       -       140       -       -       110       ns                                                                                                                                                                                                                                                                                                                          | 68   | TcCTR          | CLK / TRG Frequency<br>(counter mode)                                                                      | 2TcC                            | _                 | _     | 2TcC                            | _                 | -     | ns   |
| 70TfCTRCLK / TRG falling time4030ns71TwCTR1CLK / TRG Pulse Width (Low)12090ns72TwCTRhCLK / TRG Pulse Width (High)12090ns73TsCTR (Cs) $CLK / TRG \cap to Clock \cap Setup Time for Immediate count (counter mode)150110ns74TsCTR (CT)CLK / TRG \cap to Clock \cap Setup Time for enabling of Prescaler on following clock \cap (timer mode)150110ns75TdC (ZC / TOr)Clock \ to ZC / TO \ Delay140110ns76TdC (ZC / TOf)Clock \ to ZC / TO \ Delay140110ns$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 69   | TrCTR          | CLK / TRG rising time                                                                                      | -                               | _                 | 40    | -                               | -                 | 30    | ns   |
| 71TwCTR1CLK / TRG Pulse Width (Low)12090ns72TwCTRhCLK / TRG Pulse Width (High)12090ns73TsCTR (Cs) $CLK / TRG \uparrow$ to Clock $\uparrow$<br>Setup Time for Immediate<br>count<br>(counter mode)150110ns74TsCTR (CT) $CLK / TRG \uparrow$ to Clock $\uparrow$<br>Setup Time for enabling of<br>Prescaler on following<br>clock $\uparrow$<br>(timer mode)150110ns75TdC (ZC / TOr)Clock $\uparrow$ to ZC / TO $\downarrow$ Delay140110ns76TdC (ZC / TOf)Clock $\downarrow$ to ZC / TO $\downarrow$ Delay140110ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 70   | TfCTR          | CLK / TRG falling time                                                                                     | -                               | -                 | 40    | -                               | -                 | 30    | ns   |
| 72TwCTRhCLK / TRG Pulse Width (High)120 $ -$ 90 $ -$ ns73TsCTR (Cs) $\begin{array}{c} CLK / TRG \uparrow to Clock \uparrow \\ Setup Time for Immediate \\ count \\ (counter mode) \end{array}$ 150 $ -$ 110 $ -$ ns74TsCTR (CT) $\begin{array}{c} CLK / TRG \uparrow to Clock \uparrow \\ Setup Time for enabling of \\ Prescaler on following \\ clock \uparrow \\ (timer mode) \end{array}$ 150 $ -$ 110 $ -$ ns75TdC (ZC / TOr)Clock ↑ to ZC / TO ↑ Delay $ -$ 190 $ -$ 110ns76TdC (ZC / TOf)Clock ↓ to ZC / TO ↓ Delay $ -$ 140 $ -$ 110ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 71   | TwCTR1         | CLK / TRG Pulse Width (Low)                                                                                | 120                             | -                 | -     | 90                              | _                 | -     | ns   |
| 73 $TsCTR$ (Cs) $CLK/TRG \uparrow to Clock \uparrow Setup Time for Immediate count (counter mode)150  110  ns74TsCTR (CT)CLK/TRG \uparrow to Clock \uparrow Setup Time for enabling of Prescaler on following clock \uparrow (timer mode)150  110  ns75TdC (ZC/TOr)Clock \uparrow to ZC/TO \uparrow Delay  190  110ns76TdC (ZC/TOf)Clock \downarrow to ZC/TO \downarrow Delay  140  110ns$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 72   | TwCTRh         | CLK / TRG Pulse Width (High)                                                                               | 120                             | _                 | -     | 90                              | _                 |       | ns   |
| 74 $T_{SCTR}$ (CT) $CLK/TRG \uparrow to Clock \uparrow \\Setup Time for enabling of Prescaler on following clock \uparrow \\(timer mode)150110ns75TdC (ZC / TOr)Clock \uparrow to ZC/TO \uparrow Delay190110ns76TdC (ZC / TOf)Clock \downarrow to ZC/TO \downarrow Delay140110ns$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 73   | TsCTR (Cs)     | CLK/TRG ↑ to Clock ↑<br>Setup Time for Immediate<br>count<br>(counter mode)                                | 150                             |                   | _     | 110                             |                   |       | ns   |
| 75       TdC (ZC / TOr)       Clock ↑ to ZC/TO ↑ Delay       -       -       190       -       -       110       ns         76       TdC (ZC / TOf)       Clock ↓ to ZC/TO ↓ Delay       -       -       140       -       -       110       ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 74   | TsCTR (CT)     | CLK/TRG ↑ to Clock ↑<br>Setup Time for enabling of<br>Prescaler on following<br>clock ↑<br>(timer mode)    | 150                             |                   | _     | 110                             | _                 | _     | ns   |
| 76 TdC (ZC / TO f) Clock ↓ to ZC/TO ↓ Delay 140 110 ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 75   | TdC (ZC / TOr) | Clock ↑ to ZC/TO ↑ Delay                                                                                   | -                               | -                 | 190   | _                               | _                 | 110   | ns   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 76   | TdC (ZC / TOf) | Clock ↓ to ZC/TO ↓ Delay                                                                                   | _                               | _                 | 140   | _                               |                   | 110   | ns   |

## 4.3.4 AC Characteristics of PIO (in Active State)

| NO. | SYMBOL       | PARAMETER                                                                                            | TMP2         | 284C01!<br>(6MHz) | 5AF-6 | TMPZ         | 284C01!<br>(8MHz) | 5AF-8 | UNIT |
|-----|--------------|------------------------------------------------------------------------------------------------------|--------------|-------------------|-------|--------------|-------------------|-------|------|
|     |              |                                                                                                      | MIN.         | TYP.              | MAX.  | MIN.         | TYP.              | MAX.  |      |
| 77  | TdM1 (IEO)   | Delay from $\overline{M1}$ fall to IEO fall                                                          | -            | -                 | 100   | —            |                   | 100   | ns   |
| 78  | TsIEI (IO)   | IEI Set-up time for IORQ fall<br>(INTA cycle)                                                        | 100          | —                 | -     | 80           | _                 |       | ns   |
| 79  | TdIEI (IEOf) | Delay from IEI fall to IEO fall                                                                      | —            | -                 | 70    | -            | —                 | 50    | ns   |
| 80  | TdIEI (IEOr) | Delay from IEI rise to IEO rise                                                                      | -            | -                 | 150   | -            | —                 | 120   | ns   |
| 81  | TdC (RDYr)   | Delay from clock fall to READY rise                                                                  | _            | _                 | 170   | _            | _                 | 150   | ns   |
| 82  | TdC (RDYf)   | Delay from clock fall to<br>READY fall                                                               | —            | _                 | 120   | —            | —                 | 110   | ns   |
| 83  | TwSTB (C)    | STROBE pulse width                                                                                   | 120          | -                 | -     | 100          | -                 |       | ns   |
| 84  | TsSTB (C)    | Set-up time of STROBE rise<br>for clock fall<br>(in case of making READY to<br>active by next cycle) | 150          |                   | _     | 100          | _                 | _     | ns   |
| 85  | TdIO (PD)    | Delay from IORQ rise to port<br>data stable<br>(Mode 0)                                              |              |                   | 160   | _            | <u>.</u>          | 140   | ns   |
| 86  | TsPD (STB)   | Port Data set-up time for<br><u>STROBE</u> rise<br>(Mode 1)                                          | 190          | _                 |       | 150          | _                 | -     | ns   |
| 87  | TdSTB (PD)   | Output Port data delay time<br>from STROBE fall<br>(Mode 2)                                          |              |                   | 180   |              |                   | 150   | ns   |
| 88  | TdSTB (PDr)  | Delay from STROBE rise to<br>data float<br>(Mode 2)                                                  | _            | _                 | 160   | _            | _                 | 120   | ns   |
| 89  | IsSTRB       | STROBE setup to TL↑ for detection of interrupt                                                       | 350<br>+ T48 | _                 | _     | 350<br>+ T48 | —                 |       | ns   |
| 90  | IsPD         | Port data stable setup to<br>TL↑for detection of inter-<br>rupt (Mode 3)                             | 430<br>+ T48 | _                 | _     | 350<br>+ T48 | -                 |       | ns   |
| 91  | ThPD (STB)   | Data Hold time for STROBE<br>rise<br>(Mode 1)                                                        | 40           |                   |       | 40           |                   |       | ns   |

# 4.3.5 AC Characteristics of SIO (in Active State)

|     |                 | · · · ·                                                                                     |      |                  |       |      |                  |       | (1/2)          |
|-----|-----------------|---------------------------------------------------------------------------------------------|------|------------------|-------|------|------------------|-------|----------------|
| NO. | SYMBOL          | PARAMETER                                                                                   | TMP  | Z84C01<br>(6MHz) | 5AF-6 | TMP2 | Z84C01<br>(8MHz) | 5AF-8 | UNIT           |
|     |                 |                                                                                             | MIN. | TYP.             | MAX.  | MIN. | TYP.             | MAX.  |                |
| 92  | TsM1 (C)        | M1 ↑ to clock ↑ Setup time                                                                  | 75   |                  |       | 50   | -                | -     | ns             |
| 93  | TsIEI (IO)      | IEI ↓ to IORQ ↓ Setup time<br>(INTACK cycle)                                                | 120  | —                | -     | 100  | _                | _     | ns             |
| 94  | TdM1 (IEO)      | $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before $\overline{M1}$ ) | _    | -                | 160   | _    | _                | 120   | ns             |
| 95  | TdIEI (IEOr)    | IEI ↑ to IEO ↑ Delay<br>(after ED decode)                                                   | -    |                  | 150   |      | _                | 120   | ns             |
| 96  | TdIEI (IEOf)    | IEI↓to IEO↓Delay                                                                            | -    | -                | 70    | -    | _                | 50    | ns             |
| 97  | TdIO (W/RWf)    | IORQ↓or Œ↓to<br>W/RDY↓Delay<br>(Wait mode)                                                  | _    |                  | 175   |      |                  | 130   | ns             |
| 98  | TdC (W/RRf)     | Clock ↑ to ₩/RDY<br>↓ delay<br>(Ready Mode)                                                 | _    |                  | 100   |      |                  | 80    | ns             |
| 99  | TdC (W/RWZ)     | Clock↓to ₩/RDY float<br>delay (Wait mode)                                                   | -    | _                | 110   |      | -                | 90    | ns             |
| 100 | TwPh            | Pulse Width (High)                                                                          | 200  | -                | -     | 200  | -                | _     | ns             |
| 101 | TwPI            | Pulse Width (Low)                                                                           | 200  | -                | -     | 200  | -                | -     | ns             |
| 102 | ТсТхС           | TxC cycle time                                                                              | 330  | -                | ∞     | 250  | -                | 8     | ns             |
| 103 | TwTxCl          | TxC Width (Low)                                                                             | 100  | -                | 00    | 80   |                  | ∞     | ns             |
| 104 | TwTxCh          | TxC Width (High)                                                                            | 100  | -                | ∞     | 80   | —                | ∞     | ns             |
| 105 | TdTxC (TxD)     | TxC↓to TxD delay<br>(x1 mode)                                                               | _    | ·                | 220   | —    |                  | 180   | ns             |
| 106 | TdTxC (W/RRf)   | TxC↓to W/RDY↓delay<br>(Ready mode)                                                          | 5    |                  | 9     | 5    | _                | 9     | CLK<br>Periods |
| 107 | TcRxC           | RxC cycle time                                                                              | 330  | -                | œ     | 250  | —                | ∞     | ns             |
| 108 | TwRxCl          | RxC Width (Low)                                                                             | 100  | -                | œ     | 80   | -                | ∞     | ns             |
| 109 | TwRxCh          | RxC Width (High)                                                                            | 100  | -                | ∞     | 80   | -                | ∞     | ns             |
| 110 | TsRxD (Rxc)     | RxD to RxC↑Setup<br>time (x1 mode)                                                          | 0    | _                |       | 10   | _                |       | ns             |
| 111 | ThRxD (Rxc)     | RxC↑to RxD hold time<br>(x1 mode)                                                           | 100  |                  | _     | 80   | _                | _     | ns             |
| 112 | TdRxC (W / RRf) | RxC↑toW/RDY<br>↓delay<br>(Ready mode)                                                       | 10   | _                | 13    | 10   | _                | 13    | CLK<br>Periods |

|     |              |                                                      |                          |      |                  |                             |      |                             | (2/2)          |
|-----|--------------|------------------------------------------------------|--------------------------|------|------------------|-----------------------------|------|-----------------------------|----------------|
| NO. | SYMBOL       | PARAMETER                                            | TMPZ84C015AF-6<br>(6MHz) |      |                  | TMPZ84C015AF-8<br>(8MHz)    |      |                             | UNIT           |
|     |              |                                                      | MIN.                     | TYP. | MAX.             | MIN.                        | TYP. | MAX.                        |                |
| 113 | TdRxC (SYNC) | RxC↑to SYNC↓delay<br>(Output mode)                   | 4                        | —    | 7                | 4                           | —    | 7                           | CLK<br>Periods |
| 114 | TsSYNC (Rxc) | <u>SYNC</u> ↓ to RxC↑ Setup<br>(External SYNC modes) | -100                     | —    | _                | -100                        | _    | _                           | ns             |
| 115 | IsTxc        | TxC ↓ Setup to TL↑ for<br>detection of interrupt     | 5*T1<br>+ T48            | _    | 9*T1<br>+ T48    | 5*T1<br>+ T48               | -    | 9*T1<br>+ T48               | ns             |
| 116 | lsRxc        | RxC ↑ Setup to TL↑for<br>detection of interrupt      | 10 * T1<br>+ T48         | _    | 13 * T1<br>+ T48 | 10 <sub>*</sub> T1<br>+ T48 | —    | 13 <sub>*</sub> T1<br>+ T48 | ns             |

# 4.3.6 AC Characteristic of WDT (in Active State)

| NO. | SYMBOL     | PARAMETER                                                                     | TMPZ84C015AF-6<br>(6MHz) |                                      |      | TMPZ84C015AF-8<br>(8MHz) |                                      |      | UNIT                 |
|-----|------------|-------------------------------------------------------------------------------|--------------------------|--------------------------------------|------|--------------------------|--------------------------------------|------|----------------------|
|     |            |                                                                               | MIN.                     | TYP.                                 | MAX. | MIN.                     | TYP.                                 | MAX. |                      |
| 117 | Tdc (WDTf) | Clock ↑ to WDTOUT ↓ Delay                                                     | -                        | -                                    | 160  | -                        | -                                    | 120  | ns                   |
| 118 | Tdc (WDTr) | Clock ↑ to WDTOUT ↑ Delay                                                     | —                        | -                                    | 165  | -                        | -                                    | 125  | ns                   |
| 119 | TcWDT      | WDTOUT Out put period<br>WDT Mode 0<br>WDT Mode 1<br>WDT Mode 2<br>WDT Mode 3 |                          | T1*216<br>T1*218<br>T1*220<br>T1*222 |      |                          | T1*216<br>T1*218<br>T1*220<br>T1*222 |      | ns<br>ns<br>ns<br>ns |

030489

Note 1: Timing Measurements are made at the following voltage. Input VIH=2.4V, VIL=0.4V, VIHC=VCC-0.6V, VILC=0.6V Output VOH=2.2V, VOL=0.8V (Exept CLKOUT) CL=100pF

## TOSHIBA

## 4.4 AC TIMING CHARTS (1) (in Active State)

### 4.4.1 AC Timing Charts of MPU (in Active State)

Figures 4.4.1 through 4.4.8 show the basic timing charts. The circled numbers in these charts correspond to the numbers in the number column of the AC Electrical Characteristics Tables.



Figure 4.4.1 Opcode Fetch Cycle







Note 1: wait state (TW\*) is inserted automatically by MPU.

300389

Figure 4.4.3 I/O Cycle

MPUZ80-723



Notes 1. TL : Last state of instruction 2. 2 - wait state (TW\*) is inserted automatically by MPU

300389

## Figure 4.4.4 Interrupt Request/Acknowledge Cycle















Figure 4.4.7 HALT Acknowledge Cycle



Figure 4.4.8 Reset Cycle

## 4.4.2 AC Timing Charts of CGC (in Active State)

The following Figures show the timings in each operation mode with the CLKOUT pin connected to the CLKIN pin.







Figure 4.4.13 Timing of Clock Start by RESET (IDLE1 and IDLE2 Modes)



# 4.4.3 AC Timing Charts of CTC (in Active State)





## Figure 4.4.15 CTC Interrupt Occurrence Timing

## 4.4.4 AC Timing Charts of PIO (in Active State)



300389





Figure 4.4.17 PIO Interrupt Occurrence Timing





Figure 4.4.18 (a) SIO Timing Diagram



Figure 4.4.18 (b) SIO Timing Diagram



Figure 4.4.19 SIO Interrupt Occurrence Timing

4.4.6 AC Timing Charts of WDT (in Active State)



Figure 4.4.20 WDT Timing Diagram

# 4.5 AC ELECTRICAL CHARACTERISTICS (2) (in Inactive State)

6MHz VERSION : TA =  $-40^{\circ}$ C~ + 85°C, VCC = 5V + 10%, VSS = 0V

# 4.5.1 AC Characteristics of CGC (in Inactive State)

| NO. | SYMBOL         | PARAMETER                                                            | TMP2 | UNIT                        |      |        |
|-----|----------------|----------------------------------------------------------------------|------|-----------------------------|------|--------|
|     |                |                                                                      |      | TYP.                        | MAX. |        |
| 1   | TcCCLK         | Output Clock Cycle                                                   | -    | 162                         | -    | ns     |
| 2   | TwChCLK        | Output Clock Width (High)                                            |      | 70                          | -    | ns     |
| 3   | TwClCLK        | Output Clock Width (Low)                                             | -    | 70                          | -    | ns     |
| 4   | TfCCLK         | Output Clock fall Time                                               | _    | 12                          | -    | ns     |
| 5   | TrCCLK         | Output Clock rise Time                                               |      | 12                          |      | ns     |
| 6   | TRST (INT) S   | Clock (CLKOUT) restart Time by INT<br>(STOP mode)                    |      | 2 <sup>14</sup> +<br>2.5TcC | _    | ns     |
| 7   | TRST (NMI) S   | Clock (CLKOUT) restart Time by $\overline{\rm NMI}$ (STOP mode)      |      | 2 <sup>14</sup> +<br>2.5TcC | _    | ns     |
| 8   | TRST (INT) I   | Clock (CLKOUT) restart Time by INT<br>(IDLE 1 / 2 mode)              |      | 2.5<br>*TcC                 | _    | ns     |
| 9   | TRST (NMI) I   | Clock (CLKOUT) restart Time by $\overline{NMI}$<br>(IDLE 1 / 2 mode) | —    | 2.5<br>*TcC                 | -    | ns     |
| 10  | TRST (RESET) I | Clock (CLKOUT) restart Time by RESET<br>(IDLE 1 / 2 mode)            | —    | 1TcC                        | -    | ns     |
| 11  | TsHALT (M1r)   | HALT Set up Time                                                     | 10   | -                           | 1    | ns     |
|     |                |                                                                      |      |                             |      | 300389 |

# 4.5.2 AC Characteristics of CTC (in Inactive State)

|     |          |                                    |      |      |      | (1/2) |
|-----|----------|------------------------------------|------|------|------|-------|
| NO. | SYMBOL   | PARAMETER                          | TMP2 | UNIT |      |       |
|     |          |                                    |      | TYP. | MAX. |       |
| 12  | TcC      | ClocK Cycle Time                   | 162  | -    | -    | ns    |
| 13  | Twch     | ClocK width (High)                 | 65   | -    | —    | ns    |
| 14  | Twcl     | ClocK width (Low)                  | 65   | _    | -    | ns    |
| 15  | TfC      | ClocK falling time                 | -    |      | 20   | ns    |
| 16  | TrC      | ClocK rising time                  | -    | -    | 20   | ns    |
| 17  | Th       | Hold Time                          | 10   | -    | -    | ns    |
| 18  | TcCS (C) | CS (A1, A0) Set up time to clock ↑ | 100  | —    | -    | ns    |
| 19  | TSCE (C) | CE (A7~A2) Set up time to clock ↑  | 150  | —    |      | ns    |
| 20  | TsIO (C) | IORQ ↓ Set up time to clock ↑      | 70   | -    | -    | ns    |

300389

## MPUZ80-733
|                |                |                                                                                                                                            |       |                                        |              | (2/2) |
|----------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------|-------|----------------------------------------|--------------|-------|
| NO. SYMBOL     |                | PARAMETER                                                                                                                                  | TMP2  | UNIT                                   |              |       |
|                |                |                                                                                                                                            | MIN.  | TYP.                                   | MAX.         |       |
| 21             | TsRD (C)       | $\overline{RD}\downarrowSet$ up time to clock $\uparrow$                                                                                   | 70    | -                                      | -            | ns    |
| 22             | TdC (DO)       | Clock↑ to Data Valid Delay                                                                                                                 | -     | -                                      | 130          | ns    |
| 23             | TdC (DOz)      | IORQ, RD↑ to Data Float Delay                                                                                                              | -     | -                                      | 90           | ns    |
| 24             | TdCr (M1f)     | Data Input Set up time to clock ↑                                                                                                          | 40    | -                                      | -            | ns    |
| 25             | TsM1 (C)       | M1 Set up time to clock ↑                                                                                                                  | 70    |                                        | -            | ns    |
| 26             | TdM1 (IEO)     | $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(in case of generating only interrupt<br>immediately before $\overline{M1}$ cycle) | _     |                                        | 130          | ns    |
| 27             | TdIO (DOI)     | $\overline{\text{IORQ}}\downarrow$ to Data out Delay (INTA Cycle)                                                                          | -     | -                                      | 110          | ns    |
| 28             | TdIEI (IEOf)   | IEI↓to IEO↓ Delay                                                                                                                          | -     | <u> </u>                               | 70           | ns    |
| 29             | TdIEI (IEOf)   | IEI↑to IEO↑Delay (after ED decode)                                                                                                         | -     | -                                      | 150          | ns    |
| 30             | TdC (INT)      | Clock ↑ to INT ↓ Delay                                                                                                                     | _     | -                                      | TcC<br>+ 120 | ns    |
| 31 TdA (IORQf) |                | CLK / TRG ↑ to INT ↓ Delay<br>TsCTR (c) Satisfied                                                                                          | _     | TcC<br>+ 120<br>+ T37<br>2TcC<br>+ 120 |              | ns    |
|                |                |                                                                                                                                            | + T37 |                                        |              |       |
| 32             | TcCTR          | CLK / TRG Frequency                                                                                                                        |       | 2TcC                                   |              | ns    |
| 33             | TrCTR          | CLK / TRG rising time                                                                                                                      |       | _                                      | 40           | ns    |
| 34             | TfCTR          | CLK / TRG falling time                                                                                                                     | -     |                                        | 40           | ns    |
| 35             | TwCTRI         | CLK / TRG pulse width (Low)                                                                                                                | 120   | _                                      | -            | ns    |
| 36             | TwCTRh         | CLK / TRG pulse width (High)                                                                                                               | 120   |                                        | -            | ns    |
| 37             | TsCTR (CS)     | CLK/TKG↑ to clock ↑ Setup<br>Time for Immediate Count<br>(counter mode)                                                                    | 150   |                                        | _            | ns    |
| 38             | TsCTR (CT)     | CLK/TRG $\uparrow$ to clock $\uparrow$ Setup<br>Time for enabliling of Prescaler on<br>following clock $\uparrow$<br>(timer mode)          | 150   | _                                      | _            | ns    |
| 39             | TdC (ZC / TOr) | Clock ↑ to ZC/TO ↑ Delay                                                                                                                   | -     |                                        | 140          | ns    |
| 40             | TdC (ZC / TOf) | Clock↓to ZC/TO↓ Delay                                                                                                                      | -     | -                                      | 140          | ns    |

# 4.5.3 AC Characteristics of PIO (in Inactive State)

| NO. SYMBOL |              | PARAMETER                                                                                                                           |     | TMPZ84C015<br>(6MHz) |      | UNIT   |  |
|------------|--------------|-------------------------------------------------------------------------------------------------------------------------------------|-----|----------------------|------|--------|--|
|            |              | 1                                                                                                                                   |     | TYP.                 | MAX. |        |  |
| 41         | TsCS (RI)    | $\overline{CE}(A_7 \text{ to } A_2), B/\overline{A}(A_1), C/\overline{D}(A_0)$ Set up Time to $\overline{RD}, \overline{IORQ}$      | 50  | —                    | -    | ns     |  |
| 42         | Th           | Hold Time                                                                                                                           | 40  |                      |      | ns     |  |
| 43         | TsRI (C)     | RD, IORQ Set up time to clock ↑                                                                                                     | 70  | -                    |      | ns     |  |
| 44         | TdRI (DO)    | $\overline{\text{RD}}, \overline{\text{IORQ}} \downarrow$ to Data out Delay                                                         | -   | -                    | 300  | ns     |  |
| 45         | TdRI (DOs)   | $\overline{\text{RD}}, \overline{\text{IORQ}} \uparrow \text{to Data float Delay}$                                                  | -   |                      | 70   | ns     |  |
| 46         | TsDI (C)     | Data Set up time to clock ↑                                                                                                         | 40  | -                    | -    | ns     |  |
| 47         | TdIO (DOI)   | $\overline{IORQ}\downarrow$ to Data out Delay (INTA Cycle)                                                                          | -   | -                    | 120  | ns     |  |
| 48         | TsM1 (Cr)    | M1↓ Set up time to clock↑                                                                                                           | 70  | -                    | -    | ns     |  |
| 49         | TsM1 (Cf)    | M1↑ Set up time to clock↓ (M1 cycle)                                                                                                | 0   | -                    | -    | ns     |  |
| 50         | TdM1 (IEO)   | $\overline{\text{M1}} \downarrow$ to IEO $\downarrow$ Delay<br>(Interrupt Immedi-ately receding $\overline{\text{M1}} \downarrow$ ) |     | -                    | 100  | ns     |  |
| 51         | TsIEI (IO)   | IEI Set up time to IORQ ↓ (INTA Cycle)                                                                                              | 100 | _                    | -    | ns     |  |
| 52         | TdIEI (IEOf) | IEI↓ to IEO↓ Delay                                                                                                                  | -   | _                    | 70   | ns     |  |
| 53         | TdIEI (IE0r) | El↑ to IEO↑ Delay (after ED Decade)                                                                                                 |     | —                    | 150  | ns     |  |
| 54         | TdIO (C)     | IORQ ↑ Set up time to Clock ↓                                                                                                       | 170 | -                    | -    | ns     |  |
| 55         | TdC (RDYr)   | Clock↓ to READY↑ Delay                                                                                                              | -   | -                    | 170  | ns     |  |
| 56         | TdC (RDYf)   | Clock↓to READY↓ Delay                                                                                                               | -   | -                    | 120  | ns     |  |
| 57         | TwSTB (C)    | STROBE Pulse width                                                                                                                  | 120 | -                    | -    | ns     |  |
| 58         | TsSTB (C)    | Set up time of STROBE rise for clock fall<br>(in case of making READY to active by<br>next cycle)                                   | 150 | _                    | _    | ns     |  |
| 59         | TdIO (PD)    | Delay from IORQ rise to Port data stable<br>(Mode 0)                                                                                |     |                      | 160  | ns     |  |
| 60         | TsPD (STB)   | Port data set up time for STROBE rise<br>(Mode 1)                                                                                   | 190 | _                    |      | ns     |  |
| 61         | TdSTB (PD)   | Output Port data delay time from<br>STROBE fall (Mode 2)                                                                            |     | —                    | 180  | ns     |  |
| 62         | TdSTB (PDr)  | Delay from STROBE rise to Port data<br>float (Mode 2)                                                                               | —   | _                    | 160  | ns     |  |
| 63         | TdPD (INT)   | Delay from port data match to INT fall<br>(Mode 3)                                                                                  | _   | _                    | 430  | ns     |  |
| 64         | TdSTB (INT)  | Delay from STROBE rise to INT fall                                                                                                  |     | -                    | 350  | ns     |  |
|            |              |                                                                                                                                     |     |                      |      | 300389 |  |

MPUZ80-735

# 4.5.4 AC Characteristics of SIO (in Inactive State)

| NO.SYMBOLPARAMETERINIP 28405554MAXFIGSYMBOLCE (A7 to A2), C/D (A0), group into to clock 1GoTWMAX65TSCS (C)CE (A7 to A2), C/D (A0), group into to clock 1GoTwGoTwSrs66TSRD (C)IORQ, RD Set up time to clock 1GoTwTwMax67TdC (DO)Clock 1 to Data output DelayTwTw150Srs68TSDI (C)Data input set up time to clock 130TwTwSrs69TdRD (DO2)Data input set up time to clock 1SrsTwTwSrs70TdIO (DO1)CIRQ 1 to Data out put DelayTwTwTwTs71TSM1(C)MT set up time to Clock 1ICUTwTwTsTs72TsIEI (OD)CIRQ 1 to Data out put DelayTwTwTwTsTs73TdM1 (IEO)MT set up time to Clock 1ICUTwTwTsTs74TdIEI (ECO)IEI 1 to IEO 1 Delay (INTACK Cycle)TwTsTsTs75TdIEI (IEO 1Clock 1 to TTy Delay (INTACK Cycle)TwTsTsTs76TdC (NTMClock 1 to TTy Delay (INTACK Cycle)TwTsTsTs77TdIO (IEC 1)Clock 1 to TTy Delay (INTACK Cycle)TwTsTsTs78TdC (NTAClock 1 to TTy Delay (INTACK Cycle)TwTsTsTs79TdIE (IECO)Clo                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |            |                 |                                                                                             |      |                   |            | (1/2)          |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|-----------------|---------------------------------------------------------------------------------------------|------|-------------------|------------|----------------|
| Image: birth or state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in the state in th | NO. SYMBOL |                 | PARAMETER                                                                                   |      | 284C01!<br>(6MHz) | 5AF-6      | UNIT           |
| 65    TsCS (C) $CE (A7 to A2), C / D (A0), B / A (A1) Set up time to clock \uparrow    60     ns      66    TsRD (C)    IORQ, RD Set up Time to clock \uparrow    60     ns      67    TdC (DO)    Clock \uparrow to Data output Delay      ns      68    TsDI (C)    Data input set up time to clock \uparrow    30     90    ns      69    TdRD (DO2)    RD \uparrow to Data out Float Delay      ns      70    TdIO (DO1)    IORQ \downarrow to Data out put Delay (INTACK Cycle)    120     ns      71    TsM1 (C)    MT set up time to clock \uparrow    75      ns      72    TsIEI (IO)    IEI set up time to IORQ \downarrow (INTACK Cycle)    120     ns      73    TdM1 (IEO)    MT \downarrow to IEO \downarrow Delay (INTACK Cycle)    120     ns      74    TdIEI (IEO7)    IEI \uparrow to IEO \downarrow Delay (After ED Decode)      ns      75    TdIEI (IEO7)    IEI \uparrow to IEO \downarrow Delay (After ED Decode)      150    ns      76    TdC (NTN)    Clock \uparrow to $                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |            |                 |                                                                                             | MIN. | TYP.              | MAX.       |                |
| 66TSRD (C)IORQ, RD Set up Time to clock $\uparrow$ 60ns67TdC (DO)Clock $\uparrow$ to Data output Delay150ns68TsDI (C)Data input set up time to clock $\uparrow$<br>(write cycle or MT cycle)3090ns69TdRD (DO2)RD $\uparrow$ to Data out Float Delay90ns70TdIO (DO1)IORQ $\downarrow$ to Data out put Delay<br>(INTACK cycle)120ns71TsM1 (C)MT set up time to clock $\uparrow$ 75ns72TsIEI (IO)IEI set up time to TORQ $\downarrow$ (INTACK Cycle)120160ns73TdM1 (IEO)MT $\downarrow$ to IEO $\downarrow$ Delay<br>(interrup before MT)150ns74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)150ns75TdIEI (IEOr)IEI $\uparrow$ to IEO $\downarrow$ Delay<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 65         | TsCS (C)        | CE (A7 to A2) , C / D̄ (A0) ,<br>B / Ā (A1) Set up time to clock ↑                          | 60   | —                 | -          | ns             |
| 67TdC (DO)Clock $\uparrow$ to Data output Delay150ns68TsDI (C)Data input set up time to clock $\uparrow$<br>(write cycle or MT cycle)3090ns69TdRD (DO2)RD $\uparrow$ to Data Out Float Delay90ns70TdIO (DO1)IORQ $\downarrow$ to Data out put Delay<br>(INTACK cycle)90ns71TsM1 (C)MT set up time to clock $\uparrow$ 75ns72TsIEI (IO)IEI Set up time to IORQ $\downarrow$ (INTACK Cycle)120ns73TdM1 (IEO)MT $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before MT)150ns74TdIEI (IEOr)IEI $\uparrow$ to IEO $\downarrow$ Delay<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 66         | TsRD (C)        | IORQ, RD Set up Time to clock ↑                                                             | 60   | -                 | -          | ns             |
| 68TsDi (C)Data input set up time to clock $\uparrow$<br>(write cycle or M1 cycle)30 $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ $$ </td <td>67</td> <td>TdC (DO)</td> <td>Clock ↑ to Data output Delay</td> <td>-</td> <td>—</td> <td>150</td> <td>ns</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 67         | TdC (DO)        | Clock ↑ to Data output Delay                                                                | -    | —                 | 150        | ns             |
| 69      TdRD (DO2)      RD ↑ to Data Out Float Delay        90      ns        70      TdIO (DOI)      IORQ ↓ to Data out put Delay<br>(INTACK cycle)       120      ns        71      TsM1 (C)      MT Set up time to clock ↑      75        ns        72      TsIEI (IO)      IEI set up time to clock ↑      120        ns        73      TdM1 (IEO)      MT ↓ to IEO ↓ Delay<br>(interrupt before MT)       160      ns        74      TdIEI (IEOr)      IEI ↑ to IEO ↑ Delay (After ED Decode)        150      ns        75      TdIEI (IEOr)      IEI ↑ to IEO ↓ Delay        150      ns        76      TdC (NT)      Clock ↑ to INT ↓ Delay        150      ns        77      TdIO (W / RWf)      IORO, CE (A7 to A2) ↓ to<br>W/RDY ↓ Delay (Ready Mode)        100      ns        78      TdC (W / RWz)      Clock ↑ to W/RDY ↓ Delay (Ready Mode)        ns        79      TdC (W / RWz)      Clock ↓ to W/RDY ↓ Delay (Ready Mode)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 68         | TsDI (C)        | Data input set up time to clock ↑<br>(write cycle or M1 cycle)                              | 30   | -                 | <b>—</b> . | ns             |
| 70TdIO (DOI) $\begin{bmatrix} IORO \downarrow to Data out put Delay (INTACK cycle)120ns71TsM1 (C)Mī Set up time to clock \uparrow75ns72TsIEI (IO)IEI Set up time to IORQ \downarrow (INTACK Cycle)120ns73TdM1 (IEO)Mī \downarrow to IEO \downarrow Delay (INTACK Cycle)120150ns74TdIEI (IEO)IEI \uparrow to IEO \downarrow Delay (After ED Decode)150ns75TdIEI (IEO)IEI \uparrow to IEO \uparrow Delay (After ED Decode)150ns76TdC (INT)Clock \uparrow to INT \downarrow Delay150ns77TdIO (W / RWf)\begin{bmatrix} IORO, CE (A7 to A2) \downarrow to W/RDY \downarrow Delay (Ready Mode)100ns78TdC (W / RRf)Clock \uparrow to W/RDY \downarrow Delay (Ready Mode)100ns79TdC (W / RWf)\begin{bmatrix} Clock \downarrow to W/RDY \downarrow Delay (Ready Mode)100ns80Th, Th (CS)Any unspecified hold When set up is specified0ns81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC cycle time330ns84TwPhTxC width (Low)100ns85TwTxChTxC width (High)100ns86TdTxC ($                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 69         | TdRD (DOz)      | RD ↑ to Data Out Float Delay                                                                | _    | —                 | 90         | ns             |
| 71    TsM1 (C)    MT Set up time to clock $\uparrow$ 75     ns      72    TsIEI (IO)    IEI Set up time to IORQ $\downarrow$ (INTACK Cycle)    120     ns      73    TdM1 (IEO)    MT $\downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)     160    ns      74    TdIEI (IEOr)    IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)     7    150    ns      75    TdIEI (IEOr)    IEI $\downarrow$ to IEO $\downarrow$ Delay (After ED Decode)      7    150    ns      76    TdC (INT)    Clock $\uparrow$ to INT $\downarrow$ Delay (Matter DDecode)      17    150    ns      77    TdIEI (IEOr)    IEI $\downarrow$ to IEO $\downarrow$ Delay (Wait Mode)      17    ns      78    TdC (NT)    Clock $\uparrow$ to WRDY $\downarrow$ Delay (Ready Mode)     170    ns      78    TdC (W / RW1)    Clock $\uparrow$ to WRDY $\downarrow$ Delay (Ready Mode)     110    ns      79    TdC (W / RW2)    Clock $\downarrow$ to WRDY $\downarrow$ Delay (Ready Mode)     110    ns      80    Th, Th (CS)    Apprentited High)    200                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 70         | TdIO (DOI)      | IORQ ↓ to Data out put Delay<br>(INTAČK cycle)                                              |      | <u> </u>          | 120        | ns             |
| 72    TsIEI (IO)    IEI Setu pt time to IORQ $\downarrow$ (INTACK Cycle)    120     ns      73    TdM1 (IEO) $M1 \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)     160    ns      74    TdIEI (IEOr)    IEI $\downarrow$ to IEO $\downarrow$ Delay (After ED Decode)      150    ns      75    TdIEI (IEOr)    IEI $\downarrow$ to IEO $\downarrow$ Delay (After ED Decode)      70    ns      76    TdC (INT)    Clock $\uparrow$ to INT $\downarrow$ Delay      150    ns      77    TdIO (W / RWf)    IORQ, CE (A7 to A2) $\downarrow$ to<br>W/RDY $\downarrow$ Delay (Wait Mode)      100    ns      78    TdC (W / RWf)    Clock $\uparrow$ to W/RDY $\downarrow$ Delay (Ready Mode)      100    ns      79    TdC (W / RWf)    Clock $\downarrow$ to W/RDY $\downarrow$ Delay (Ready Mode)      110    ns      80    Th, Th (CS)    Any unspecified hold When set up is<br>specified    0      ns      81    TWPh    Pulse width (Low)    200      ns      83    TcTxC    TxC (y clo time    330     0    ns <td>71</td> <td>TsM1 (C)</td> <td>M1 Set up time to clock ↑</td> <td>75</td> <td></td> <td></td> <td>ns</td>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 71         | TsM1 (C)        | M1 Set up time to clock ↑                                                                   | 75   |                   |            | ns             |
| 73TdM1 (IEO) $\overline{MT} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before M1)160ns74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)150ns75TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay (After ED Decode)150ns76TdC (INT)Clock $\uparrow$ to INT $\downarrow$ Delay150ns77TdIO (W / RWf) $\overline{IORQ, CE (A7 to A2) \downarrow to}$<br>$W/RDY \downarrow Delay (Wait Mode)100ns78TdC (W / RRf)Clock \uparrow to \overline{W/RDY} \downarrow Delay (Ready Mode)100ns79TdC (W / RWz)Clock \uparrow to \overline{W/RDY} I Delay (Ready Mode)110ns80Th, Th (CS)Any unspecified hold When set up isspecified0ns81TwPhPulse width (High)200ns82TwPIPulse width (Low)200ns83TcTxCTxC Cycle time330\inftyns84TwTxChTxC width (Low)100220ns85TdTxC (TxD)TxC \downarrow to \overline{W/RDY} \downarrow Delay (Ready mode)59CLKPeriods88TdTxC (INT)TxC \downarrow to \overline{W/RDY} \downarrow Delay (Ready mode)559CLKPeriods88TdTxC (INT)TxC \downarrow to \overline{W/RDY} \downarrow Delay (Ready mode)559CLKPeriods89TcRxCRxC Cycle tim$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 72         | TsIEI (IO)      | $\overline{IEI}$ Set up time to $\overline{IORQ}\downarrow$ (INTACK Cycle)                  | 120  |                   | -          | ns             |
| 74TdIEI (IEOr)IEI $\uparrow$ to IEO $\uparrow$ Delay (After ED Decode)150ns75TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay70ns76TdC (INT)Clock $\uparrow$ to INT $\downarrow$ Delay150ns77TdIO (W / RWf) $\boxed{IORQ, CE}(A7 to A2) \downarrow$ to<br>$\boxedW/RDY \downarrow Delay (Wait Mode)100ns78TdC (W / RRf)Clock \uparrow to W/RDY \downarrow Delay (Ready Mode)100ns79TdC (W / RRf)Clock \downarrow to W/RDY \downarrow Delay (Ready Mode)100ns80Th, Th (CS)Any unspecified hold When set up isspecified0ns81TwPhPulse width (High)200ns82TwPIPulse width (Low)200ns83TcTxCTxC Cycle time3300ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (High)100220ns86TdTxC (TxD)TxC \downarrow to TxD Delay (Ready mode)59CLKPeriods87TdTxC (W / RRf)TxC \downarrow to TxD Delay (Ready mode)59CLKPeriods88TdTxC (INT)TxC \downarrow to TxD Delay (Ready mode)59CLKPeriods89TcRxCRxC \lor RxC \lor RxC Cycle time3300ns$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 73         | TdM1 (IEO)      | $\overline{M1} \downarrow$ to IEO $\downarrow$ Delay<br>(interrupt before $\overline{M1}$ ) | -    | _                 | 160        | ns             |
| 75TdIEI (IEOf)IEI $\downarrow$ to IEO $\downarrow$ Delay $  7$ $7$ $7$ $7$ $7$ $7$ $7$ $7$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$ $1$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 74         | TdIEI (IEOr)    | IEI ↑ to IEO ↑ Delay (After ED Decode)                                                      | -    | —                 | 150        | ns             |
| 76TdC (INT)Clock $\uparrow$ to INT $\downarrow$ Delay150ns77TdlO (W / RWf) $\overrightarrow{IORQ}, \overrightarrow{CE}$ (A7 to A2) $\downarrow$ to<br>W/RDY $\downarrow$ Delay (Wait Mode)175ns78TdC (W / RRf)Clock $\uparrow$ to W/RDY $\downarrow$ Delay (Ready Mode)100ns79TdC (W / RWz)Clock $\uparrow$ to W/RDY $\downarrow$ Delay (Ready Mode)110ns80Th, Th (CS)Any unspecified hold When set up is<br>specified0ns81TwPhPulse width (High)200ns82TwPIPulse width (Low)200ns83TcTxCTxC Cycle time330ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (High)1000ns86TdTxC (TxD)TxC \to TxD Delay (x1 Mode)120ns87TdTxC (W / RRf)TxC $\downarrow$ to TxD Delay (Ready mode)59CLK<br>Periods88TdTxC (INT)TxC $\downarrow$ to TxT $\downarrow$ DelayS300ns89TcRxCRxC (INT)RxC ycle time3300ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 75         | TdIEI (IEOf)    | IEI↓to IEO↓Delay                                                                            | -    | -                 | 70         | ns             |
| 77TdIO (W / RWf) $\overline{IORQ}, \overline{CE} (A7 to A2) \downarrow to W/RDY \downarrow Delay (Wait Mode)$ 175ns78TdC (W / RRf)Clock ↑ to W/RDY ↓ Delay (Ready Mode)100ns79TdC (W / RWz) $Clock ↓ to W/RDY ↓ Delay (Ready Mode)$ 110ns80Th, Th (CS)Any unspecified hold When set up is specified0ns81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC Cycle time3300ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (High)1000ns86TdTxC (X/ RM)TxC \to TxD Delay (x1 Mode)100ns87TdTxC (W / RRf)TxC \to W/RDY \to Delay (Ready mode)59CLK Periods88TdTxC (INT)TxC \to TxT \to Delay3300ns89TcRxCRxC Cycle time3300ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 76         | TdC (INT)       | Clock ↑ to INT ↓ Delay                                                                      | -    | -                 | 150        | ns             |
| 78TdC (W / RRf)Clock $\uparrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready Mode)100ns79TdC (W / RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)110ns80Th, Th (CS)Any unspecified hold When set up is<br>specified0ns81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC Cycle time3300ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (High)1000ns86TdTxC (TxD)TxC \ot ot TxD Delay (x1 Mode)10087TdTxC (W / RRf)TxC \ot ot                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 77         | TdIO (W / RWf)  | IORQ, CE (A7 to A2) ↓ to<br>W/RDY ↓ Delay (Wait Mode)                                       | _    | _                 | 175        | ns             |
| 79TdC (W / RWz)Clock $\downarrow$ to $\overline{W/RDY}$ Float Delay<br>(Wait Mode)110ns80Th, Th (CS)Any unspecified hold When set up is<br>specified0ns81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC cycle time3300ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (High)1000ns86TdTxC (TxD)TxC $\downarrow$ to TxD Delay (x1 Mode)220ns87TdTxC (W / RRf)TxC $\downarrow$ to $\overline{W/RDY} \downarrow$ Delay (Ready mode)59CLK<br>Periods88TdTxC (INT)TxC $\downarrow$ to $\overline{INT} \downarrow$ Delay3300ns89TcRxCRxC Cycle time3300ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 78         | TdC (W / RRf)   | $Clock \uparrow to \overline{W/RDY} \downarrow  Delay  (Ready  Mode)$                       | -    | -                 | 100        | ns             |
| 80Th, Th (CS)Any unspecified hold When set up is<br>specified0ns81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC Cycle time3300ns84TwTxClTxC width (Low)1000ns85TwTxChTxC width (Low)1000ns86TdTxC (TxD)TxC width (High)1000ns87TdTxC (TxD)TxC \to TxD Delay (x1 Mode)220ns88TdTxC (W/RRf)TxC \to W/RDY \to Delay (Ready mode)59CLK<br>Periods89TcRxCRxC Cycle time3300ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 79         | TdC (W / RWz)   | Clock ↓ to W/RDY Float Delay<br>(Wait Mode)                                                 | _    | -                 | 110        | ns             |
| 81TwPhPulse width (High)200ns82TwPlPulse width (Low)200ns83TcTxCTxC Cycle time330 $\infty$ ns84TwTxClTxC width (Low)100 $\infty$ ns85TwTxChTxC width (High)100 $\infty$ ns86TdTxC (TxD)TxC $\downarrow$ to TxD Delay (x1 Mode)220ns87TdTxC (W / RRf)TxC $\downarrow$ to W/RDY $\downarrow$ Delay (Ready mode)59CLK<br>Periods88TdTxC (INT)TxC $\downarrow$ to INT $\downarrow$ Delay330 $\infty$ ns89TcRxCRxC Cycle time330 $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 80         | Th, Th (CS)     | Any unspecified hold When set up is specified                                               | 0    | _                 | _          | ns             |
| 82TwPlPulse width (Low)200ns83TcTxCTxC Cycle time330 $\infty$ ns84TwTxClTxC width (Low)100 $\infty$ ns85TwTxChTxC width (High)100 $\infty$ ns86TdTxC (TxD)TxC \ot o TxD Delay (x1 Mode)220ns87TdTxC (W / RRf)TxC \ot o W/RDY \ot Delay (Ready mode)59CLK Periods88TdTxC (INT)TxC \ot o INT \ot Delay59CLK Periods89TcRxCRxC Cycle time330 $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 81         | TwPh            | Pulse width (High)                                                                          | 200  | —                 | -          | ns             |
| 83TcTxCTxC Cycle time330 $\infty$ ns84TwTxClTxC width (Low)100 $\infty$ ns85TwTxChTxC width (High)100 $\infty$ ns86TdTxC (TxD)TxC \ot or txD Delay (x1 Mode)220ns87TdTxC (W / RRf)TxC \ot or txD Delay (Ready mode)59CLK Periods88TdTxC (INT)TxC \ot or tyD Delay59CLK Periods89TcRxCRxC Cycle time330 $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 82         | TwPl            | Pulse width (Low)                                                                           | 200  | -                 | -          | ns             |
| 84TwTxClTxC width (Low)100 $\infty$ ns85TwTxChTxC width (High)100 $\infty$ ns86TdTxC (TxD)TxC \otymetric to TxD Delay (x1 Mode)220ns87TdTxC (W/RRf)TxC \otymetric to W/RDY \otymetric Delay (Ready mode)59CLK Periods88TdTxC (INT)TxC \otymetric to INT \otymetric Delay59CLK Periods89TcRxCRxC Cycle time330 $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 83         | ТсТхС           | TxC Cycle time                                                                              | 330  |                   | ∞ .        | ns             |
| 85TwTxChTxC width (High)100 $ \infty$ ns86TdTxC (TxD)TxC \otymed to TxD Delay (x1 Mode) $ -$ 220ns87TdTxC (W / RRf)TxC \otymed to W/RDY \otymed Delay (Ready mode)5 $-$ 9CLK Periods88TdTxC (INT)TxC \otymed to TNT \otymed Delay5 $-$ 9CLK Periods89TcRxCRxC Cycle time330 $ \infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 84         | TwTxCl          | TxC width (Low)                                                                             | 100  |                   | ∞          | ns             |
| 86    TdTxC (TxD)    TxC ↓ to TxD Delay (x1 Mode)      220    ns      87    TdTxC (W / RRf)    TxC ↓ to TxD Delay (x1 Mode)    5     9    CLK Periods      88    TdTxC (INT)    TxC ↓ to TNT ↓ Delay    5     9    CLK Periods      89    TcRxC    RxC Cycle time    330     ∞    ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 85         | TwTxCh          | TxC width (High)                                                                            | 100  | -                 | ∞          | ns             |
| 87 $TdTxC$ (W / RRf) $TxC \downarrow to W/RDY \downarrow Delay (Ready mode)$ 59CLK<br>Periods88 $TdTxC$ (INT) $TxC \downarrow to INT \downarrow Delay$ 59CLK<br>Periods89 $TcRxC$ $RxC$ Cycle time330 $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 86         | TdTxC (TxD)     | $\overline{TxC} \downarrow$ to TxD Delay (x1 Mode)                                          |      | —                 | 220        | ns             |
| 88TdTxC (INT) $\overline{TxC} \downarrow$ to $\overline{INT} \downarrow$ Delay5-9CLK<br>Periods89TcRxC $\overline{RxC}$ Cycle time330- $\infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 87         | TdTxC (W / RRf) | $\overline{TxC}\downarrowto\overline{W/RDY}\downarrowDelay(Readymode)$                      | 5    | -                 | 9          | CLK<br>Periods |
| 89TcRxC $\overline{RxC}$ Cycle time330 $ \infty$ ns                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 88         | TdTxC (INT)     | TxC↓to INT↓Delay                                                                            | 5    | _                 | 9          | CLK<br>Periods |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 89         | TcRxC           | RxC Cycle time                                                                              | 330  |                   | ∞          | ns             |

MPUZ80-736

|            |                 |                                                                                                           |                          |      |      | (~,~)          |
|------------|-----------------|-----------------------------------------------------------------------------------------------------------|--------------------------|------|------|----------------|
| NO. SYMBOL |                 | PARAMETER                                                                                                 | TMPZ84C015AF-6<br>(6MHz) |      |      | UNIT           |
|            |                 |                                                                                                           | MIN.                     | TYP. | MAX. |                |
| 90         | TwRxCl          | RxC width (Low)                                                                                           | 100                      | -    | œ    | ns             |
| 91         | TwRxCh          | RxC width (High)                                                                                          | 100                      | -    | œ    | ns             |
| 92         | TsRxD (RxC)     | RxD to $\overline{RxC} \uparrow$ Set up time (x1 mode)                                                    | 0                        | -    | -    | ns             |
| 93         | ThRxD (RxC)     | RxC↑ to RxD Hold time (x1 mode)                                                                           | 100                      | -    |      | ns             |
| 94         | TdRxC (W / RRf) | $\overline{\text{RxC}} \uparrow \text{to } \overline{\text{W/RDY}} \downarrow \text{Delay (Ready mode)}$  | 10                       |      | 13   | CLK<br>Periods |
| 95         | TdRxC (INT)     | RxC ↑ to INT ↓ Delay                                                                                      | 10                       | _    | 13   | CLK<br>Periods |
| 96         | TdRxC (SYNC)    | $\overline{\text{RxC}} \uparrow \text{to } \overline{\text{SYNC}} \downarrow \text{Delay (output modes)}$ | 4                        |      | 7    | CLK<br>Periods |
| 97         | TsSYNC (RxC)    | SYNC↓to RxC↑ Set up Time<br>(External sync modes)                                                         | -100                     | —    | -    | ns             |
| 98         | TsAdd (Cr)      | Address Set up time to clock ↑                                                                            | 150                      | —    | -    | ns             |
| 99         | TsIO (Cr)       | $\overline{IORQ} \downarrow Set$ up time to clock $\uparrow$                                              | 70                       |      | -    | ns             |
| 100        | TdRD (Cr)       | $\overline{RD} \downarrow Set$ up time to clock $\uparrow$                                                | 70                       | _    | -    | ns             |
| 101        | TdCr (Do)       | Data out Delay to clock ↑                                                                                 | -                        |      | 130  | ns             |
| 102        | TdlORDr (DoZ)   | Data Float Delay to $\overline{IORQ} \uparrow$ , $\overline{RD} \uparrow$                                 | -                        | _    | 90   | ns             |
| 103        | TsWR (Cr)       | WR↓Set up time to clock↑                                                                                  | 70                       |      |      | ns             |
| 104        | TsDI (Cr)       | Data Input Set up time to clock ↑                                                                         | 0                        | -    | -    | ns             |
| 105        | TdIOWRf (D)     | Data Hold time to $\overline{IORQ} \uparrow$ , $\overline{WR} \uparrow$                                   | 20                       | -    | -    | ns             |

(2/2)

# 4.5.5.AC Characteristics of WDT (in Inactive State)

| NO. | SYMBOL     | PARAMETER                           |      | TMPZ84C015AF-6<br>(6MHz) |      |    |
|-----|------------|-------------------------------------|------|--------------------------|------|----|
|     |            |                                     | MIN. | TYP.                     | MAX. |    |
| 106 | TdC (WDTf) | Clock ↑ to WDTOUT ↓ Delay           | -    | -                        | 160  | ns |
| 107 | TdC (WDTr) | Clock ↑ to WDTOUT ↑ Delay           | -    | -                        | 165  | ns |
|     | TCWDT      | WDTOUT out put period<br>WDT Mode 0 | _    | T12*<br>216              | _    | ns |
| 108 |            | WDT Mode 1                          |      | T12*<br>218              | -    | ns |
|     |            | WDT Mode 2                          | —    | T12 *                    | -    | ns |
|     |            | WDT Mode 3                          | _    | T12 *<br>222             | _    | ns |

300389

Note1: Timing Measurements are made at the following voltage. Input VIH=2.4V, VIL=0.4V

Input V V Output V

VIHC = VCC - 0.6V,VOH = 2.2V,CL = 100pF VILC=0.6V VOL=0.8V (Except CLKOUT)

MPUZ80-738

### 4.6 AC TIMING CHARTS (2) (IN INACTIVE STATE)

### 4.6.1 AC Timing Charts of CGC (in Inactive State)

The following Figures show the timing charts in each operation mode with the CLKOUT pin connected to the CLKIN pin.



Figure 4.6.2 Clock restart timing (STOP mode)







Figure 4.6.7 CTC timing diagram (Inactive)

MPUZ80-741

300389

# TOSHIBA

# 4.6.3 AC Timing Charts of PIO (in Inactive State)



Figure 4.6.8 PIO timing diagram (Inactive)

# 4.6.4 AC Timing Charts of SIO (in Inactive State)



Figure 4.6.9 SIO timing diagram (a) (Inactive)



Figure 4.6.9 SIO timing diagram (b) (Inactive)

# 4.6.5 AC Timing Charts of WDT (in Inactive State)

(The mode setting and daisy chain interrupt setting registers on  $WDT\)$ 



Figure 4.6.10 RD/WRITE, WDTOUT timing Diagram

### 4.7 PIN CAPACITANCE

| SYMBOL | ITEM                    | TEST CONDITION               | MIN. | TYP. | MAX. | UNIT   |
|--------|-------------------------|------------------------------|------|------|------|--------|
| CLOCK  | Clock Input Capacitance | F = 1MHz                     | -    |      | 8    |        |
| CIN    | Input Capacitance       | All terminals except that to | -    | -    | 6    | PF     |
| COUT   | Output Capacitance      | be measured be earthed       | -    | -    | 10   |        |
|        |                         |                              |      |      |      | 300389 |

# 5. EXETERNAL DIMENSIONS

QFP100-P-1420B

Unit : mm



MPUZ80-747

# The Guide Of TOSHIBA TLCS-Z80 ASSP Development Tools And Development Methods

This guide shows how to develop the ASSP application systems with development tools.

### 1. GENERAL

Toshiba ASSP series are high-performance CMOS Z80 micro-processors, in which they include counter/timer circuit (CTC), clock generator/controller (CGC), input/output port (PIO, SIO), and watchdog timer. ASSP series are applied to the communication systems, controllers, and measurement instruments.

In developing, these processors work as the evaluation chips. Thus development tools for Z80 MPU (Toshiba's real time emulator : RTE-80 or others) can be used, and new tools for these processors are not required.

180489

# TOSHIBA

### 2. EVALUATION MODE OF ASSP

EV pin is provided to disconnect the MPU from the ASSP processor. Normally this EV pin is low level.

In developing, after one machine code has executed the MPU of the ASSP has disconnected from the target system by EV pin input high and BUSREQ pin input low.

Then an emulator executes programs, and operates peripherals in the ASSP processor.

Table 2.1 shows the pins of the MPU which are disconnected by EV and BUSREQ. Figure 2.1 shows the timing of disconnection.

| 16016 2.1    | Table 2.1 Tills to be disconnected       |  |  |  |  |  |  |
|--------------|------------------------------------------|--|--|--|--|--|--|
| mode set pin | pin to be disconnected                   |  |  |  |  |  |  |
| EV           | M1, HALT, RFSH (note)                    |  |  |  |  |  |  |
| BUSREQ       | WR, MREQ, IORQ<br>A00 – A15, D0 – D7, RD |  |  |  |  |  |  |

|  | Г | able | 2. | 1 | Pins | to | be | disco | nne | ected | ł |
|--|---|------|----|---|------|----|----|-------|-----|-------|---|
|--|---|------|----|---|------|----|----|-------|-----|-------|---|

Note : BUSACK is not disconnected

: For the TMPZ84C011A RFSH pin is not disconnected and goes "High".





Figure 2.1 Timing of Disconnection

#### MPUZ80-749

# 3. EMULATOR CONNECTION AND ADAPTER BOARDS

When developing the systems using ASSP processor, an evaluation board interfacing between the target board and real time emulator is required.

There are two ways to develop the ASSP systems (Level 1 and Level 2), and the evaluation boards for both ways are available.

#### 3.1 LEVEL 1 (Evaluation boards : BM8024/25)

This level is adopted when the pattern for the ASSP is not completed on the target board or the target board is pre-production.

Remove ASSP chip from the target board, then connect the all signal lines of the ASSP to the evaluation board. An ASSP chip on the evaluation board is working in evaluation mode. (MPU in the chip is disconnected. Therefore emulator operates the peripherals in ASSP.)

On the evaluation board there is an universal area to compose target system.

Evaluation board BM8024 for TMPZ84C011A BM8025 for TMPZ84C015A

#### 3.2 LEVEL 2 (Adapter boards : BM8026/27)

In this case the ASSP chip on the target board works in evaluation mode. This level is adopted to debug final target board.

Adapter board BM8026 for TMPZ84C011A BM8027 for TMPZ84C015A

# 4. DEVELOPMENT METHOD

#### 4.1 LEVEL 1

Figure 4.1 shows the way to develop the target system with evaluation board and RTE80 (Toshiba's real time emulator).



Figure 4.1 Example of connection (Level 1) (For the detail, refer to instruction manuals)

#### 4.2 LEVEL 2



Figure 4.2 shows the way to develop the target system with adapter board and RTE80.



#### 4.3 CONNECTION OF BM8026/BM8027 AND TARGET SYSTEM

There are three ways to connect 50-pin connector of the adapter board and ASSP on the target system.

(1) Provide a 50-pin flat cable socket on the target system



(2) Solder the male connector of the flat cable directly



(3) To provide patterns on the target system to insert mini terminals on a board



The TMPZ84C011A and TMPZ84C015A are housed in the 100-pin mini flat package. When connecting the adapter board (BM8026/BM8027) for them by using any of the ways, take care on the following points.

(1) To use ASSP chip on the target system in the evaluation mode by connecting to the emulator, all bus signals of the MPU in ASSP should be placed in floating state or opened for emulator.

The adapter board can be disconnected from the emulator by controlling the interface circuit inside the emulator, and it can be operated independently.

(2) Tables 4.1 (a) and (b) show the signal names of the connector.

| pin Name | pin Nu | umber | pin Name |  |  |  |  |  |
|----------|--------|-------|----------|--|--|--|--|--|
| A11      | 1      | 40    | A10      |  |  |  |  |  |
| A12      | 2      | 39    | A9       |  |  |  |  |  |
| A13      | 3      | 38    | A8       |  |  |  |  |  |
| A14      | 4      | 37    | A7       |  |  |  |  |  |
| A15      | 5      | 36    | A6       |  |  |  |  |  |
| CLK      | 6      | 35    | A5       |  |  |  |  |  |
| D4       | 7      | 34    | A4       |  |  |  |  |  |
| D3       | 8      | 33    | A3       |  |  |  |  |  |
| D5       | 9      | 32    | A2       |  |  |  |  |  |
| D6       | 10     | 31    | A1       |  |  |  |  |  |
| VCC      | 11     | 30    | A0       |  |  |  |  |  |
| D2       | 12     | 29    | GND      |  |  |  |  |  |
| D7       | 13     | 28    | RFSH     |  |  |  |  |  |
| D0       | 14     | 27    | M1       |  |  |  |  |  |
| D1       | 15     | 26    | RESET    |  |  |  |  |  |
| INT      | 16     | 25    | BUSREQ   |  |  |  |  |  |
| NMI      | 17     | 24    | WAIT     |  |  |  |  |  |
| HALT     | 18     | 23    | BUSACK   |  |  |  |  |  |
| MREQ     | 19     | 22    | WR       |  |  |  |  |  |
| IORQ     | 20     | 21    | RD       |  |  |  |  |  |
|          |        |       |          |  |  |  |  |  |

CNA : Connect to the emulator (RTE80 or others)

40-pin DIP socket

Table 4.1 (a) Pin Connection Table

| pin Name        | pin Nı | umber | pin Name | F |
|-----------------|--------|-------|----------|---|
| D7              | 1      | 2     | D6       |   |
| D5              | 3      | 4     | D4       |   |
| D3              | 5      | 6     | D2       |   |
| D1              | 7      | 8     | D0       |   |
| INT             | 9      | 10    | EV       |   |
| HALT            | 11     | 12    | MREQ     |   |
| IORQ            | 13     | 14    | WR       |   |
| U.RD            | 15     | 16    | RD       |   |
| <b>U.BUSACK</b> | 17     | 18    | BUSACK   |   |
| WAIT            | 19     | 20    | NC       |   |
| <b>U.BUSREQ</b> | 21     | 22    | BUSREQ   |   |
| RESET           | 23     | 24    | M1       |   |
| U.RFSH          | 25     | 26    | RFSH     |   |
| VCC             | 27     | 28    | GND      |   |
| A0              | 29     | 30    | A1       |   |
| A2              | 31     | 32    | A3       | Ū |
| A4              | 33     | 34    | A5       |   |
| A6              | 35     | 36    | A7       | Ū |
| A8              | 37     | 38    | A9       |   |
| A10             | 39     | 40    | A11      |   |
| A12             | 41     | 42    | A13      |   |
| A14             | 43     | 44    | A15      |   |
| NMI             | 45     | 46    | VCC      |   |
| GND             | 47     | 48    | CLK      |   |
| NC              | 49     | 50    | NC       |   |

CNB : BM8026

| Connect to target system |
|--------------------------|
| 50-pin flat cable socket |

CNB : BM8027

| pin Name        | pin Nu | umber | pin Name |
|-----------------|--------|-------|----------|
| NC              | 1      | 2     | D7       |
| D6              | 3      | 4     | D5       |
| D4              | 5      | 6     | D3       |
| D2              | 7      | 8     | D1       |
| D0              | 9      | 10    | VCC      |
| A15             | 11     | 12    | A14      |
| A13             | 13     | 14    | A12      |
| A11             | 15     | 16    | A10      |
| A9              | 17     | 18    | A8       |
| A7              | 19     | 20    | A6       |
| A5              | 21     | 22    | A4       |
| A3              | 23     | 24    | A2       |
| A1              | 25     | 26    | A0       |
| NC              | 27     | 28    | RFSH     |
| M1              | 29     | 30    | RESET    |
| <b>U.BUSREQ</b> | 31     | 32    | BUSREQ   |
| NC              | 33     | 34    | WAIT     |
| <b>U.BUSACK</b> | 35     | 36    | BUSACK   |
| NC              | 37     | 38    | WR       |
| U.RD            | 39     | 40    | RD       |
| IORQ            | 41     | 42    | GND      |
| MREQ            | 43     | 44    | HALT     |
| INT             | 45     | 46    | NC       |
| CLKOUT          | 47     | 48    | EV       |
| GND             | 49     | 50    | NMI      |

U.RD, U.BUSACK, U.BUSREQ, U.RFSH are target system's signals.

180489

#### Table 4.1 (b) Pin Connection Table

- (3) A 50-pin flat cable connector is provided on the adapter board to connect ASSP chip on the target board.
- (4) When connecting the adapter board and the target system :
  - a) Connect all the signals of the TMPZ84C011A or TMPZ84C015A to the target system directly or via the connector
  - b) EV pin is driven by adapter board, so pull down this pin by a resistor.  $(10k\Omega-100k\Omega)$

(Don't connect directly to Vss)

- (c) It is not necessary to connect BUSREQ and U.BUSREQ, BUSACK and U.BUSACK, RD and U.RD on the target system.
  (These signals are connected on the adapter board respectively)
  Note: When the adapter board is removed, these signals should be connected on the target system, respectively.
- (d) When the target system does not use BUSREQ pin and BUSACK pin, U.BASACK pin can be used in open state, and input to U.BUSREQ must be CMOS high level.
- Note 1: The following signals in adapter board are pulled up by resistor. HALT, RD, U.RD, MI RFSH (applied for BM8027 only), and BUSACK.
- Note 2: Power Supply of the adapter board must be supplied by the target system.



Figure 4.3 shows the connection of adapter board, target system, and emulator.

Note 1: Connect these signals when adapter board is disconnected.

Note 2: For the BM8026, RFSH pin and U.RFSH pin are provided in place of RFSH pin.

Figure 4.3 Interface Circuit

For more details, refer to the following manuals.

- 1. TLCS-Z80 DEVELOPMENT SYSTEM MANUAL
- 2. TMPZ84C011A Experimental Board (Evaluation Board : BM8024) BM8024 Instruction Manual
- 3. TMPZ84C015A Experimental Board (Evaluation Board : BM8025) BM8025 Instruction Manual
- 4. TMPZ84C011A Adapter Board (BM8026) BM8026 Instruction Manual
- 5. TMPZ84C015A Adapter Board (BM8027) BM8027 Instruction Manual

# PART 2 8-BIT MICROPROCESSOR

# TLCS-85 FAMILY

TOSHIBA CORPORATION

CONTENTS

# CONTENTS

| TMP8085AP-2 / TMP8085AHP-2                 | MPU85 - 1   |
|--------------------------------------------|-------------|
| TMP8155P-2 / TMP8156P-2                    | MPU85 - 26  |
| TMP82C51AP-2 / TMP82C51AP-10               |             |
| TMP82C51AM-2/TMP82C51AM-10                 | MPU85 - 42  |
| TMP8251AP                                  | MPU85 - 60  |
| TMP82C53P-2                                | MPU85 - 78  |
| TMP82C54P-2 / TMP82C54M-2                  | MPU85 - 93  |
| TMP8253P-5                                 | MPU85 - 119 |
| TMP82C55AP-2 / TMP82C55AM-2                |             |
| TMP82C55AP-10/TMP82C55AM-10                | MPU85 - 133 |
| TMP8255AP-5                                | MPU85 - 153 |
| TMP82C59AP-2/TMP82C59AM-2                  | MPU85 - 172 |
| ТМР8259АР                                  | MPU85 - 198 |
| TMP82C37AP-5 / TMP82C37AM-5 / TMP82C37AT-5 | MPU85 - 207 |
| TMP8237AP-5                                | MPU85 - 240 |
| TMP82C79P-2 / TMP82C79M-2                  | MPU85 - 272 |
| TMP8279P-5                                 | MPU85 - 294 |
| TMP82C255AN-2 / TMP82C265AF-2              |             |
| TMP82C255AN-10/TMP82C265AF-10              | MPU85 - 316 |

i

# TMP8085AP-2/TMP8085AHP-2 8-BIT MICROPROCESSOR

# 1. GENERAL DESCRIPTION

The TMP8085AP-2/TMP8085AHP-2, hereafter on referred to as TMP8085A, is a 8 bit micro processing unit (MPU). TMP8085A uses a multiplexed data bus. The address is split between the 8 bit address bus and the 8 bit data bus. The on-chip address latches of TMP8155P-2/TMP8156P-2 allow a direct interface with TMP8085A.

# 2. FEATURES

- 0.8µSec Instruction Cycle (CLK Cycle Period @200nSec)
- Single +5V Power Supply (TMP8085AP-2: 5V±5%, TMP8085AHP-2: 5V±10%)
- On-Chip Clock Generator (with External Crystal or RC Network)
- On-Chip System Controller; Cycle status information available for Large System Control
- 4 Vectored Interrupts (One is Non-Maskable)
- Decimal, Binary and Double Precision Arithmetic
- Serial In/Serial Out Port
- Direct Addressing Capability up to 64K Byte Memory Space
- Compatible with Intel's 8085A
- Low Power Consumption (TMP8085AHP-2: Icc max = 135mA)

# 3. PIN CONNECTION (TOP VIEW)

|                 |      |            |    | - |                 |
|-----------------|------|------------|----|---|-----------------|
| X1              | C 1  | $\bigcirc$ | 40 | þ | V <sub>CC</sub> |
| X2              | d 2  |            | 39 | þ | HOLD            |
| RESET OUT       | [З   |            | 38 | þ | HLDA            |
| SOD             | C 4  |            | 37 | þ | CLK (OUT)       |
| SID             | 05   |            | 36 | þ | <b>RESET IN</b> |
| TRAP            | 6    |            | 35 | þ | READY           |
| RST7.5          | ٢ ٦  |            | 34 | þ | IO/M            |
| RST6.5          | 8 ]  |            | 33 | þ | S <sub>1</sub>  |
| RST5.5          | d 9  | TMP8085A   | 32 | þ | RD              |
| INTR            | d 10 |            | 31 | þ | WR              |
| INTA            | d 11 |            | 30 | þ | ALE             |
| AD <sub>0</sub> | d 12 |            | 29 | þ | S <sub>0</sub>  |
| AD <sub>1</sub> | E 13 |            | 28 | þ | A <sub>15</sub> |
| AD <sub>2</sub> | d 14 |            | 27 | þ | A <sub>14</sub> |
| AD3             | [ 15 |            | 26 | þ | A <sub>13</sub> |
| AD4             | [ 16 |            | 25 | þ | A <sub>12</sub> |
| AD <sub>5</sub> | C 17 |            | 24 | þ | A <sub>11</sub> |
| AD <sub>6</sub> | [ 18 |            | 23 | þ | A <sub>10</sub> |
| AD7             | [ 19 |            | 22 | þ | Ag              |
| $V_{SS}$        | 0 20 |            | 21 | þ | A <sub>8</sub>  |
|                 |      |            |    |   |                 |

Figure 3.1

# 4. BLOCK DIAGRAM



Figure 4.1

# 5. PIN NAME AND PIN DESCRIPTION

• X<sub>1</sub>, X<sub>2</sub> (Input)

Crystal, LC, or RC network are connected to  $X_1$  and  $X_2$  to drive the internal clock generator.  $X_1$  and  $X_2$  can also be driven by an external clock source. The input frequency is devided by 2 to give the processor's internal operating frequency.

• CLK(Output)

Clock Output for use as a system clock. The period of CLK is twice the  $\mathrm{X}_1,\,\mathrm{X}_2$  input period.

• RESETIN (Input)

The RESETIN Input initializes the processor by clearing the program counter, instruction register, SOD latch, Interrupt Enable flip-flop and HLDA flip-flop. The address and data buses and the control lines are 3-stated during RESET and because of the asynchronous nature of RESET, the processor's internal registers and flags may be altered by RESET with unpredictable results. RESETIN is a Schmitttriggered input, allowing connection to an RC network for power on RESET delay. The TMP8085A is held in the reset condition as long as RESETIN is applied.

• RESET OUT (Output)

The RESET OUT signal indicates that the TMP8085A is being reset. It can be used as a system reset. It is synchronized to the processor clock and lasts an integral number of clock periods.

• SOD (Output)

Serial output data line. The output SOD is set or reset as specified by the SIM instruction.

• SID (Input)

Serial input data line. The data on this line is loaded into accumulator bit 7 whenever a RIM instruction is executed.

• INTR (Input)

INTERRUPT REQUEST signal provides a mechanism for external devices to modify the instruction flow of the program in progress. It is sampled only during the next to the last clock cycle of an instruction and during Hold and Halt states. If it is recognized, the processor will complete the execution of the current instruction, and then the Program Counter (PC) will be inhibited from incrementing and an  $\overline{\text{INTA}}$  will be issued. During this cycle a RESTART or CALL instruction can be inserted to jump to the interrupt service routine. The INTR is enabled and disabled by software. It is disabled by RESET and immediately after an interrupt is accepted.

• INTA (Output)

INTERRUPT ACKNOWLEDGE: Occurs in response to an Interrupt input and indicates that the processor will be ready for an interrupt instruction on the data bus. It is used instead of (and has the same timing as)  $\overline{\text{RD}}$  during the instruction cycle after an INTR is accepted.

RST 5.5 RST 6.5 (Inputs) RST 7.5

RESTART INTERRUPTS: These three inputs have the same timing as INTR except they cause an internal RESTART to be automatically inserted. These interrupts have a higher priority than INTR. The priority of these interrupts is ordered as shown Table 1. These interrupts are maskable using the SIM instruction.

• TRAP (Input)

Trap interrupt is a nonmaskable RESTART interrupt. It is sampled at the same timing as INTR or RST 5.5-7.5. It is unaffected by SIM or Enable/Disable Interrupt instruction. It has the highest priority of any interrupt.

• AD<sub>0</sub>-AD<sub>7</sub> (Input/Output, 3-state)

Lower 8 bits of the memory address (or I/O address) appear on the bus during the first clock cycle ( $T_1$  state) of a machine cycle. It then becomes the data bus during the second and third clock cycles.

•  $A_8$ - $A_{15}$  (Output, 3-state)

Upper 8 bits of the memory address or the 8 bits of the I/O address, 3-stated during Hold and Halt modes and during RESET.

•  $S_0, S_1, and IO/\overline{M}$  (Output)

Machine cycle status:

| $IO/\overline{M}$ | $S_1$ | $S_0$ | Status                |
|-------------------|-------|-------|-----------------------|
| 0                 | 1     | 1     | Opcode fetch          |
| 0                 | 1     | 0     | Memory read           |
| 0                 | 0     | 1     | Memory write          |
| 1                 | 1     | 0     | I/O read              |
| 1                 | 0     | 1     | I/O write             |
| 1                 | 1     | 1     | Interrupt Acknowledge |
| TS                | 0     | 0     | Halt                  |
| TS                | Х     | Х     | Hold                  |
| TS                | Х     | Х     | Reset                 |
|                   |       |       |                       |

Note : TS=3-state (high impedance) X=unspecified

• ALE (Output)

Address Latch Enable: It occurs during the first clock state of a machine cycle and enables the address to get latched into the external latch or the on-chip latch of peripherals. The falling edge of ALE can be used to strobe the status information. ALE never goes 3-stated.

• WR (Output, 3-state)

WRITE control: A low level on  $\overline{WR}$  indicates the data on the Data Bus is to be written into the selected memory or I/O location. Data is set up at the trailing edge of  $\overline{WR}$ . It is 3-stated during Hold and Halt modes and during RESET.

• RD (Output, 3-state)

READ control: A low level on  $\overline{\text{RD}}$  indicates the selected memory or I/O device to be read and that the Data Bus is available for the data transfer, 3-stated during Hold and Halt modes and during RESET.

• READY (Input)

When READY is inactive (low), indicating the external operation has not been complete yet, the processor will enter the Wait state. It will wait for an integral number of clock cycles until READY goes high before completing the read or write cycle. • HOLD (Input)

The HOLD input cause TMP8085A to release the control over the address bus and the data bus. When HOLD goes active, the processor completes its current operation, activates the HLDA output, and puts the Address, Data,  $\overline{\text{RD}}$ ,  $\overline{\text{WR}}$ , and  $IO/\overline{M}$  lines into high-impedance state. Internal processing can continue. The Holding device can then utilize the address and data buses instead of TMP8085A. TMP8085A can regain the bus only after the HOLD goes inactive (low).

• HLDA (Output)

The Hold Acknowledge output, HLDA signal is a response to a HOLD input. It indicates that TMP8085A has received the HOLD request and HOLD will release the bus control in the next cycle. HLDA goes low after the HOLD goes inactive (low). TMP8085A takes over the bus control one half clock after HDLA goes low.

• V<sub>CC</sub>

+ 5 volt supply

• V<sub>SS</sub>

Ground Reference

# 6. FUNCTIONAL DESCRIPTION

#### TMP8085A is a 8-bit central processor.

TMP8085A is provided with internal 8-bit registers and 16-bit registers. TMP8085A has eight addressable 8-bit registers. Six of them can be used either as 8-bit registers or as 16-bit register pairs. In addition to the register pairs, the TMP8085A contains two additional 16-bit registers. TMP8085A register set is as follows:

- The acccumulator (A Register) is the focus of all of the accumulator instructions, which include arithmetic, logic, load and store, and I/O instructions.
- The program counter (PC) always points to the memory location of the next instruction to be executed.
- General-purpose registers BC, DE, and HL may be used as 8-bit registers or as three 16-bit registers, interchangeably, depending on the instruction being performed.
- The stack pointer (SP) is a special data pointer that always points to the stack top (next available stack address).
- The flag register contains five one-bit flags, each of which records processor status information and may also control processor operation.

The five flags in TMP8085A are shown below:

(MSB)

| D7 | D <sub>6</sub> | D <sub>5</sub> | D4 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----|----------------|----------------|----|----------------|----------------|----------------|----------------|
| S  | Z              |                | AC |                | Р              |                | С              |

- The carry flag (C) is set and reset by arithmetic operations. An additional operation that results in an overflow out of the high-order bit of the accumulator sets the carry flag. The carry flag also acts as a "borrow" flag for subtract instruction.
- The auxiliary carry flag (AC) indicates overflow out of bit 3 of the accumulator in the same way that C flag indicates overflow out of bit 7. This flag is commonly used in BCD arithmetic.
- The sign flag (S) is set to the condition of the most significant (MSB) bit of the accumulator following the execution of arithmetic or logic instructions.
- The zero flag (Z) is set if the result generated by certain instructions is zero. The zero flag is cleared if the result is not zero.
- The parity flag (P) is set to 1 if the parity (number of 1-bits) of the accumulator is even. If odd, it is cleared. TMP8085A offers the functions of clock generation,

system bus control, and interrupt priority selection as well as execution of the instruction set. TMP8085A uses a multiplexed Data Bus. The address is split between the higher 8-bit Address Bus and the lower 8-bit Address/Data Bus. During the first T state ( $T_1$  clock cycle) of a machine cycle the lower order address is sent out on the Address/Data Bus. These lower 8 bits may be latched externally by the Address Latch Enable signal (ALE). During the rest of the machine cycle, the data bus is used for memory or I/O data transferring.
### 7. INTERRUPT AND SERIAL I/O

TMP8085A has 5 interrupt inputs: INTR, RST 5.5, RST 6.5, RST 7.5, and TRAP. INTR is identical in function to 8080A INT. Each of three RESTART inputs 5.5, 6.5, 7.5, has a programmable mask. TRAP is also one of RESTART interrupts but it is nonmaskable.

The three RESTART interrupts cause the internal execution of RESTART if the interrupts are enabled and if the corresponding interrupt mask is not set. The nonmaskable TRAP always causes internal interrupt execution whether INTR, RST 5.5, RST 6.5 and RST 7.5 interrupts are enable or not.

There are two different types of inputs in the restart interrupts. RST 5.5 and RST 6.5 are high-level sensitive like INTR and are recognized with the same timing as INTR. RST 7.5 is rising edge-sensitive.

For RST 7.5, only a pulse is required to set an internal flip-flop which generates the interrupt request. The RST 7.5 request flip-flop remains set until the request is serviced. Then it is reset automatically. This flip-flop may also be reset by using the SIM instruction or by issuing a RESETIN to TMP8085A. The RST 7.5 internal flip-flop will be set by a pulse on the RST 7.5 pin even when the RST 7.5 interrupt is masked.

The interrupts are arranged in a fixed priority that determines which interrupt is to be recognized if more than one is pending: TRAP-highest priority. RST 7.5, RST 6.5, RST 5.5, INTR-lowest priority. This priority scheme does not take into account the priority of a routine that was started by a higher priority interrupt. RST 5.5 can interrupt a RST 7.5 routine if the interrupts were reenabled before the end of the RST 7.5 routine.

The TRAP interrupt is useful for catastrophic errors such as power failure or bus error. It is not affected by any flag or mask. The TRAP input is both edge and level sensitive. The TRAP input must go high and remain high until it is acknowledged. It will not be recognized again until it goes low, then high again. This avoids any false triggering due to noise or logic glitches.

| Name    | Priority | Address branched to<br>When Interrupt Occurs | Type Trigger                              |  |  |
|---------|----------|----------------------------------------------|-------------------------------------------|--|--|
| TRAP    | 1        | 24 (Hex. )                                   | Rising edge and high level until sampled. |  |  |
| RST 7.5 | 2        | 3C (Hex. )                                   | Rising edge (latched) .                   |  |  |
| RST 6.5 | 3        | 34 (Hex. )                                   | High level until sampled.                 |  |  |
| RST 5.5 | 4        | 2C (Hex. )                                   | High level until sampled.                 |  |  |
| INTR    | 5        | See Note (2)                                 | High level until sampled.                 |  |  |

| Table 7.1 | Interrupt Prio      | rity, Restart Ad                        | ddress, and           | Sensitivity   |
|-----------|---------------------|-----------------------------------------|-----------------------|---------------|
|           | in the transfer the | , , , , , , , , , , , , , , , , , , , , | a a 1 0 3 3 7 a 1 1 a | o cribicitity |

050489

Notes: (1) The processor pushes the PC on the stack before branching to the indicated address.
(2) The address branched to depends on the instruction provided to TMP8085A when the interrupt is acknowledged.

The TRAP interrupt is special in that it disables all other interrupts, but preserves the previous interrupt enable status. Performing the first RIM instruction following a TRAP interrupt allows you to determine whether interrupts were enabled or disabled prior to the TRAP. All subsequent RIM instruction provide current interrupt enable status. Performing a RIM instruction following INTR, or RST 5.5-7.5 will provide current interrupt enable status, revealing that interrupts are disabled.

The serial I/O system is also controlled by the RIM and SIM instructions. SID is read by RIM, and SIM sets the SOD date.

### 8. BASIC TIMING

The execution of each instruction by the TMP8085A consists of a sequence of from one to five machine cycles, and cach machine cycle consists of a minimum of from three to six clock cycles. Most machine cycles consist of three T states, (cycles of the CLK output) with the exception of opecode fetch, which normally has either four or six T states (unless WAIT or HOLD states are forced by the receipt of READY or HOLD inputs). Any T state must be one of ten possible states, shown in Table 3.

At the beginning of every machine cycle, TMP8085A sends out three status signals  $(IO/\overline{M}, S_1, S_0)$  that define what type of machine cycle is about to take place. TMP8085A also sends out a 16-bit address at the beginning of every machine cycle to identify the particular memory location or I/O port that the machine cycle applies to.

The special timing signal, ADDRESS LATCH ENABLE (ALE), is used a strobe to sample the lower 8-bits of address on the AD<sub>0</sub>-AD<sub>7</sub> lines. ALE is present during  $T_1$  of every machine cycle. Control lines  $\overline{RD}$  (INTA) and  $\overline{WR}$  become active later, at the time when the transfer of data is to take plece.

Figure 3 shows an instruction fetch, memory read and I/O write cycle (as would occur during processing of the OUT instruction).

| MACHINE CYCLE       | IO/M | S <sub>1</sub> | S <sub>0</sub> | RD | WR | INTA   |
|---------------------|------|----------------|----------------|----|----|--------|
| OPCODE FETCH        | 0    | 1              | 1              | 0  | 1  | 1      |
| MEMORY READ         | 0    | 1              | 0              | 0  | 1  | 1      |
| MEMORY WRITE        | 0    | 0              | 1              | 1  | 0  | 1      |
| I/O READ            | 1    | 1              | 0              | 0  | 1  | 1      |
| I/O WRITE           | 1    | 0              | 1              | 1  | 0  | 1      |
| ACKNOWLEDGE OF INTR | 1    | 1              | 1              | 1  | 1  | 0      |
| BUSIDLE: DAD        | 0    | 1              | 0              | 1  | 1  | 1      |
| ACK. OF RST,        | 1    | 1              | 1              | 1  | 1  | 1      |
| TRAP                |      |                |                |    |    |        |
| HALT                | TS   | 0              | 0              | TS | TS | 1      |
|                     |      |                |                |    |    | 050489 |

Table 8.1 TMP8085 Machine Cycle Chart

Notes: 0=Logic "0", 1=Logic "1", TS=High Impedance

050489

| MACHINE<br>STATE | \$ <sub>1</sub> , \$ <sub>0</sub> | IO/M | A8-A15 | AD <sub>0</sub> -AD7 | RD, WR | INTA | ALE |
|------------------|-----------------------------------|------|--------|----------------------|--------|------|-----|
| T <sub>1</sub>   | Х                                 | Х    | Х      | х                    | 1      | 1    | 1°  |
| T <sub>2</sub>   | Х                                 | Х    | Х      | X                    | Х      | Х    | 0   |
| TWAIT            | Х                                 | Х    | Х      | X                    | X      | Х    | 0   |
| T <sub>3</sub>   | Х                                 | Х    | Х      | X                    | X      | Х    | 0   |
| T <sub>4</sub>   | 1                                 | 0 +  | Х      | TS                   | 1      | 1    | 0   |
| T <sub>5</sub>   | 1                                 | 0+   | Х      | TS                   | 1      | 1    | 0   |
| T <sub>6</sub>   | 1                                 | 0 +  | Х      | TS                   | 1      | 1    | 0   |
| TRESET           | X                                 | TS   | TS     | TS                   | TS     | 1    | 0   |
| THALT            | 0                                 | TS   | TS     | TS                   | TS     | 1    | 0   |
| THOLD            | X                                 | TS   | TS     | TS                   | TS     | 1    | 0   |

Table 8.2 TMP8085 Machine State Chart

Notes : (1) 0 = LOGIC "0", 1 = Logic "1", TS = High Impedance,

X = Unspecified

- (2) °ALE not generated during 2nd and 3rd machine cycles of DAD instruction
- (3)  $+IO/\overline{M} = 1$  during T<sub>4</sub>-T<sub>6</sub> of INA matchine cycle





# 9. DRIVING THE X1 AND X2 INPUTS

The clock inputs of TMP8085A may be driven by a crystal oscilator, an LC tuned circuit, an RC network or an external clock source. The Minimum driving frequency must be 1 MHz, and must be twice as much as the desired internal clock frequency.

#### (1) Quartz Crystal Clock Driver

If a crystal used, it must have the following characteristics.

- Parallel resonance at twice the clock frequency desired
- $C_S$  (shunt capacitance)  $\leq 7 \, pF$
- $R_S$  (equivalent shunt resistance)  $\leq 75$  Ohms



050489



Note : A value of the external capacitors  $C_1$  and  $C_2$  between X1, X2 and ground. The following values are recommended

 $\begin{array}{ll} 1MHz \leq f < 4MHz & : \ C_1 \! = \! 20 pF, C_2 \! = \! 20 pF \\ 4MHz \leq f \leq 8MHz & : \ C_1 \! = \! 10 pF, C_2 \! = \! 10 pF \\ 8MHz < f \leq 10MHz & : \ C_1 \! = \! 0, C_2 \! = \! 0 \end{array}$ 

#### (2) LC Turned Circuit Clock Driver

A parallel-resonant LC circuit may be used as the frequency-determining network for TMP8085A, providing that its frequency tolerance of approximately 10% is acceptable. The components are chosen from the formula.

 $f = \frac{1}{2\pi\sqrt{L (C_{ext} + C_{int})}}$ 

The use of an LC circuit is not recommended for frequencies higher than approximately 5 MHz.





### (3) RC Circuit Clock Driver

An RC circuit may be used in the case without precise clock frequency stability. Variations in the on-chip timing generation can cause a wide variation in frequency when using RC circuit. The driving frequency generated by the circuit shown is approximately 3 MHz. It is not recommended that frequencies greatly higher or lower than this be attempted.





(4) External clock Driver Circuit



Figure 9.4

# 10. POWER-ON-RESET

The TMP8085A is not guaranteed to work until 10 ms after  $V_{CC}$  reaches 4.75V. It is suggested that <u>RESETIN</u> be kept low during this period. Note that the 10 ms period does not include the time it takes for the power supply to reach its 4.75V level.

For the TMP8085AHP-2, Power-on-reset can be performed when the supply voltage reaches 4.50V.

# **11. INSTRUCION SET**

The code and function of machine instructions are shown as following table. In this table the symbols and abbreviated symbols are used for describing the instructions. However, the symbols required for special attention are explained on the page using them.

| Division         | Symbol                | Description                                                                                                                                       |                                                                                                                                                               |  |  |  |  |
|------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| keg i ster       | r, g<br>t             | Register<br>Register pair<br>Stack pointer<br>Register pair                                                                                       | B, C, D, E, H, L, A<br>BC, DE, HL<br>SP<br>BC, DE, HL                                                                                                         |  |  |  |  |
| Ľ                | 1                     | Program status word                                                                                                                               | PSW                                                                                                                                                           |  |  |  |  |
| Memory           | mn<br>(mn)<br>(HL)    | Memory address or immedia<br>m expresses higher 8 bits and<br>Contents of memory addres<br>Contents of memory addres<br>Contents of memory addres | ate data indicated by 16 bits<br>I n expresses lower 8 bits<br>s indicated by mn<br>s indicated by register pair<br>s indicated by register pair BC,DE and SP |  |  |  |  |
| Flag status      | 0<br>1<br>-<br>*      | Be reset to 0<br>Be set to 1<br>No change<br>Be affected by operation (be                                                                         | e set to 0 or 1.)                                                                                                                                             |  |  |  |  |
| Operation symbol | ←<br>+<br>-<br>\<br>V | Transfer<br>Exchange<br>Addition<br>Subtraction<br>Logical AND for every bit<br>Logical OR for every bit<br>Exclusive OR for every bit            |                                                                                                                                                               |  |  |  |  |
| Other            | IM<br>CY              | Interrupt mask register<br>Carry flag                                                                                                             |                                                                                                                                                               |  |  |  |  |

## Explanation of Symbols

| Σ        |                               | OBJECT                                 | CODE                                   |                                                           |    |                  |     | c      |             | :              |             |                          |          |
|----------|-------------------------------|----------------------------------------|----------------------------------------|-----------------------------------------------------------|----|------------------|-----|--------|-------------|----------------|-------------|--------------------------|----------|
| ~\~      |                               | BIN                                    | HEX                                    | FUNCTION                                                  |    | F                | LAG | 2      |             | ΥCL            | TAT         |                          |          |
| CLA      | MINEMONIC                     | 76 543 210                             |                                        |                                                           | CY | z                | s   | Р      | AC          | U              | S           |                          |          |
|          | MOV g,r<br>MOV g,M<br>MOV M,r | 01 ggg rrr<br>01 ggg 110<br>01 110 rrr | 40 + g × 8 + r<br>46 + g × 8<br>70 + r | g ←r<br>g ←(HL)<br>(HL)←r                                 |    |                  | -   | -<br>- | -           | _1<br>_2<br>_2 | 4<br>7<br>7 | rrr<br><u>ggg</u><br>000 | Register |
|          | MVI g, n                      | 00 ggg 110<br>nn nnn nnn               | 06+g×8<br>n                            | g ←n                                                      | -  | -                | -   | -      | -           | 2              | 7           | 001<br>010               | C<br>D   |
| oad      | MVI M, n                      | 00 110 110<br>nn nnn nnn               | 36<br>n                                | (HL)←n<br>                                                | -  | -                | -   |        | -           | 3              | 10          | 011<br>100               | E<br>H   |
| 1        | LDAX B                        | 00 001 010                             | 0A<br>1A                               | A ←(BC)<br>A ←(DF)                                        |    |                  |     |        |             | 2              | 7           | 101                      | L        |
| 8bi      | LDA mn                        | 00 111 010                             | 3A                                     | A ←(mn)                                                   | -  | -                | -   | -      | -           | 4              | 13          | 111                      | A        |
|          |                               | mmmmmmm                                | m                                      |                                                           |    |                  |     |        |             |                |             |                          |          |
|          | STAX B                        | 00 000 010                             | 02                                     | (BC)←A                                                    | -  | -                |     |        | -           | . 2            | 7           |                          |          |
|          | STAX D                        | 00 010 010                             | 12                                     | (DE)←A                                                    |    |                  |     |        |             | 2              | 7           |                          |          |
|          | STA mn                        | nn nnn nnn                             | n 32                                   | (mn)←A                                                    | -  | -                | -   | -      | -           | 4              | 13          |                          |          |
| <u> </u> | IXI t mn                      | 00 tt0 001                             | m<br>01+t×16                           | t ← mn                                                    |    |                  |     |        |             | 2              | 10          |                          | Register |
|          |                               | nn nnn nnn                             | n                                      |                                                           |    |                  |     |        |             |                |             | 01                       | DE       |
| -        | LHLD mn                       | 00 101 010                             | 2A                                     | H←(mn + 1)                                                |    | -                | -   |        | -           | <br>5          | 16          | 11                       | SP       |
| load     |                               | nn nnn nnn                             | n                                      | L←(mn)                                                    |    |                  |     |        |             |                |             |                          |          |
| ÷        | SHLD mn                       | 00 100 010                             | 22                                     | (mn + 1)←H                                                |    |                  |     | _      | _           | 5              | 16          |                          |          |
| iq       |                               | nn nnn nnn                             | n                                      | (mn)←L                                                    |    |                  |     |        |             | Ĵ              | 10          |                          |          |
| =        |                               | mmmmmmm                                | m                                      |                                                           |    |                  |     |        |             |                |             |                          | 1        |
|          | SPHL                          | 11 111 001                             | F9                                     | SP←HL                                                     |    |                  |     |        |             | 1              | 6           |                          |          |
|          | PUSH Q                        |                                        | Co+q×6                                 | $(SP - 1)(SP - 2) \leftarrow q$<br>$SP \leftarrow SP - 2$ | -  | -                | -   | -      | -           | 5              | 12          | <u>qq</u>                | Register |
| 1        | POP q                         | 11 qq0 001                             | C1 + q × 6                             | q ←(SP + 1)(SP)                                           | ~  |                  | -   | -      | _           | 3              | 10          | 01                       | DE       |
|          |                               |                                        |                                        | SP ←SP + 2                                                | *  | *                | *   | *      | *           |                |             | 10 ך                     | HL       |
| (a)      | XCHG<br>XTHI                  | 11 101 011                             | EB<br>F3                               | I DE⇔HL<br>H⇔(SP + 1) I ⇔(SP)                             |    |                  |     |        | <del></del> | . <u>1</u>     | 4           | 11                       | PSW      |
|          | ADD r                         | 10 000 rrr                             | 80 + r                                 | A ←A+r                                                    | *  | *                | *   | *      | *           | 1              | 4           |                          | PSW only |
|          | ADD M                         | 10 000 110                             | 86                                     | A ←A+(HL)                                                 | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
|          | ADI n                         | 11 000 110                             | C6                                     | A ←A+n                                                    | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
|          | ADC r                         | 10 001 rrr                             | n<br>88 + r                            | A ←A+r+CY                                                 | *  | *                | *   | *      | *           |                | A           |                          |          |
|          | ADC M                         | 10 001 110                             | 8E                                     | A ←A+(HL)+CY                                              | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
| i ca l   | ACI n                         | 11 001 110                             | CE                                     | A ←A+n+CY                                                 | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
| Бо       | SUB r                         | 10 010 rrr                             | 90 + r                                 | A ←A−r                                                    | *  | *                | *   | *      | *           | 1              | 4           |                          |          |
| 5        | SUB M                         | 10 010 110                             | 96                                     | A ←A-(HL)                                                 | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
| au       | SUI n                         | 11 010 110                             | D6                                     | A ←A−n                                                    | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
|          | SBB r                         | 10 011 rrr                             | 98 + r                                 | A ←A-r-CY                                                 | *  | *                | *   | *      | *           | 1              | 4           |                          |          |
| let      | SBB M                         | 10 011 110                             | 9E                                     | A ←A – (HL) – CY                                          | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
| thu      | SBI n                         | 11 011 110                             | DE                                     | A ←A-n-CY                                                 | *  | *                | *   | *      | *           | 2              | 7           |                          |          |
|          | ANA r                         | 10 100 rrr                             | A0 + r                                 | A ←A∧r                                                    |    | *                | *   | *      | 1           | 1              |             |                          |          |
| L a      | ANA M                         | 10 100 110                             | A6                                     | A ←A∧(HL)                                                 | 0  | *                | *   | *      | 1           | 2              | 7           |                          |          |
| l iq     | ANI n                         | 11 100 110                             | E6                                     | A ←A∧n                                                    | 0  | *                | *   | *      | 1           | 2              | 7           |                          |          |
| <b>∞</b> |                               | nn nnn nnn                             | n                                      | A / A1/-                                                  |    | <u>.</u>         |     |        |             |                |             |                          |          |
|          | ORA M                         | 10 110 110                             | 80 + r<br>86                           | IA ←AVr<br>Δ ←ΔV/(HL)                                     | 0  | *                | *   | *      | 0           | 1              | 4           |                          |          |
| 1        | ORI n                         | 11 110 110                             | F6                                     | A ←A∨n                                                    | 0  | *                | *   | *      | 0           | 2              | ····'.<br>7 |                          |          |
|          |                               | nn nnn nnn                             | n                                      |                                                           |    |                  |     |        |             |                |             |                          |          |
| 1        | XRA r                         | 10 101 rrr                             | A8 + r                                 | A ←A∀r                                                    | 0  | *                | *   | *      | 0           |                | 4           |                          |          |
| L        | L'UNA INI                     | 1.0 101 110                            | 105                                    |                                                           | U  | : <sup>-</sup> . |     |        | . U         | 4              | 1 /         | 1                        |          |

# TLCS-85 List of Machine Instruction (1/2)

# TLCS-85 List of Machine Instruction (2/2)

| Σ               |            | OBJECT                   | CODE            |                                                              |          | c            |                | c              |                |          | Γ.            |            |     |               |
|-----------------|------------|--------------------------|-----------------|--------------------------------------------------------------|----------|--------------|----------------|----------------|----------------|----------|---------------|------------|-----|---------------|
| ~/ <del>-</del> | ASSEMBLER  | BIN                      | HEX             | FUNCTION                                                     |          | r            | LAG            | 2              |                | λCL      | TAT           |            |     |               |
| CLA             | MINEMIONIC | 76 543 210               |                 |                                                              | CY       | z            | s              | Ρ              | AC             |          | S             |            |     |               |
| -               | XRI n      | 11 101 110               | EE              | A←A∀n                                                        | 0        | *            | *              | *              | 0              | 2        | 7             |            |     |               |
| 0.2             | CMP r      | nn nnn nnn<br>10 111 rrr | n<br>B8±r       | A.r                                                          | *        | *            | *              | *              | *              | <u>.</u> |               |            |     |               |
| l oc            | CPM M      | 10 111 110               | BE              | A-(HL)                                                       | *        | *            | *              | *              | *              | 2        | 7             |            |     |               |
| m q p           | CPI n      | 11 111 110               | FE              | A-n                                                          | *        | *            | *              | *              | *              | 2        | 7             |            |     |               |
| art             | INP        | nn nnn nnn               | n<br>04 - a × 9 | 0.001                                                        |          |              |                | *              | •              |          |               |            |     |               |
| a<br>           | INR M      | 00 110 100               | 34              | [ 9                                                          | -        | *            | *              | *              | *              | 3        | 10            |            |     |               |
| bit             | DCR g      | 00 ggg 101               | 05 + g × 8      | g ←g-1                                                       | -        | *            | *              | *              | *              | . 1      | 4             |            |     |               |
| ∞<br>—          | DCR M      | 00 110 101               | 35              | (HL)←(HL)-1                                                  | -        | *            | *              | *              | *              | 3        | 10            | ĺ          |     |               |
|                 | CMA        | 00 101 111               | 2F              | A←NOT A                                                      | -        | -            | _              |                | -              | !<br>  1 | 4             |            |     |               |
|                 | CMC        | 00 111 111               | 3F              | CY←NOT CY                                                    | *        | <del>.</del> | -              | -              | -              | 1        | 4             | l          |     |               |
| â               | STC        | 00 110 111               | 37              | CY←1                                                         | 1        | <del>.</del> |                | ļ <del>.</del> |                | 1        | . 4           | l          |     |               |
|                 | HIT        | 01 110 110               | 76              | MPU halt                                                     |          | <u>.</u>     | <u></u>        | ÷              | <u>.</u>       | <u>1</u> | 4             | l          |     |               |
|                 | DI         | 11 110 011               | F3              | INTE F/F Reset                                               | -        | -            | -              | -              | -              | 1        | 4             |            |     |               |
|                 | El         | 11 111 011               | FB              | INTE F/F Set                                                 | -        | -            | -              |                | -              | 1        | 4             |            |     |               |
|                 | DAD t      | 00 tt1 001               | 09 + t × 10     | HL←HL+t                                                      | **       |              |                | ļ              |                | .3       | 10            | 1          |     |               |
| ) ů             | DCX t      | 00 tt1 011               | 0B + t × 10     | t ←t+1                                                       |          | 1-2-         | -              | 1              | 12             | 1        | <u>0</u><br>6 |            |     |               |
|                 |            |                          |                 |                                                              |          |              |                |                |                |          |               |            |     |               |
|                 | RLC        | 00 000 111               | 07              |                                                              | *        | -            | -              | -              | -              | 1        | 4             |            |     |               |
| 1±              |            |                          |                 | A                                                            |          |              |                |                |                |          |               | l l        |     |               |
| <sup>d</sup>    | RAL        | 00 010 111               | 17              | CY ← 7 ← 0 ←                                                 | *        | -            | -              | -              | -              | 1        | 4             |            |     |               |
| an              |            |                          |                 | Α                                                            |          |              | ļ              | ļ              | ļ              |          |               | l l        |     |               |
| te              | RRC        | 00 001 111               | OF              | $7 \rightarrow 0$ $(Y)$                                      | *        | _            | _              | _              | _              | 1        | ۵             | l l        |     |               |
| ota             |            |                          |                 |                                                              |          |              |                |                |                |          | ,             | l          |     |               |
| Å               |            |                          |                 |                                                              |          |              |                |                |                |          |               |            |     |               |
|                 | RAR        | 00 011 111               | 1F              |                                                              | *        | -            | -              | -              | -              | 1        | 4             |            |     |               |
|                 | JMP mn     | 11 000 011               | C3              | PC ←mn                                                       | -        | -            |                | -              | -              | 3        | 10            |            |     |               |
|                 |            | nn nnn nnn               | n               |                                                              |          |              |                |                |                |          |               | l l        |     |               |
|                 | lic mp     |                          | m<br>(7+C×8     | IF or is true PC-mn                                          |          | ļ            | }              |                |                |          | 10            |            |     | Condition     |
| L L             |            | nn nnn nnn               | n               | otherwise, PC←PC+3                                           |          | 12           |                | :              | 12             | 2        | 7             | 000        | NZ  | no zero       |
| etu             |            | mmmmmmm                  | m               |                                                              |          |              |                | <u>.</u>       | <u>.</u>       |          |               | 001        | z   | zero          |
| -               | PCHL       | 11 101 001               | E9              | PC ←HL                                                       |          | <del>.</del> | ; <del>.</del> |                | <del>.</del>   | 1        | 6             | 010        | NC  | no carry      |
| anc             | CALL IND   |                          | n               | $(3r - 1)(3P - 2) \leftarrow PC,$<br>SP $\leftarrow$ SP - 2, | -        | -            | -              | -              | -              | 2        | 18            | 100        | PO  | parity odd    |
| =               |            | mmmmmmmm                 | m               | PC ←mn                                                       |          |              |                | <u>.</u>       |                |          |               | 101        | PE  | parity even   |
| ca              | Cc mn      | 11 ccc 100               | C4 + c × 8      | IF c is ture, (SP - 1)(SP - 2)                               | -        | -            | -              | -              | -              | 5        | 18            | 110        | P   | sign positive |
| pu              |            | nn nnn nnn<br>mmmmmmmm   | m               | $\leftarrow$ rc, SP $\leftarrow$ SP - 2, PC $\leftarrow$ mn  |          |              |                |                |                | 2        |               | 111        | N I | sign negative |
| ° °             | RET        | 11 001 001               | C9              | PC←(SP + 1)(SP),                                             | -        | -            |                | -              | -              | 3        | 10            |            |     |               |
| ۲<br>۳          |            |                          |                 | SP←SP + 2                                                    | <b>.</b> | ļ            |                |                |                |          |               |            | I   |               |
| 1-              | Rc         | 11 ccc 000               | C0 + C × 8      | IF c is true, PC←(SP + 1)(SP),                               | -        | -            | -              | -              | -              | 3        | 12            | kkk<br>000 | L I | -             |
| 1               |            |                          |                 | otherwise, PC←PC+1                                           |          | -            | -              |                | -              | 1        | 6             | 000        | 1   |               |
|                 | RST j      | 11 kkk 111               | C7 + k × 8      | (SP – 1)(SP – 2)←PC,                                         | -        | -            | -              | -              | -              | 3        | 12            | 010        | 2   |               |
|                 | 101        | 11.011.011               |                 | SP←SP - 2, PC←kkk×8                                          |          | :            | <u>.</u>       | ļ              |                |          |               | 011        | 3   |               |
|                 |            |                          | n               | A ←(n)                                                       | -        | -            | -              | -              | -              | 3        | 10            | 100        | 4   |               |
| P)              | OUT n      | 11 010 011               | D3              | (n) ←A                                                       | -        | -            | -              | <br>. –        | -              | 3        | 10            | 110        | 6   |               |
| L               |            | nn nnn nnn               | n               |                                                              |          |              |                |                |                |          |               | 111        | 7   |               |
| (e)             | RIM<br>SIM | 00 100 000               | 20              | A ←IM<br>M ←Δ                                                |          | <del>.</del> |                |                | ļ <del>.</del> | 1        | 4             |            |     | 050489        |
|                 | 1.5000     | 000 110 000              | 1.30            | 1                                                            |          |              |                |                |                | <u> </u> | 4             | i i        |     |               |

Note: "POP PSw" instruction changes state of flags.

(a) Exechange (b) General purpose arithmetic and MPU control (c) 16bit arithmetic (d) Input and output (e) Interrupt

# TOSHIBA

# 12. ELECTRICAL CARACTERISTICS

#### 12.1 ABSOLUTE MAXIMUM RATINGS

| Symbol  | ltem                  | Ratings        | Units |
|---------|-----------------------|----------------|-------|
| VCC     | VCC Supply voltage    | - 0.5 to + 7.0 | V     |
| PD      | Power Dissipation     | 1.5            | W     |
| Tsolder | Soldering Temperature | 260 (10 sec)   | °C    |
| Tstg    | Storage Temperature   | – 55 to 150    | °C    |
| Topr    | Operating Temperature | 0 to 70        | °C    |

050489

#### 12.2 DC CHARACTERISTICS

# TA = 0°C to 70°C, VCC = 5V ± 5% : TMP8085AP-2 VCC = 5V ± 10% : TMP8085AHP-2

| Symbol | Parameter                | Test Conditions           | Min.  | Max.      | Units |
|--------|--------------------------|---------------------------|-------|-----------|-------|
| VIL    | Input Low Voltage        |                           | - 0.5 | 0.8       | V     |
| VIH    | Input High Voltage       |                           | 2.0   | VCC + 0.5 | V     |
| VOL    | Output Low Voltage       | IOL = 2mA                 |       | 0.45      | V     |
| VOH    | Output High Voltage      | IOH = - 400µA             | 2.4   |           | V     |
| ICC    | Power Supply Current     | TMP8085AP/AP-2            |       | 170       | mA    |
|        |                          | TMP8085AHP/AHP-2          |       | 135       |       |
| IIL    | Input Leakage            | $0 \le VIN \le VCC$       |       | ± 10      | μA    |
| ILO    | Output Leakage           | $0.45 \leq VOUT \leq VCC$ |       | ±10       | μA    |
| VILR   | Input Low Level (RESET)  |                           | - 0.5 | 0.8       | V     |
| VIHR   | Input High Level (RESET) |                           | 2.4   | VCC + 0.5 | V     |
| VHY    | Hysteresis (RESET)       |                           | 0.25  |           | V     |

# 12.3 AC CHARACTERISTICS

 $TA = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%$  : TMP8085AP-2

VCC = 5V ± 10% : TMP8085AHP-2

#### Vss = 0V, unless otherwise noted.

| Symbol | Parameter                                             | Min.      | Max. | Units    |
|--------|-------------------------------------------------------|-----------|------|----------|
| tCYC   | CLK Cycle Period                                      | 200       | 2000 | ns       |
| tL     | CLK Low Time                                          | 40        |      | ns       |
|        |                                                       | 50*       |      | ns       |
| tH     | CLK High Time                                         | 70<br>80* |      | ns<br>ns |
| tr, tf | CLK Rise and Fall Time                                |           | 30   | ns       |
| tXKR   | X1 Rising to CLK Rising                               | 30        | 100  | ns       |
| tXKF   | X1 Rising to CLK Falling                              | 30        | 110  | ns       |
| tAC    | A8-15 Valid to Leading Edge of Control [1]            | 115       |      | ns       |
| tACL   | A0-7 Valid to Leading of Control                      | 115       |      | ns       |
| tAD    | A0-15 Valid to Valid Data In                          |           | 350  | ns       |
| tAFR   | Address Float after Leading Edge of ALE READ<br>(INT) |           | 0    | ns       |
| tAL    | A8-15 Valid before Trailing Edge of ALE [1]           | • 50      |      | ns       |
| tALL   | A0-7 Valid before Trailing Edge of ALE                | 50        |      | ns       |
| tARY   | READY Valid from Address Valid                        |           | 100  | ns       |
| tCA    | Address (A8-15) Valid after Control                   | 60        |      | ns       |
| tCC    | Width of Control Low (RD, WR, INTA) Edge of<br>ALE    | 230       |      | ns       |
| tCL    | Trailing Edge of Control to Leading Edge of ALE       | 25        |      | ns       |
| tDW    | Data Valid to Trailing Edge of WRITE                  | 230       |      | ns       |
| tHABE  | HLDA to Bus Enable                                    |           | 150  | ns       |
| tHABF  | Bus Float after HLDA                                  |           | 150  | ns       |
| tHACK  | HLDA Valid to Trailing Edge of CLK                    | 40        |      | ns       |
| tHDH   | HOLD Hold Time                                        | 0         |      | ns       |
| tHDS   | HOLD Setup Time to Trailing Edge of CLK               | 120       |      | ns       |
| tINH   | INTR Hold Time                                        | 0         |      | ns       |
| tINS   | INTR, RST and TRAP Setup Time to Falling              | 150       |      | ns       |
| tLA    | Edge of CLK Address Hold Time after ALE               | 50        |      | ns       |
| tLC    | Trailing Edge of ALE to Leading Edge of Control       | 60        |      | ns       |
|        |                                                       |           |      | 050489   |

| Symbol | Parameter                                                | Min. | Max. | Units  |
|--------|----------------------------------------------------------|------|------|--------|
| tLCK   | ALE Low during CLK High                                  | 50   |      | ns     |
| tLDR   | ALE to Valid Data during Read                            |      | 270  | ns     |
| tLDW   | ALE to Valid Data during Write                           |      | 120  | ns     |
| tLL    | ALE Width                                                | 80   |      | ns     |
| tLRY   | ALE to READY Stable                                      |      | 30   | ns     |
| tRAE   | Trailing Edge of READ to Re-Enabling of Address          | 90   |      | ns     |
| tRD    | READ (or INTA) to Valid Data                             |      | 150  | ns     |
| tRV    | Control Trailing Edge of Leading Edge of Next<br>Control | 220  |      | ns     |
| tRDH   | Data Hold Time After READ INTA                           | 0    |      | ns     |
| tRYH   | READY Hold Time                                          | 0    |      | ns     |
| tRYS   | READY Setup Time to Leading Edge of CLK                  | 100  |      | ns     |
| tWD    | Data Valid After Trailing Edge of WRITE                  | 60   |      | ns     |
| tWDL   | LEADING Edge of WRITE to Data Valid                      |      | 20   | ns     |
|        |                                                          |      |      | 050489 |

Test conditions CL = 150pF (\*: CL = 50pF + 1TTL) tcyc = 200ns

Notes : 1. A8-15 address specs apply to IO/M, S0 and S1 expect A8-15 are undifiend during T4-T6 of Cycle whereas IO/M, S0, and S1 are stable.

2. Timing defining signal voltage are;

- Output High level = 2.0V, Low level = 0.8V
- 3. To calculate timing specifications at other value of tCYC use Table 12.1.

# TOSHIBA

TMP8085A

### 12.4 TIMING WAVEFORMS

















Figure 12.4 Read Operation with Wait Cycle (Typical) - Same Ready Timing Applied to Write Operation





# 13. OUTLINE DRAWING (40PINS PLASTIC PACKAGE)

DIP40-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoritical positions with respect to No.1 and No.40 leads.

# TMP8155P-2/TMP8156P-2

# 256 BYTE STATIC RAM WITH I/O PORTS AND TIMER

# 1. GENERAL DESCRIPTION

The TMP8155/8156P-2 are RAM including I/O ports and counter/timer on one chip for using in the TLCS-85A microcomputer system. The RAM portion is designed with 2K bit static memory cells organized as 256 x 8. The 14 bit programmable counter/timer is the down counter. It provides either a square wave terminal count pulse for the MPU system depending on timer mode.

The I/O portion consists of 2 programmable 8 bit I/O ports and 1 programmable 6 bit I/O port. The programmble I/O ports can be operated by BASIC MODE and STROBE MODE.

## 2. FEATURES

- Single + 5V Power supply
- Access Time: 330 ns
- Internal Address Latch
- 2 Programmable 8 bit I/O Ports and 1 Programmable 6 bit I/O Port
- 256 x 8 bit RAM
- Programmable 14 bit Binary Counter/Timer
- Multiplexed Address/Data Bus
- Chip Enable Active High (TMP8156P-2) or Low (TMP8155P-2)
- 40 pin DIP

050489

# 3. PIN CONNECTION (TOP VIEW)



Figure 3.1

Note: \* TMP8155 =  $\overline{CE}$ TMP8156 = CE

4. BLOCK DIAGRAM





MPU85-27

# 5. PIN NAMES AND PIN DESCRIPTION

RESET (INPUT)

The Reset signal is a pulse provided by TMP8085A to initialize the system. Input high on this line resets the chip and initializes the internal three I/O ports to input mode.

The width of RESET pulse should typically be two clock cycles of TMP8085A.

AD <sub>0~7</sub> (INPUT/OUTPUT, 3-STATE)

These are 3-state Address/Data lines that interface with the MPU lower 8-bit Address/Data Bus. The 8-bit address can be applied to the memory section or the I/O section depending on the polarity of the  $IO/\overline{M}$  input signal. 8-bit data is either written into or read from the TMP8155/8156 depending on the status of  $\overline{WR}$  or  $\overline{RD}$  input signal.

• CE OR  $\overline{CE}$  (INPUT)

Chip Enable : On the TMP8155P-2, this pin is  $\overline{\text{CE}}$  and is Active Low. On The TMP8156P-2, this pin is CE and is Active High.

• RD (INPUT)

Input low on this line with the Chip Enable active enables the  $AD_{0\sim7}$  buffers. If  $IO/\overline{M}$  pin is low, the RAM content will be read out from the  $AD_{0\sim7}$  bus. Otherwise the content of the selected I/O port or command/status register will be read out from the  $AD_{0\sim7}$  bus.

•  $\overline{WR}$  (INPUT)

Input low on this line with the active CE/ $\overline{CE}$  causes the data on the AD<sub>0~7</sub> lines to be written to the RAM or I/O ports and command/status register depending on the polarity of IO/ $\overline{M}$ .

• ALE (INPUT)

Address Latch Enable : This control signal latches both the data on the  $AD_{0\sim7}$  lines and the state of the Chip Enable and  $IO/\overline{M}$  into the chip at the falling edge of ALE.

• IO/M (INPUT)

IO/Memory Select : This line selects the memory if low and selects the I/O or command/status register if high.

•  $PA_{0\sim7}$  (INPUT/OUTPUT, 3-STATE)

These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command Register.

# TOSHIBA

• PB<sub>0~7</sub> (INPUT/OUTPUT, 3-STATE)

These 8 pins are general purpose I/O pins. The in/out direction is selected by programming the Command Register.

• PC <sub>0~5</sub> (INPUT/OUTPUT, 3-STATE)

These 6 pins can function as either input port, output port, or as control signal for PA and PB. Programming is done through the Command Register.

When PC  $_{0\sim5}$  are used as control signals, they are defined as the following :

PC0 - A INTR (Port A Interrupt) PC1 - A BF (Port A Buffer Full) PC2 - A STB (Port A Strobe) PC3 - B INTR (Port B Interrupt) PC4 - B BF (Port B Buffer Full) PC5 - B STB (Port B Strobe)

• TIMER IN (INPUT)

This is the input to the counter-timer.

• TIMEROUT (OUTPUT)

This pin is the timer output. This output can be either a square wave or a pulse depending on the timer mode.

- VCC (Power)
  - +5 volt supply
- VSS (Power) Ground Reference

# TOSHIBA

050489

# 6. FUNCTIONAL DESCRIPTION

#### 6.1 PROGRAMMING THE COMMAND REGISTER

The command register consists of either latches. Four bits (0-3) define the mode of the ports, two bits (4-5) enable or disable the interrupt from port C when is acts as control port, and the last two bits (6-7) are for the timer.

The command register contents can be altered at any time by using the I/O address XXXX000 during a WRITE operation. The functions of each bit of the command register is shown in Figure 6.1

Note that the command register is a write-only register and can not be read.





MPU85-30

#### 6.2 READING THE STATUS REGISTER

The status register consists of seven latches, one for each bit; six (0-5) for the status of the ports and one (6) for the status of the timer.

The status of the timer and the I/O section can be polled by reading the Status Register (Address XXXX000). Status word format is shown in Figure 6.2.



Figure 6.2 Status Register Bit Assignment

#### 6.3 I/O SECTION

- COMMAND/STATUS REGISTER (C/S) Both registers have the same address XXXXX000. When the C/S registers are selected during WRITE operation, a command is written into the C/S Register. The contents of this register are not accessible through the pins. When the C/S is selected during a READ operation, the status information of the I/O ports and the timer becomes available on the  $AD_{0\sim7}$  lines.
- PA Register This register can be programmed to be either input or output ports depending on the status of the contents of the C/S Register. Also depending on the command, this port can operate in either the basic mode or the strobed mode (See timing diagram). The I/O pins assigned in relation to this register are PA<sub>0-7</sub>. The address of this register is XXXXX001.
- PB Register This register functions the same as PA Register. The I/O pins assigned are PB<sub>0-7</sub>. The address of this register is XXXXX010.
- PC Register This register has the address XXXXX011 and contains only 6-bits. The 6-bits can be programmed to be either input ports, output ports or as control signals for PA and PB by properly programming the AD<sub>2</sub> and AD<sub>3</sub> bits of the C/S Register.

When  $PC_{0-5}$  is used as a control port, 3-bits are assigned for Port A and 3 for Port B. The first bit is an interrupt that the TMP8155/8156 issues. The second is an output signal indicating whether the buffer is full or empty, and the third is an input pin to accept a strobe for the strobed input mode. See Table 6.2.

When the port C is programmed to either MODE 3 or MODE 4, the control signals for PA and PB are initialized as follows :

| CONTROL<br>MODE | BF             | INTR | STB           |  |  |
|-----------------|----------------|------|---------------|--|--|
| INPUT MODE      | Low            | Low  | Input Control |  |  |
| OUTPUT MODE     | UTPUT MODE Low |      | Input Control |  |  |

To summarize, the register's address assignments are shown in Table 6.1.

|    | I / O ADDRESS  |                |                |                |                |                |                |                                 |                                                         |             |
|----|----------------|----------------|----------------|----------------|----------------|----------------|----------------|---------------------------------|---------------------------------------------------------|-------------|
| A7 | A <sub>6</sub> | A <sub>5</sub> | A <sub>4</sub> | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> |                                 | SELECTION                                               | NO. OF BITS |
| Х  | X              | X              | x              | X              | 0              | 0              | 0              | Internal                        | nternal Command / Status Register                       |             |
| X  | X              | X              | Х              | X              | 0              | 0              | 1              | PA <sub>0-7</sub>               | General Purpose I / O Port A                            | 8           |
| Х  | X              | x              | х              | x              | 0              | 1              | 0              | PB <sub>0-7</sub>               | PB <sub>0-7</sub> General Purpose I / O Port B          |             |
| Х  | Х              | X              | х              | х              | 0              | 1              | 1              | PC <sub>0-7</sub>               | PC <sub>0-7</sub> General Purpose I / O Port or Control |             |
| Х  | х              | x              | Х              | х              | 1              | 0              | 0              | Low-Order 8 bits of Timer Count |                                                         |             |
| х  | X              | х              | х              | X              | 1              | 0              | 1              |                                 | High 6 bits / 2 bits of Timer Count                     |             |

## Table 6.1 I/O Port Addressing Scheme

050489

Table 6.2 Port Control Assignment

| Pin | MODE 1     | MODE 2      | MODE 3                    | MODE 4                    |
|-----|------------|-------------|---------------------------|---------------------------|
| PC0 | Input Port | Output Port | A INTR (Port A Interrupt) | A INTR (Port A Interrupt) |
| PC1 | Input Port | Output Port | A BF (Port A Buffer Full) | A BF (Port A Buffer Full) |
| PC2 | Input Port | Output Port | A STB (Port A strobe)     | A STB (Port A strobe)     |
| PC3 | Input Port | Output Port | Output Port               | B INTR (Port B Interrupt) |
| PC4 | Input Port | Output Port | Output Port               | B BF (Port B Buffer Full) |
| PC5 | Input Port | Output Port | Output Port               | B STB (Port B strobe)     |

### TOSHIBA

#### 6.4 TIMER SECTION

The timer is a 14-bit down-counter that counts the 'timer input' pulses and provides either a square wave or pulse when terminal count (TC) is reached.

The timer has I/O address XXXXX100 for the low order byte of the register and the I/O address XXXXX101 for the high order of the register.

To program the timer, the COUNT LENGTH REGISTER is loaded first, one byte at a time, by selecting the timer addresses. Bits 0-13 will specify the length of the next count and bits 14-15 will specify the timer output mode. The value loaded into the count length register can have any value from 2H through 3FFFH in bits 0-13.

| M <sub>2</sub> M <sub>1</sub> |                | T <sub>13</sub> | T <sub>12</sub> | T <sub>11</sub> | T <sub>10</sub> | T9             | Т8 |
|-------------------------------|----------------|-----------------|-----------------|-----------------|-----------------|----------------|----|
| TIMER MODE                    |                | N               | ASB OF          | COUNT           | LENGT           | H              |    |
| T <sub>7</sub>                | T <sub>6</sub> | T <sub>5</sub>  | T4              | T <sub>3</sub>  | T2              | T <sub>1</sub> | To |

LSB OF COUNT LENGTH

050489

#### Figure 6.3 Timer Format

There are four timer modes which are defined by M2 and M1.

#### M2 M1

0 0 — Put out low during second half of count.

- 0 1 ——— Continuous square wave; The period of the square-wave equals the count length programmed with automatic reload at terminal count.
- 1 0 ——— Single pulse upon TC being reached.
- 1 1 —— Continuous pulses.
- Note: In case of an odd-numbered count, the first half-cycle of the square-wave output, which is high, is one count longer than the second (low) half-cycle as shown in Figure 6.3.



Figure 6.3 Asymmetrical Square-Wave Output resulting from Count 5

Bits 6-7 (TM2 and TM1) of command register contents are used to start and stop the counter. There are four commands to choose from;

| TM2 | TM1 |                                                                                                                                                                                                                        |
|-----|-----|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0   | 0   | NOP : Do not affect counter operation.                                                                                                                                                                                 |
| 0   | 1   | STOP : NOP if timer has not started; stop counting if the timer is running.                                                                                                                                            |
| 1   | 0   | STOP AFTER TC : Stop immediately after present TC is reached.<br>(NOP if timer has not started)                                                                                                                        |
| 1   | 1   | START : Load mode and count length and start immediately after<br>loading (if timer is not presently running).<br>If timer is running, start the new mode and count length<br>immediately after present TC is reached. |

Note that while the counter is counting, a new count and mode can be loaded into the count length registers. Before the new count and mode will be used by the counter, a START command should be issued to the counter. This applies even though only the change of the count is required in the previous (same) mode.

The counter in the TMP8155/8156 is not initialized to any particular mode or count when hardware RESET occurs, but RESET does stop the counting.

Therefore a START command must be issued via the C/S register, because counting cannot begin following RESET.

Note that the timer circuit on the TMP8155/8156 chip is designed to be a square-wave timer, not an event counter. To achieve this, it counts down by two twice in completing one cycle. Thus, its registers do not contain values directly representing the number of TIMER IN pulses received. Counter value '1' can't be loaded as the initial value into the count register because the timer operates as its terminal count value is 10 (binary). After the timer has started counting down, the values residing in the count registers can be used to calculate the actual number of TIMER IN pulses required to complete the timer cycle if desired. To obtain the remaining count, the following operations should be done in order :

- 1. Stop the count.
- 2. Read in the 16-bit value from the count length registers.
- 3. Reset the upper two mode bits.
- 4. Reset the carry and rotate right one position all 16 bits through carry.
- 5. If carry is set, add 1/2 of the full original count (1/2 full count<sup>-1</sup> if full count is odd.)
- Note: When the initial count value is odd and the third count pulse has not come yet, it will be unknown whether one or two counts has occurred. Regardless of this, the TMP8155/8156 always counts out the right number of pulses in generating the TIMEROUT waveforms.

# 7. ELECTRICAL CHARACTERISTICS

## 7.1 ABSOLUTE MAXIMUM RATINGS

| Symbol              | ltem                                           | Rating         | Units  |
|---------------------|------------------------------------------------|----------------|--------|
| Vcc                 | $V_{CC}$ Supply Voltage with Respect to Vss    | – 0.5 to + 7.0 | V      |
| PD                  | Power Dissipation                              | 1.5            | W      |
| T <sub>SOLDER</sub> | Soldering Temperature (Soldering Time 10 sec.) | 260            | °C     |
| T <sub>STG</sub>    | Storage Temperature                            | – 55 to + 150  | °C     |
| T <sub>OPR</sub>    | Operating Temperature                          | 0 to +70       | °C     |
|                     |                                                |                | 050489 |

### 7.2 D.C. CHARACTERISTICS

| Symbol               | Parameter                           | Test Conditions                          | Min.  | Max.                  | Units    |
|----------------------|-------------------------------------|------------------------------------------|-------|-----------------------|----------|
| VIL                  | Input Low Voltage                   |                                          | - 0.5 | 0.8                   | V        |
| V <sub>IH</sub>      | Input High Voltage                  |                                          | 2.0   | V <sub>CC</sub> + 0.5 | V        |
| V <sub>OL</sub>      | Output Low Voltage                  | I <sub>OL</sub> = 2mA                    | -     | 0.45                  | V        |
| V <sub>OH</sub>      | Output High Voltage                 | I <sub>OH</sub> = - 400µА                | 2.4   | -                     | V        |
| ۱ <sub>۱L</sub>      | Input Leakage                       | V <sub>IN</sub> = V <sub>CC</sub> to 0V  | -     | ± 10                  | μA       |
| ILO                  | Output Leakage Current              | $0.45V \le V_{OUT} \le V_{CC}$           | -     | ± 10                  | μA       |
| lcc                  | V <sub>CC</sub> Supply Current      |                                          | -     | 180                   | mA       |
| I <sub>IL</sub> (CE) | Chip Enable Leakage<br>8155<br>8156 | V <sub>IN</sub> = V <sub>CC</sub> to 0V. | _     | + 100<br>- 100        | µА<br>µА |

# $TA = 0^{\circ}C \text{ to } + 70^{\circ}C, V_{CC} = +5V \pm 5\%$

### 7.3 A.C. CHARACTERISTICS

 $TA = 0^{\circ}C \text{ to } + 70^{\circ}C, V_{CC} = +5V \pm 5\%$ 

| Symbol                         | Parameters                                             | Min. | Max. | Units |
|--------------------------------|--------------------------------------------------------|------|------|-------|
| t <sub>AL</sub>                | Address to Latch Setup Time                            | 30   |      | ns    |
| t <sub>LA</sub>                | Address Hold Time after Latch                          | 30   | -    | ns    |
| t <sub>LC</sub>                | Latch to READ / WRITE Control                          | 40   | -    | ns    |
| t <sub>RD</sub>                | Valid Data out Delay from READ Control                 | -    | 140  | ns    |
| t <sub>AD</sub>                | Address Stable To Data Out Valid                       | _    | 330  | ns    |
| t <sub>LL</sub>                | Latch Enable Width                                     | 70   | -    | ns    |
| t <sub>RDF</sub>               | Data Bus Float after READ                              | 0    | 80   | ns    |
| t <sub>CL</sub>                | READ / WRITE Control Latch Enable                      | 10   |      | ns    |
| t <sub>CC</sub>                | READ / WRITE Control Width                             | 200  |      | ns    |
| t <sub>DW</sub>                | Data in to WRITE Setup Time                            | 100  |      | ns    |
| t <sub>WD</sub>                | Data in Hold Time After WRITE                          | 0    | -    | ns    |
| t <sub>RV</sub>                | Recovery Time Between Controls                         | 200  |      | ns    |
| t <sub>WP</sub>                | WRITE to Port Output                                   | -    | 300  | ns    |
| t <sub>PR</sub>                | Port Input Setup Time                                  | 50   | -    | ns    |
| t <sub>RP</sub>                | Port Input Hold Time                                   | 10   |      | ns    |
| t <sub>SBF</sub>               | Strobe to Buffer Full                                  | -    | 300  | ns    |
| tss                            | Strobe Width                                           | 150  | -    | ns    |
| t <sub>RBE</sub>               | READ to Buffer Empty                                   | -    | 300  | ns    |
| t <sub>SI</sub>                | Strobe to INTR On                                      | -    | 300  | ns    |
| t <sub>RDI</sub>               | Strobe to INTR Off                                     | -    | 300  | ns    |
| tpss                           | Port Setup Time to Strobe                              | 20   |      | ns    |
| t <sub>PHS</sub>               | Port Hold Time after Strobe                            | 100  |      | ns    |
| t <sub>SBE</sub>               | Strobe to Buffer Empty                                 | -    | 300  | ns    |
| t <sub>WBF</sub>               | WRITE to Buffer Full                                   |      | 300  | ns    |
| t <sub>WI</sub>                | WRITE to INTR Off                                      | -    | 300  | ns    |
| t <sub>TL</sub>                | TIMER-IN to TIMEROUT Low                               |      | 300  | ns    |
| t <sub>TH</sub>                | TIMER-IN to TIMEROUT High                              | -    | 300  | ns    |
| t <sub>RDE</sub>               | Data Bus Enable from READ Control                      | 10   | _    | ns    |
| tL                             | TIMER-IN Low Time                                      | 40   | -    | ns    |
| t <sub>H</sub>                 | TIMER-IN High Time                                     | 70   | —    | ns    |
| t <sub>CYC</sub>               | CLK Cycle Period                                       | 200  | -    | ns    |
| t <sub>r,</sub> t <sub>f</sub> | CLK Rise and Fall Time                                 | -    | 30   | ns    |
| t <sub>WT</sub>                | WRITE to TIMER-IN<br>(for writes which start counting) | 200  | -    | ns    |

230589

Notes: 1. Test conditions CL=150pF

2. Timing defining signal voltage are ; Output High level =2V, Low level=0.8V

# 8. TIMING WAVEFORMS







# 9. OUTLINE DRAWING (40Pins Plastic Package)

### DIP40-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoritical positions with respect to No. 1 and No. 40 leads.

# TMP82C51AP-2 / TMP82C51AP-10 TMP82C51AM-2 / TMP82C51AM-10

# PROGRAMMABLE COMMUNICATION INTERFACE

## 1. GENERAL DESCRIPTION

The TMP82C51A is the industry standard Universal Synchronous/Asynchronous Receiver/Transmitter (USART) that is fabricated using C-MOS silicon gate technology. The 82C51A is mainly used for 8-bit microcomputer extention system, which require serial data communications.

The TMP82C51AP-2/TMP82C51AP-10 is packaged in the 28 pin standard Dual Inline Package.

The TMP82C51AM-2/TMP82C51AM-10 is packaged in the 28 pin Small Out Line Package.

#### FEATURES

• Synchronous:

5-8 Bit Characters

Internal or External Character Synchronization Single or Double Character Synchronization (Inrternal) Automatic Sync Character(s) Insertion

• Asynchronous:

5-8 Bit Characters Clock Rate -1, 16 or 64 Times Transfer Rate Break Character Generation 1, 1.5 or 2 stop Bits False Start Bit Detection Automatic Break Detect and Handling

- Transfer Rate TMP82C51A-2 TMP82C51A-10
   DC-104K bps DC-300K bps
- Full-Duplex, Double-Buffered, Transmitter and Receiver
- Error DetectionParity, Overrun and Framing.
- Single +5V Supply:  $5V \pm 10\%$

050489

# 2. PIN CONNECTIONS



3. BLOCK DIAGRAM



### TOSHIBA

## 4. PIN NAMES AND PIN DESCRIPTIONS

#### 4.1 INTERFACE SIGNALS TO CPU (MAIN SYSTEM)

• D0-D7 (Input/Output)

This 3-state, bidirectional, 8-bit buffer is used to interface with the system Data Bus. Data is transmitted or received through the buffer upon execution of Input or Output Instructions of the CPU. Control Words, Command Words and Status Information are also transferred through the Data Bus Buffer.

• WR (Input)

A "low" level signal on this input informs the 82C51A that the CPU is Writing Data or Control Words to the 82C51A.

• RD (Input)

A "low" level signal on this input informs the 82C51A that the CPU is Reading Data or Status Information from the 82C51A.

•  $\overline{\text{CS}}$  (Input)

A "low" level signal on this input selects the 82C51A. No reading or writing operation will occur unless the device is selected. When  $\overline{CS}$  is "high" the Data Bus is in the floating state and  $\overline{RD}$  and  $\overline{WR}$  have no effect on the chip.

•  $C/\overline{D}$  (Input)

This input signal, in conjuction with the  $\overline{WR}$  and  $\overline{RD}$  inputs, informs the 82C51A that the word on the Data Bus is either a Data Bus Character, Control Word or Status Information. A "high" level signal means Control or Status, a "low" level signal means Data.

| C/D | RD | WR | CS |                                                   |
|-----|----|----|----|---------------------------------------------------|
| 0   | 0  | 1  | 0  | 82C51A Receive DATA Buffer $\rightarrow$ DATA Bus |
| 0   | 1  | 0  | 0  | 82C51A Transmit DATA Buffer 🔶 DATA Bus            |
| 1   | 0  | 1  | 0  | 82C51A Status DATA Buffer $\rightarrow$ DATA Bus  |
| х   | 1  | 1  | 0  | DATA Bus is in floating state.                    |
| X   | Х  | х  | 1  | DATA Bus is in floating state.                    |

#### • CLK (Input)

The CLK input is used to generate internal device timing. No external input or output referenced to CLK, but the frequency of CLK must be greater than 30 times the Receiver or Transmitter Data Bit Rates ( $\overline{RxC}$  or  $\overline{TxC}$ ) in Synchronous Operation, and greater than 4.5 times the Receiver Data Bit Rates ( $\overline{RxC}$  or Trransmitter,  $\overline{TxC}$ ) in Asynchronous operation.

## • RESET (Input)

A "high" level signal on this input forces the 82C51A into an "Idle" mode. The device will remain "Idle" until a new set of Control Words is written into the 82C51A to program its functional definition. Minimum RESET pulse width is 6 tcy.

## 4.2 MODEM CONTROL SIGNALS

• DSR (Input)

The  $\overline{\text{DSR}}$  input signal is a general purpose, 1-bit inverting input port. Its condition can be tested by the CPU using a Status Read Operation. The  $\overline{\text{DSR}}$  input is normally used to test MODEM conditions such as Data Set Ready signal.

• DTR (Output)

The DTR output signal is a general purpose, 1-bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction Words. The DTR output signal is normally used for MODEM control such as Data Terminal Ready or Rate Select signal.

• RTS (Output)

The RTS output signal is a general purpose, 1-bit inverting output port. It can be set "low" by pogramming the appropriate bit in the Command Instruction Word. The RTS output signal is normally used for MODEM control such as Request to Send signal.

• CTS (Input)

A "low" level signal on this input enables the 82C51A to transmit serial data, if the Tx Enable Bit in the Command Byte is set to a "one" (TxEN=1). If either a Tx Enable off (TxEN=0) or  $\overline{\text{CTS}}$  off (CTS=1) condition occurs while the Tx is in operaion, the Tx will transmit all the data in the USART, written prior to Tx Disable Command before shutting down.

### 4.3 TRANSMIT CONTROL SIGNALS

• TxC (Input)

The transmitter Clock controls the rate at which the character is to be transmitted. In the Synchronous Transmission Mode, the Transfer Rate (1x) is equal to the  $\overline{TxC}$  frequency. In Asynchronous Transmission Mode the transfer rate is a fraction of the actual  $\overline{TxC}$  ferquency. A portion of the Mode Instruction selects this factor; it can be 1, 1/16 or 1/64 the  $\overline{TxC}$ .
For Example:

If Transfer Rate equals 110 bps,

 $\overline{\text{TxC}} = 110 \text{ Hz} \qquad (1x)$  $\overline{\text{TxC}} = 1.76 \text{ kHz} \qquad (16x)$  $\overline{\text{TxC}} = 7.04 \text{ Hz} \qquad (64x)$ 

The falling edge of  $\overline{\text{TxC}}$  shifts the serial data out of the 82C51A.

• TxD (Output)

This line is used to transmit serial data. Serial output data on TxD is changed from parallel data to serial data in accordance with the TxD line will be held in the marking state ('1' level) immediately on one of the followings.

- Master Reset
- Tx Disable (TxEN = 0)
- CTS signal is high  $(\overline{\text{CTS}}=1)$
- TxEMPTY signal is high (TxEMPTY=1)

• TxRDY (Output)

This output informs the CPU that the transmitter is ready to accept a Data Character. The TxRDY output pin can be used as an interrupt to the system, since it is masked by Tx Disable (TxEN=0), or, for polled Operation, the CPU can check TxRDY using a Status Read Operation, TxRDY is automatically reset by the trailing edge of  $\overline{WR}$  when a Data Character is loaded from the CPU. The TxRDY pin output status (TxRDY (pin)) is different from the TxRDY status bit status register (TxRDY (status bit)) as follows.

TxRDY (status bit) = (Transmit Data Buffer Empty)

TxRDY (pin) = (Transmit Data Buffer Empty) AND ( $\overline{CTS} = 0$ ) AND (TxEN = 1)

TxEMPTY (Output)

The TxEMPTY output will go "high" when the 82C51A has no characters to send. It resets upon receiving a character from the CPU if the transmitter is enabled.

In Synchronous Mode, a "high" level signal on this output indicates that a Character has not been loaded and the SYNC Character or Characters are about to be or are being transmitted automatically as "fillers". TxEMPTY does not go "low" when the SYNC characters are being shifted out.

## 4.4 RECEIVE CONTROL SIGNALS

• RxC (Input)

The Receiver Clock controls the rate at which the character is to be received. In Synchronous Mode, the Transfer Rate (1x) is equal to the actual frequency of  $\overline{RxC}$ . In Asynchronous Mode, the Transfer Rate is a fraction of the actual  $\overline{RxC}$  frequency. A portion of the Mode Instruction selects this factor; 1, 1/16 or 1/64 the  $\overline{RxC}$ .

For Example:

If Transfere Rate equals 2400 bps,

 $\overline{\text{RxC}} = 2.4 \text{ kHz} \quad (1\text{x})$  $\overline{\text{RxC}} = 38.4 \text{ kHz} \quad (16\text{x})$  $\overline{\text{RxC}} = 153.6 \text{ kHz} \quad (64\text{x})$ 

RxC = 153.6 kHz (64x)

Data is sampled into the 82C51A on the rising edge of  $\overline{RxC}$ .

• RxD (Input)

This line is used to receive the serial data. Serial input data on this line is changed to parallel data in accordance with the format specified by the Control Words, and then transfered to the Receive Data Buffer.

• RxRDY (Output)

This output indicates that the 82C51A contains a Data Character that is ready to be input to the CPU. RxRDY can be connected to the interrupt structure of the CPU, or, for Polled Operation, the CPU can check the condition of RxRDY using Status Read Operation.

 $Rx\ Enable\ off\ both\ masks\ and\ holds\ RxRDY\ in\ the\ Reset\ Condition.$ 

• SYNDET/BD (Input/Output)

This pin is used for SYNDET in Synchronous Mode and may used as either input or output, programmable through the Control Word. It is reset to output mode "low" upon RESET. When used as an Output (Internal Sync Mode), the SYNDET pin will go "high" to indicate that the 82C51A has located the SYNC Character in the Receive Mode. If the 82C51A is programmed to use Double Sync Characters then SYDET will go "high" in the middle of the last bit of the second SYNC Character. SYNDET is automatically reset upon a Status Read Operation. When used as an Input (External Sync Mode), a positive going signal will cause the 82C51A to start assembling Data Characters on the rising edge of the next  $\overline{RxC}$ . In Asynchronous Mode this pin is used BD.

This output will go "high" whenever the receiver remains "low" through two consecutive Stop Bit Sequences (including the Start Bits, Data Bits, and parity bits). Break Detect may also be read as a Status Bit.

It is reset only upon a Master Chip Reset or Rx Data returning to a "one" state.

4.5 POWER SUPPLY

• VCC (Power)

+5 Volt supply

• GND (Power)

0 Volt supply

# 5. ELECTRICAL CHARACTERISTICS

### 5.1 MAXIMUM RATINGS

| Symbol            | ltem                                       | Rating                          |
|-------------------|--------------------------------------------|---------------------------------|
| V <sub>CC</sub>   | Power Supply Voltage (with respect to GND) | – 0.5V to 7.0V                  |
| VIN               | Input Voltage (with respect to GND)        | ~ 0.5V to V <sub>CC</sub> + 0.5 |
| Vout              | Output Voltage (with respect to GND)       | – 0.5V to V <sub>CC</sub> + 0.5 |
| PD                | Power Dissipation                          | 250mW                           |
| TSOLDER           | Soldering Temperature (10 sec)             | 260°C                           |
| T <sub>STG.</sub> | Storage Temperature                        | – 65°C to 150°C                 |
| T <sub>OPR.</sub> | Operating Temperature                      | – 40°C to 85°C                  |

#### 050489

### 5.2 D.C CHARACTERS

## Topr = $-40^{\circ}$ C to $+85^{\circ}$ C, VCC = $+5V \pm 10\%$ , GND = 0V, Unless otherwise noted.

| Symbol           | Parameter                                    | Test Conditions                                                     | Min.      | Тур. | Max.      | Units |
|------------------|----------------------------------------------|---------------------------------------------------------------------|-----------|------|-----------|-------|
| VIL              | Input Low Voltage                            |                                                                     | - 0.5     | -    | 0.8       | V     |
| VIH              | Input High Voltage                           |                                                                     | 2.2       | -    | VCC + 0.5 | V     |
| V <sub>OL</sub>  | Output Low Voltage                           | IOL = 2.2mA                                                         | -         | -    | 0.45      | V     |
| V <sub>OH1</sub> | Output High Voltage                          | IOH = -400µA                                                        | 2.4       | -    | -         | V     |
| V <sub>OH2</sub> | Output High Voltage                          | IOH = - 100µA                                                       | Vcc – 0.8 | -    | -         | V     |
| IOFL             | Output Leak Current                          | $0.45V \leq VOUT \leq VCC$                                          | -         | -    | ± 10      | μΑ    |
| IIL              | Input Leak Current                           | $0.45V \le VOUT \le VCC$                                            | -         | -    | ± 10      | μA    |
|                  | Power Supply Current<br>(AP-2/AM-2, 5MHz)    | tcyc = 200ns<br>Vin = 4.8V/0.2V                                     | -         | 1.2  | 5.0       | mA    |
| ICC1             | Power Supply Current<br>(AP-8/AM-8, 8MHz)    | tcyc = 125ns<br>Vin = 4.8V/0.2V                                     | -         | 2.0  | 10.0      | mA    |
|                  | Power Supply Current<br>(AP-10/AM-10, 10MHz) | tcyc = 100ns<br>Vin = 4.8V/0.2V                                     | -         | 2.5  | 15        | mA    |
| ICC2             | Power Supply Current<br>(Standby Mode)       | STOP All Clocks<br>VCC = 5V, $\overline{CS}$ = 1<br>Vin = 4.8V/0.2V | -         | 0.5  | 10.0      | μА    |

## 5.3 AC CHARACTERISTICS

Topr =  $-40^{\circ}$ C to  $85^{\circ}$ C, VCC = 5V  $\pm 10^{\circ}$ , GND = 0V, Unless otherwise noted.

## 5.3.1 Bus Read Cycle Timing Note 1)

| Symbol          | Parameter                                                            | Test                  | AP-2 / AM-2 |      | AP-10/ | Units |       |
|-----------------|----------------------------------------------------------------------|-----------------------|-------------|------|--------|-------|-------|
| Symbol          | Farameter                                                            | Conditions            | Min.        | Max. | Min.   | Max.  | Units |
| t <sub>AR</sub> | CS, C/D Set-up<br>Time for RD                                        |                       | 0           | -    | 0      | -     | nS    |
| t <sub>RA</sub> | $\overline{CS}$ , C/ $\overline{D}$ Hold<br>Time for $\overline{RD}$ |                       | 0           | -    | 0      | -     | nS    |
| t <sub>RR</sub> | RD Pulse Width                                                       |                       | 150         | -    | 120    | -     | nS    |
| t <sub>RD</sub> | Data Delay Time<br>for RD Note 2)                                    | CL = 150pF<br>Note 3) | -           | 140  | -      | 100   | nS    |
| t <sub>DF</sub> | Data Hold Time for $\overline{RD}$                                   |                       | 10          | 80   | 10     | 50    | nS    |

230589

## 5.3.2 Bus Write Cycle Timing (Note 1)

| Symbol          | Paramotor                                                            | Test       | AP-2/ | AM-2 | AP-10/ | AM-10 | Unite  |
|-----------------|----------------------------------------------------------------------|------------|-------|------|--------|-------|--------|
|                 | Falameter                                                            | Conditions | Min.  | Max. | Min.   | Max.  | Units  |
| t <sub>AW</sub> | CS, C/D Set-up<br>Time for ₩R                                        |            | 0     | -    | 0      | -     | nS     |
| t <sub>WA</sub> | $\overline{CS}$ , C/ $\overline{D}$ Hold<br>Time for $\overline{WR}$ |            | 0     | -    | 0      | -     | nS     |
| tww             | RD Pulse Width                                                       |            | 150   | -    | 120    | -     | nS     |
| t <sub>DW</sub> | Data Set-up Time<br>for WR                                           |            | 100   | -    | 70     | -     | nS     |
| t <sub>WD</sub> | Data Hold Time<br>for WR                                             |            | 0     | -    | 0      | -     | nS     |
| t <sub>RV</sub> | Recovery Time Between<br>Write                                       | Note 4)    | 6     | -    | 6      | -     | tcyc   |
|                 |                                                                      |            |       |      |        |       | 230589 |

## 5.3.3 Other Timings

| Cumbal | Davagatar            | Test               | AP-2 | AM-2 | AP-10/ | 'AM-10 | Linite |
|--------|----------------------|--------------------|------|------|--------|--------|--------|
| Symbol | Parameter            | Conditions         | Min. | Max. | Min.   | Max.   | Units  |
| tcyc   | Clock Period Note    | 5), 6)             | 200  | -    | 100    | -      | nS     |
| tH     | Clock High Level V   | Vdith              | 80   | -    | 40     | -      | nS     |
| tL     | Clock Low Level W    | /dith              | 50   | -    | 30     | -      | nS     |
| tR, tF | Clock Rise, Fall Tir | ne                 | -    | 20   | -      | 10     | nS     |
| +DTv   | TxD Delay Time fro   | om Falling         | -    | 1    | -      | 0.5    | us     |
| UTX .  | Edge of TxC          |                    |      |      |        |        |        |
|        | Transmitter Input    | 1xBaud Rate        | DC   | 104  | DC     | 300    |        |
| f⊤x    | Clock Frequency      | 16xBaud Rate       | DC   | 528  | DC     | 2000   | kHz    |
|        |                      | 64xBaud Rate       | DC   | 832  | DC     | 2000   |        |
|        | Transmitter Input    | 1xBaud Rate        | 12   | -    | 12     | -      |        |
| tTPH   | Clock Low Level      | 16x, 64x,          | 1    | -    | 1      | -      | tcyc   |
|        | Width                | Baud Rate          |      |      |        |        |        |
|        | Transmitter Input    | 1xBaud Rate        | 15   | -    | 15     | -      |        |
| tTPL   | Clock High Level     | 16x, 64x,          | 3    | -    | 3      | -      | tcyc   |
|        | Width                | Baud Rate          |      |      |        |        |        |
|        | Receiver Input       | 1xBaud Rate        | DC   | 104  | DC     | 300    |        |
| fRx    | Clock Frequency      | 16xBaud Rate       | DC   | 528  | DC     | 2000   | kHz    |
|        |                      | 64xBaud Rate       | DC   | 832  | DC     | 2000   | ]      |
|        | Receiver Input       | 1xBaud Rate        | 12   | -    | 12     | -      |        |
| tRPH   | Clock High Level     | 16x, 64x,          | 1    | -    | 1      | -      | tcyc   |
|        | Width                | Baud Rate          |      |      |        |        |        |
|        | Receiver Input       | 1xBaud Rate        | 15   | -    | 15     | -      |        |
| tRPH   | Clock Low Level      | 16x, 64x,          | 3    | -    | 3      | -      | tcyc   |
|        | Width                | Baud Rate          |      |      |        |        |        |
| +TUDDV | TxRDY Pin Delay T    | ime from           | -    | 14   | -      | 14     | tcyc   |
| TIXKDT | Center of Last Bit   | Center of Last Bit |      |      | }      |        |        |
| tTxRDY | TxRDY Clear Delay    | Time from          | -    | 400  | -      | 150    | ns     |
| CLEAR  | Leading Edge of V    | VR                 |      |      |        |        |        |
| +PyPDV | TxRDY Pin Delay T    | ime from           | -    | 26   | -      | 26     | tcyc   |
| INXKUT | Center of Last Bit   |                    |      |      |        |        |        |
| tRxRDY | TxRDY Clear Delay    | Time from          | -    | 400  | -      | 150    | ns     |
| CLEAR  | Leading Edge of V    | VR                 |      |      |        |        |        |
| +10    | Internal SYNDET D    | elay Time          | -    | 26   | -      | 26     | tcyc   |
| us     | from Rising Edge of  | of RxC             |      |      |        |        |        |
| +=c    | External SYNDET S    | et-up Time for     | -    | 18   | -      | 18     | tcyc   |
| LES    | Falling Edge of Rx   | Ē                  |      |      |        |        |        |
| tTx    | TxEMPTY Delay Ti     | me from            |      | 20   | -      | 20     | tcyc   |
| EMPTY  | Center of Last Bit   |                    |      |      |        |        |        |
| +\\/C  | Control Delay Tim    | e from Rising      | -    | 8    | -      | 8      | tcyc   |
| ιννς   | Edge of WR (TxEN     | , DTR RTS)         |      |      |        |        |        |
| tCR    | DSR, CTS Set-up Ti   | me for RD          | 20   | -    | 20     | -      | tcyc   |

230589

### MPU85-51

Notes:

- 1) AC Test Condition: Output measuring points VOH=2.2V, VOL=0.8V Input supply level VIH=2.4V, VIL=0.45V
- 2) Assumes that Address is valid before the falling edge  $\overline{\text{RD}}$ .
- 3) CL means load capacitance.
- This recovery time is defind only for Mode Intialization.
   Write Data is allowed only when TxRDY = 1. Recovery Time between Writes for Asynchronous Mode is 8 tcyc and for Synchronous Mode is 16 tcyc.
- 5) The TxC and RxC frequencies have the following limitations with respect to CLK: For 1x Transfer Rate, fTx or fRx <1 (30 tcyc) For 16x and 64x Transfer Rate, fTx or fRx≤1 (4.5 tcyc)
- 6) Minimum Reset Pulse Width is 6 tcyc. System Clock must running during Reset.
- Status up data can have a maximum delay of 28 clock periods from the event affecting the status.

# 6. TIMING WAVEFORMS







Figure 6.2 Transmitter Clock and Data





















TMP82C51A







EXAMPLE FORMAT : 5 BIT CHARACTERS WITH PARITY 2 SYNC CHARACTERS.

050489



MPU85-56









# 7. OUTLINE DRAWING

7.1 DIP

DIP28-P-600



270289

Note : Lead pitch is 2.54mm and to lerance is  $\pm 0.25$ mm against theoretical center of each lead that is obtained on the basis of No.1 and No.28 leads.

### 7.2 SOP

SOP28-P-450



270289

Note : Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

## PROGRAMMABLE COMMUNICATION INTERFACE

## TMP8251AP

## 1. GENERAL DESCRIPTION

The TMP8251AP is the industry standard Universal Synchronous/Asynchoronous Receiver/Transmitter (USART) that is fabricated using N-channel silicon gate MOS technology.

The TMP8251A is mainly used for 8-bit microcomputer extension systems, which require serial data communications.

The TMP8251AP is packaged in the 28pin standard Dual Inline package.

#### FEATURES

Synchoronous:

5-8 Bit Characters Internal or External Character Synchronization Single or Double Character Synchronization (Internal) Automatic Sync Insertion

Asynchronous:

5-8 Bit Characters Clock Rate - 1, 16 or 64 Times Transfer Rate Break Character Generation 1, 1.5, or 2 Stop Bits False Start Bit Detection Automatic Break Detect and Handling

• Transfer Rate DC to 64K bps (Synchronous)

DC to 19.6K bps (Asynchronous)

- Full-Duplex, Double-Buffered, Transmitter and Receiver
- Error DetectionParity, Overrun and Framing
- Single + 5V Supply
- Compatible with Intel's 8251A/S2657

# 2. PIN CONNECTIONS (TOP VIEW)



050489

## 3. BLOCK DIAGRAM



## 4. PIN NAMES AND PIN DESCRIPTIONS

#### 4.1 INTERFACE SIGNALS TO MPU (MAIN SYSTEM)

•  $D_0 \sim D_7$  (Input/Output)

This 3-state bidirectional, 8-bit buffer is used to interface the 8251A to the system Data Bus. Data is transmitted or received through the buffer upon execution of Input or Output Instructions of the MPU. Control Words, Command Words and Status Information are also transferred through the Data Bus Buffer.

• WR (Input)

A "low" level signal on this input informs the 8251A that the MPU is Writing Data or Control Words to the 8251A.

• RD (Input)

A "low" level signal on this input informs the 8251A that the MPU is Reading Data or Status Information from the 8251A.

•  $\overline{\text{CS}}$  (Input)

A "low" level signal on this input selects the 8251A. No reading or writing  $\cdot$  operation will occur unless the device is selected. When  $\overline{CS}$  is "high" the Data Bus is in the floating state and  $\overline{RD}$  and  $\overline{WR}$  have no effect on the chips.

•  $C/\overline{D}$  (Input)

This input signal, in conjunction with the  $\overline{WR}$  and  $\overline{RD}$  inputs, informs the 8251A that the word on the Data Bus is either a Data Character, Control Word or Status Information. A "high" level signal means Control or Status, a "low" level signal means Data.

| C/D | RD | WR | CS |                                                  |
|-----|----|----|----|--------------------------------------------------|
| 0   | 0  | 1  | 0  | 8251A Recieve DATA Buffer $\rightarrow$ Data Bus |
| 0   | 1  | 0  | 0  | 8251A Transmit DATA Buffer $\leftarrow$ Data Bus |
| 1   | 0  | 1  | 0  | 8251A Status DATA Buffer $ ightarrow$ Data Bus   |
| 1   | 1  | 0  | 0  | 8251A Command DATA Buffer $\leftarrow$ Data Bus  |
| ×   | 1  | 1  | 0  | DATA Bus is in floating state.                   |
| ×   | ×  | ×  | 1  | //                                               |

• CLK (Input)

The CLK input is used to generate internal device timing. No external input or output is referenced to CLK, but the frequency of CLK must be greater than 30 times the Receiver or Transmitter Data Bit Rates ( $\overline{RxC}$  or  $\overline{TxC}$ ) in Synchronous Operation, and greater than 4.5 times the Receiver Data Bit Rated ( $\overline{RxC}$ ) in Asynchronous Operation.

• RESET (Input)

A "high" level signal on this input forces the 8251A into an "Idle" mode. The device will remain at "Idel" untill a new set of Control Words is written into the 8251A to program its functional definition. Minimum RESET pulse width is 6 tcy.

#### 4.2 MODEM CONTROL SIGNALS

• DSR (Input)

The  $\overline{\text{DSR}}$  input signal is a general purpose, 1-bit inverting input port. Its condition can be tested by the MPU using a Status Read Operation. The  $\overline{\text{DSR}}$  input is normlaly used to test MODEM conditions such as Data Set Ready signal.

• DTR (Output)

The DTR output signal is a general purpose, 1-bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instsruction Word. The DTR output signal is normally used for MODEM control such as Data Terminal Ready or Rate Select signal.

• RTS (Output)

The RTS output signal is a general purpose, 1-bit inverting output port. It can be set "low" by programming the appropriate bit in the Command Instruction Word. The RTS output signal is normally used for MODEM control such as Request to Send signal.

•  $\overline{\text{CTS}}$  (Input)

A "low" level signal on this input enables the 8251A to transmit serial data, if the Tx Enable Bit in the Command Byte is set to a "one" (TxEN=1). If either a Tx Enable off (TxEN=0) or CTS off ( $\overline{CTS}=1$ ) condition occurs while the Tx is in operation, the Tx will transmit all the data in the USART, written prior to Tx Disable Command before shutting down.

#### 4.3 TRANSMIT CONTROL SIGNALS

• TxC (Input)

The Transmitter Clock Controls the rate at which the character is to be transmitted. In the Synchronous Transmission Mode, the transfer rate (1x) is equal to the  $\overline{\text{TxC}}$  frequency. In Asynchronous Transmission Mode, the transfer rate is a fraction of the actual  $\overline{\text{TxC}}$  frequency. A poriton of the Mode Instruction selects this factor; it can be 1,  $\frac{1}{16}$  or  $\frac{1}{64}$  the  $\overline{\text{TxC}}$ .

For Example:

If transfer rate equals 110 bps,  $\overline{\text{TxC}} = 110 \text{ Hz} (1x)$   $\overline{\text{TxC}} = 1.76 \text{ KHz} (16x)$  $\overline{\text{TxC}} = 7.04 \text{ KHz} (64x)$ 

The falling edge of TxC shifts the serial data out of the 8251A.

TxD (Output)

This line is used to transmit the serial data. Serial output data on TxD is changed from paralled data to serial data in accordancae with the format specified by the Control Words.

TxD line will be held in the marking state ('1' level) immediately on one of the following.s

- Master Reset Tx Disable (TxEN=0)
- CTS signal is high  $(\overline{\text{CTS}}=1)$  TxEMPTY signal is high (TxEMPTY=1)
- TxRDY (Output)

This output informs the MPU that the transmitter is ready to accept a Data Character. The TxRDY output pin can be used as an interrupt to the system, since it is masked by Tx Disable (TxEN=0), or, for polled Operation, the MPU can check TxRDY using a Status Read Operation. TxRDY is automatically reset by the trailing edge of  $\overline{WR}$  when a Data Character is loaded from the MPU. The Tx RDY pin output status (Tx RDY (pin)) is different from the TxRDY status bit status (TxRDY (status bit)) as follows.

TXRDY (status bit) = (Transmit Data Buffer Empty)

 $TxRDY (pin) = (Transmit Data Buffer Empty) \cdot (CTS = 0) \cdot (TxEN = 1)$ 

• TxEMPTY (Output)

The TxEMPTY output will go "high" when the 8251A has no characters to send. It resets upon receiving as character from the MPU if the transmitter is enabled. In Synchronous Mode, a"high" level signal on this output indicates that a Character has not been loaded and the SYNC Character or Characters are about to be or are being transmitted automatically as "fillers". Tx EMPTY does not go "low" when the SYNC characters are being shifted out.

#### 4.4 RECEIVE CONTROL SIGNLAS

•  $\overline{RxC}$  (Input)

The Receiver Clock controls the rate at which the character is to be received. In Synchronous Mode, the Transfer Rate (1x) is equal to the actual frequency of  $\overline{\text{RxC}}$ . In Asynchronous Mode, the Transfer Rate is a fraction of the actual  $\overline{\text{RxC}}$  frequency. A portion of the Mode Instruction selects this factor; 1,  $^{1}/_{16}$  or  $^{1}/_{64}$  the  $\overline{\text{RxC}}$ .

For Example: if Transfer Rate equals 2400 bps,  $\overline{RxC} = 2.4 \text{ KHz} (1x)$   $\overline{RxC} = 38.4 \text{ KHz} (16x)$  $\overline{RxC} = 153.6 \text{ KHz} (64x)$ 

Data is sampled into the 8251A on the rising edge of  $\overline{RxC}$ .

• RxD (Input)

This line is used to receive the serial data. Serial input data on this line is changed to parallel data in accordance with the format specified by the Control Words, and then transfered to the Receive Data Buffer.

• RxRDY (Output)

This output indicates that the 8251A contains a Data Character that is ready to be input to the MPU. RxRDY can be connected to the interrupt structure of the MPU, or, for Polled Operation, the MPU can check the condition of RxRDY using a Status Ready Operaiton.

Rx Enable off both masks and holds RxRDY in the Reset Condition.

#### • SYNDET/BD (Input/Output)

This pin is used for SYNDET in Synchronous Mode and may be used as eigher input or ourput, programmable through the Contorl Word. It is reset to output mode "low" upon RESET. When used as an Output (Internal Sync Mode), the SYNDET pin will go "high" to indicate that the 8251A is programmed to use SYNC Character in the Receive Mode. If the 8251A is programmed to use Double Sync Characters then SYNDET will go "high" in the middle of the last bit of the second SYNC Character. SYNDET is automatically reset upon a Status Read Operation. When used as an Input (External Sync Mode), a positive going signal will cause the 8251A to start assembling Data Characters on the rising edge of the next  $\overline{RxC}$ .

In Asynchronous Mode this pin is used for BD. This output will go "high" whenever the receiver remains "low" through two consecutive Stop Bit Sequences (including the Start Bits, Data Bits, and Parity Bits). Break Detect may also be read as a Status Bit. It is reset only upon a Master Chip Reset or Rx Data returning to a "one" state. But, if the Rx data returns to a "one" State during the last bit of the next character after the Break, Break detect does not always reset.

#### 4.5 POWER SUPPLY

- V<sub>CC</sub> (Power) + 5 Volt supply
- GND (Power) 0 Volt supply

# 5. ELECTRICAL CHARACTERISTICS

# 5.1 MAXIMUM RATINGS

| SYMBOL              | ITEM                                       | RATING          |
|---------------------|--------------------------------------------|-----------------|
| V <sub>CC</sub>     | Power Supply Voltage (with respect to GND) | – 0.5V to 7.0V  |
| VIN                 | Input Voltage (with respect to GND)        | – 0.5V to 7.0V  |
| Vout                | Output Voltage (with respect to GND)       | – 0.5V to 7.0V  |
| PD                  | Power Dissipation (Ta = 70°C)              | 1 W             |
| T <sub>solder</sub> | Soldering Temperature (10 sec)             | 260°C           |
| T <sub>stg.</sub>   | Storage Temperature                        | – 55°C to 150°C |
| T <sub>opr.</sub>   | Operating Temperature                      | 0°C to 70°C     |
|                     |                                            | 050489          |

## 5.2 D.C. CHARACTERISTICS

| $I_{opr} = 0^{\circ}C$ to $10^{\circ}C$ , $V_{CC} = 5V \pm 5\%$ , GND = 0V, Unless otherv |
|-------------------------------------------------------------------------------------------|
|-------------------------------------------------------------------------------------------|

| - F ·           |                      |                                 |      |      |                 |      |
|-----------------|----------------------|---------------------------------|------|------|-----------------|------|
| SYMBOL          | PARAMETER            | TEST CONDITIONS                 | MIN. | TYP. | MAX.            | UNIT |
| V <sub>IL</sub> | Input Low Voltage    |                                 | -0.5 | -    | 0.8             | V    |
| VIH             | Input High Voltage   |                                 | 2.2  | -    | V <sub>CC</sub> | V    |
| V <sub>OL</sub> | Output Low Voltage   | I <sub>OL</sub> = 2.2mA         | -    | -    | 0.45            | V    |
| V <sub>OH</sub> | Output High Voltage  | I <sub>OH</sub> = -400µА        | 2.4  | -    | -               | V    |
| IOFL            | Output Leak Current  | $0.45V \le V_{OUT} \le V_{CC}$  | -    | -    | ± 10            | μA   |
| l <sub>IL</sub> | Input Leak Current   | $0.45V \leq V_{IN} \leq V_{CC}$ | -    | -    | ± 10            | μA   |
| lcc             | Power Supply Current | All Outputs = "High"            | -    | -    | 100             | mA   |

050489

### 5.3 A.C CHARACTERISTICS

 $T_{opr} = 0^{\circ}C$  to  $70^{\circ}C$ ,  $V_{CC} = 5V \pm 5\%$ , GND = 0V, Unless otherwise noted.

## 5.3.1 Bus Read Cycle Timing Note 1)

| SYMBOL          | PARAMETER                                                                                | TEST CONDITIONS                | MIN. | TYP. | MAX. | UNIT   |
|-----------------|------------------------------------------------------------------------------------------|--------------------------------|------|------|------|--------|
| t <sub>AR</sub> | $\overline{\text{CS}}$ , C/ $\overline{\text{D}}$ Set-up Time for $\overline{\text{RD}}$ |                                | 50   | -    | -    | ns     |
| t <sub>RA</sub> | $\overline{CS}$ , C/ $\overline{D}$ Hold Time for $\overline{RD}$                        |                                | 50   | -    | -    | ns     |
| t <sub>RR</sub> | RD Pulse Width                                                                           |                                | 250  | -    | -    | ns     |
| t <sub>RD</sub> | Data Delay Time for RD Note 2)                                                           | C <sub>L</sub> = 150pF Note 3) | -    | -    | 250  | ns     |
| t <sub>DF</sub> | $\overline{CS}$ , C/ $\overline{D}$ Set-up Time for $\overline{RD}$                      |                                | 10   | -    | 100  | ns     |
|                 |                                                                                          |                                |      |      |      | 050489 |

# 5.3.2 Bus Write Cycle Timing Note 1)

| SYMBOL          | PARAMETER                                                                                | TEST CONDITIONS | MIN. | TYP. | MAX. | UNIT             |
|-----------------|------------------------------------------------------------------------------------------|-----------------|------|------|------|------------------|
| t <sub>AW</sub> | $\overline{\text{CS}}$ , C/ $\overline{\text{D}}$ Set-up Time for $\overline{\text{WR}}$ |                 | 50   | - `  | -    | ns               |
| t <sub>WA</sub> | $\overline{\text{CS}}$ , C/ $\overline{\text{D}}$ Hold Time for $\overline{\text{WR}}$   |                 | 50   | -    | . –  | ns               |
| t <sub>WW</sub> | WR Pulse Width                                                                           |                 | 250  | -    | -    | ns               |
| t <sub>DW</sub> | Data Set Up Time for $\overline{WR}$                                                     |                 | 150  | -    | -    | ns               |
| t <sub>WD</sub> | Data Hold Time for $\overline{WR}$                                                       |                 | 50   | -    | -    | ns               |
| t <sub>RV</sub> | Recovery Time between WRITES                                                             | Note 4)         | 6    | -    | -    | t <sub>cyc</sub> |

# 5.3.3 Other Timing

| SYMBOL                          | PARA                                 | METER                 | MIN. | TYP. | MAX.                  | UNIT             | ]      |        |        |
|---------------------------------|--------------------------------------|-----------------------|------|------|-----------------------|------------------|--------|--------|--------|
| t <sub>cyc</sub>                | Clock Period Note 5                  | ), 6)                 | 320  | -    | 1350                  | ns               | ]      |        |        |
| t <sub>H</sub>                  | Clock High Level W                   | idth                  | 140  | -    | t <sub>cyc</sub> – 90 | ns               |        |        |        |
| tL                              | Clock Low Level Wi                   | Clock Low Level Width |      | -    | -                     | ns               |        |        |        |
| t <sub>R</sub> , t <sub>F</sub> | Clock Rise and Fall                  | Time                  | -    | -    | 20                    | ns               |        |        |        |
| t <sub>DTx</sub>                | TxD Delay Time fro<br>TxC            | m Falling Edge of     | -    | -    | 1                     | μs               |        |        |        |
|                                 | 1x, 64x Baud Rate DC                 | DC                    | -    | 64   |                       |                  |        |        |        |
| f <sub>Tx</sub>                 | Transmitter Input                    | 16x Baud Rate         | DC   | -    | 310                   | kHz              |        |        |        |
|                                 | Clock Frequency                      | 64x Baud Rate         | DC   | -    | 615                   |                  |        |        |        |
|                                 | Transmitter Input                    | 1x Baud Rate          | 12   | -    | -                     |                  | 1      |        |        |
| t <sub>трн</sub>                | Clock High Level<br>  Width          | 16, 64x Baud Rate     | 1    | -    | -                     | τ <sub>сус</sub> |        |        |        |
|                                 | Transmitter Input                    | 1x Baud Rate          | 15   | -    | -                     | +                | 1      |        |        |
| t <sub>TPL</sub>                | Width                                | 64x Baud Rate         | 3    | _    | -                     | L Cyc            |        |        |        |
|                                 |                                      | 1x Baud Rate          | DC   | -    | 64                    |                  |        |        |        |
| f <sub>Rx</sub>                 | Transmitter Input<br>Clock Frequency | 16, 64x Baud Rate     | DC   | -    | 310                   | kHz              |        |        |        |
|                                 |                                      | 64x Baud Rate         | DC   | -    | 615                   |                  |        |        |        |
| taou                            | Transmitter Input                    | 1x Baud Rate          | 12   | -    | -                     | +                |        |        |        |
| чкрн                            | Width                                | 64x Baud Rate         | 1    | -    | -                     | Lcyc             |        |        |        |
| tee                             | Transmitter Input                    | 1x Baud Rate          | 15   | -    | -                     | t <sub>cyc</sub> |        |        |        |
| "NPL                            | Width                                | 64x Baud Rate         | 3    | _    | -                     |                  |        |        |        |
|                                 | TxRDY Pin Delay Tir                  | me from Center of     |      |      | 0                     | +                | Neto 7 |        |        |
| t <sub>txrdy</sub>              | Last Bit                             |                       | -    | -    | -   .                 |                  | 8      | L CYC  | Note / |
|                                 | TxRDY Clear Delay                    | Time from Trailing    |      |      |                       | C                | +      |        |        |
| t <sub>RxRDY</sub> CLEAR        | Edge of WR                           | Edge of WR            |      | _    | 0                     | t <sub>cyc</sub> | Note / |        |        |
|                                 | RxRDY Pin Delay Ti                   | me from Center of     |      |      | 24                    | +                | Noto 7 |        |        |
| t <sub>rxrdy</sub>              | Last Bit                             |                       | -    | -    | 24                    | L Cyc            | Note / |        |        |
|                                 | RxRDY Clear Delay                    | Time from Leading     |      |      |                       | +                | Noto 7 |        |        |
| t <sub>Rx</sub> RDY CLEAR       | Edge of RD                           |                       | -    | -    | 6                     | L CYC            | Note / |        |        |
| _                               | Internal SYNDET De                   | elaya Time from       |      |      |                       | +                | Noto 7 |        |        |
| t <sub>is</sub>                 | Rising Edge of RxC                   |                       | -    | -    | 24                    | L CYC            | Note / |        |        |
|                                 | External SYNDET Se                   | et-Up Time fore       |      |      |                       | +                |        |        |        |
| t <sub>ES</sub>                 | Falling Edge of RxC                  |                       | 16   | -    | -                     | - cyc            | Note / |        |        |
|                                 | TxEMPTY Delay Tim                    | ne from Center of     | 20   |      |                       | +                | Note 7 |        |        |
| t <sub>txempty</sub>            | Last Bit                             |                       | 20   | -    | _                     | чсус             |        |        |        |
|                                 | Control Delay Time                   | from Rising Edge      | 8 –  | 0    |                       |                  | t      | Note 7 |        |
| τwc                             | of WR (TxEN, DTR,                    | RTS)                  |      | δ –  |                       | τ <sub>сус</sub> | Note / |        |        |
| t <sub>CR</sub>                 | DSR, CTS Set-Up Tir                  | me for RD             | 20   |      | -                     | t <sub>cyc</sub> | Note 7 |        |        |

Note :

2)

- 1) AC Test Conditions: Output measuring Point  $V_{OH} = 2.0V, V_{OL} = 0.8V$ 
  - Input supply level  $V_{IH} = 2.4V, V_{IL} = 0.45V$
  - Assumes that Address is valid before the falling edge of  $\overline{\text{RD}}$ .
- 3) C<sub>L</sub> means load capacitance.
- 4) This recovery time is defined only for Mode Intialization. Write Data is allowed only when TxRDY = 1. Recovery Time between Writes for Asynchronous Mode is 8 tcy and for Synchronous Mode is 16 tcy.
- 5) The TxC and RxC frequencies have the following limitations with respect to CLK: For 1x Transfer Rate,  $f_{Tx}$  or  $f_{Rx} \le 1/(30 \text{ tcy})$ 
  - For 16x and 64x Transfer Rate,  $f_{Tx}$  or  $f_{Rx} \! \leq \! 1/\left( 4.5 tcy \right)$
- 6) Minimum Reset Pulse Width is 6 tcy. System Clock must be running during Reset.
- 7) Status up data can have a maximum delay of 28 clock periods from the event affecting the status.

# 6. TIMING WAVEFORMS



Figure 6.1 System Clock



Figure 6.2 Transmitter Clock and Data



Figure 6.3 Receiver Clock and Data











EXAMPLE FORMAT : 5 BIT CHARACTER WITH PARITY 2 SYNC CHARACTERS.

050489

### Figure 6.8 Transmitter Control and Flag Timing (SYNC Mode)



```
EXAMPLE FORMAT : 5 BIT CHARACTER WITH PARITY 2 SYNC CHARACTERS.
```





 $\label{eq:Note:transmit} \begin{array}{ll} Note: & TxRDY\,(PIN)-(Transmit Data Buffer is empty) \cdot (TxEN=1) \cdot (CTS-0) \\ & TxRDY\,(STATUS\,BIT)-(Transmit Data Buffer is empty) \end{array}$ 







# 7. OUTLINE DRAWING (Dual Inline Package)

### DIP28-P-600



270289

Note: Lead pitch is 2.54m and to lerance is  $\pm 25$ mm against theoretical center of each lead that is obtained on the basis of No.1 and No.28 leads.

# PROGRAMMABLE INTERVAL TIMER

## TMP82C53P-2

## 1. GENERAL DESCRIPTION

The TMP82C53P-2 (hereinafter referred to as TMP82C53) is a programmable counter/timer. It is organized as 3 independent 16 bit counters, each operates with a count rate of up to 5MHz. All modes of operation are software programmable.

## 2. FEATURES

- Count Binary or BCD
- 3 Independent 16 Bit Counters
- Single +5V Supply
- Count rate DC to 5MHz
- 6 programmable Counter Mode
- Low Power Consumption 5mA MAX. @5MHz
- Extended Operating Temperature 40°C to 85°C
- 3. PIN CONNECTIONS

| D7                |   | 1  | 24 | ի | Vcc               |
|-------------------|---|----|----|---|-------------------|
| D <sub>6</sub>    | ٢ | 2  | 23 | þ | WR                |
| $D_5$             | C | 3  | 22 | þ | RD                |
| D4                | Ľ | 4  | 21 | þ | CS                |
| D <sub>3</sub>    | E | 5  | 20 | þ | A <sub>1</sub>    |
| D <sub>2</sub>    | ۵ | 6  | 19 | þ | A <sub>0</sub>    |
| D <sub>1</sub>    | q | 7  | 18 | þ | CLK <sub>2</sub>  |
| D <sub>0</sub>    | q | 8  | 17 | þ | $OUT_2$           |
| CLK <sub>0</sub>  | ۵ | 9  | 16 | þ | GATE <sub>2</sub> |
| OUT <sub>0</sub>  | þ | 10 | 15 | þ | CLK <sub>1</sub>  |
| GATE <sub>0</sub> | ۵ | 11 | 14 | þ | GATE <sub>1</sub> |
| Vss (GND)         | C | 12 | 13 | þ | OUT1              |
|                   |   |    |    |   |                   |

TMP82C53P-2

| D7~D0           | Data Bus (8 bit)    |
|-----------------|---------------------|
| CLK n           | Counter Clock Input |
| GATE n          | Counter Gate Input  |
| OUT n           | Counter Output      |
| RD              | Read Counter        |
| WR              | Write Counter       |
| <u>CS</u>       | Chip Select         |
| A0~A1           | Counter Select      |
| Vcc             | + 5V                |
| V <sub>SS</sub> | Ground(0v)          |

#### Table 3.1 PIN NAMES

# 4. BLOCK DIAGRAM



# 5. PIN NAMES AND PIN DESCRIPTION

• Vss (GND) (Power Supply)

Ground.

• VCC (Power supply)

+5V during operation.

•  $\overline{\mathrm{CS}}$  (Input)

A low level input on this pin enables read and write communication between the MPU and the TMP82C53. The  $\overline{CS}$  input has no effect upon the actual operation of the counters.

•  $A_0, A_1$  (Input)

These inputs acts in conjunction with the  $\overline{CS}$ ,  $\overline{WR}$ , and  $\overline{RD}$  pins. This pin is used to select one of the three counters to be operated on and to address the control word register for mode selection.

• WR (Input)

A low level input on this pin when  $\overline{\rm CS}$  is low enables the TMP82C53 to accept mode information or loading counters from the MPU.

• RD (Input)

A low level input on this pin when  $\overline{CS}$  is low enables the TMP82C53 to output a counter value onto the data bus.

## • D<sub>0</sub>-D<sub>7</sub> (Input/Output)

Bidirectional 8bit data bus. Mode information and the count values are transferred via this data bus.

• CLK<sub>0</sub>-CLK<sub>2</sub> (Input)

Clock inputs to counters. Falling edge on this pin enable the counter to count down.

• GATE<sub>0</sub>-GATE<sub>2</sub> (Input)

Gate inputs to counters. The function of this pin differs by the mode selection of counter operation.

•  $OUT_0$ - $OUT_2$  (Output)

Outputs from the counters. The output signal from this pin differs by the mode selection of counter operation.

# 6. FUNCTIONAL DESCRIPTION

#### [Block Description]

Data Bus Buffer

This is 3-state, bidirectional, 8 bit buffer used for interfacing the TMP82C53 to the system data bus. The Data Bus Buffer has three functions as follows. Programming the MODEs of the TMP82C53, Loading the count registers, and Reading the count values.

#### Read/Write Logic

The Read/Write Logic accepts inputs from the system bus and in turn generates control signals for overall device operation.

| <del>CS</del> | $\overline{RD}$ | WR | Α1 | A <sub>0</sub> |                                     |
|---------------|-----------------|----|----|----------------|-------------------------------------|
| 0             | 1               | 0  | 0  | 0              | Load Counter #0                     |
| 0             | 1               | 0  | 0  | 1              | Load Counter #1                     |
| 0             | 1               | 0  | 1  | 0              | Load Counter #2                     |
| 0             | 1               | 0  | 1  | 1              | Write Mode Word                     |
| 0             | 0               | 1  | 0  | 0              | Read Counter #0                     |
| 0             | 0               | 1  | 0  | 1              | Read Counter #1                     |
| 0             | 0               | 1  | 1  | 0              | Read Counter #2                     |
| 0             | 0               | 1  | 1  | 1              |                                     |
| 1             | ×               | ×  | ×  | ×              | Data Bus is in High-impedance state |
| 0             | 1               | 1  | ×  | ×              |                                     |

| abled. I Counter Addressing | Гаb | le6. | 1 | Counter | Addressing |
|-----------------------------|-----|------|---|---------|------------|
|-----------------------------|-----|------|---|---------|------------|
#### **Control Word Register**

The Control Word Register is selected when  $A_0$ ,  $A_1$  are 11. It then accepts information from the data bus buffer and stores it in a register. The information stored in this register controls the operation mode of each counter, selection of binary or BCD counting and the loading of each count register. No reading of the contents of the control Word Register is available.

#### Counter #0, Counter #1, Counter #2

Since these three counters are identical, only a single counter will be described herafter. Each counter consists of a single, 16bit, presettable, down counter. The counter can operate in either binary or BCD and its input, gate and output are configured by the selection of modes (6 modes: MODE 0 to MODE 5) stored in the Control Word Register. Also the control word handles the loading of the count value so that software overhead can be minimized for these functions.

The reading of the contents of each counter is available to the programmer with simple read operations for event counting applications. Special commands and logic are built in the TMP82C53 so that the contents of each counter can be read "on-the-fly" without having to inhibit the clock input.

#### [MODE Definition]

Mode 0: Interrupt on Terminal Count.

The output will be initially low after the mode set operation. After the count is loaded into the selected count register, the output will remain low and the counter will count. When terminal count is reached, the output will go high and remain high until the selected count register is reloaded with the mode or a new count value is loaded. The counter continues to decrement after terminal count has been reached. Rewriting a counter register during counting results in the following:

- (1) Write 1st byte stops the current counting.
- (2) Write 2nd byte starts the new count.

MODE1: Programmable One Shot.

The output will go low on the count following the rising edge of the GATE input. The output will go high on the terminal count. If a new count value is loaded while the output is low it will not affect the duration of the one-shot pulse until the succeeding trigger. The current count can be read at any time without affecting the one-shot pulse.

The one-shot is retriggerable, hence the output will remain low for the full count after any rising edge of the GATE input.

### MODE2: Rate Generator

Divide by N counter. The output will be low for one period of the input clock. The period from one output pulse to the next equals the number of input counts in the count register. If the count register is reloaded between output pulses the present period will not be affected, but the subsequent period will reflect the new value.

The GATE input, when low, will force the output high. When the GATE input goes high, the count will start from the initial count. Thus, the GATE input can be used to synchronize the counter.

When this mode is set, the output will remain high until after the count register is loaded. The output then can also synchronized by software.

#### MODE 3: Square Wave Rate Generator

Similar to MODE 2 except that the output will remain high until one half the count has been completed (for even numbers) and go low for the other half of the count.

This is accomplished by decrementing the counter by two on the falling edge of each clock pulse. When the counter reaches terminal count, the state of the output is changed and the counter is reloaded with the full count and the whole process is repeated.

If the count is odd and the output is high, the first clock pulse (after the count is loaded) decrements the count by 1. Subsequent clock pulses decrement the clock by 2. After timeout, the output goes low and the full count is reloaded. The first clock pulse (following the reload) decrements the counter by 3. Subsequent clock pulses decrement the count by 2 until timeout. Then the whole process is repeated. In this way, if the count is odd, the output will be high for (N+1)/2 counts and low for (N-1)/2 counts.

#### MODE 4: Software Triggered Strobe

After the mode is set, the output will be high. When the count is loaded, the counter will begin counting. On terminal count, the output will go low for one input clock period, then will go high again.

If the count register is reloaded between output pulses, counting will continue from the new value. The count will be inhibited while the GATE input is low. Reloading the counter register will restart counting beginning with the new number.

### MODE 5: Hardware Triggered Strobe

The counter will start counting after the rising edge of the trigger input and will go low for one clock period when the terminal count is reached. The counter is retriggerable. The output will not go low until the full count after the rising edge of any trigger.

| Status<br>Modes | Low or Going Low                                                                         | Rising                                                                              | High            |
|-----------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------|
| 0               | Disables counting                                                                        |                                                                                     | Enable counting |
| 1               |                                                                                          | <ul><li>(1) Initiates counting</li><li>(2) Resets output after next clock</li></ul> |                 |
| 2               | <ul><li>(1) Disables counting</li><li>(2) Sets output immediately</li><li>High</li></ul> | Initiates counting                                                                  | Enable counting |
| 3               | <ul><li>(1) Disables counting</li><li>(2) Sets output immediately</li><li>High</li></ul> | Initiates counting                                                                  | Enable counting |
| 4               | Disables counting                                                                        |                                                                                     | Enable counting |
| 5               |                                                                                          | Initiates counting                                                                  |                 |
|                 |                                                                                          |                                                                                     | 050489          |

Table 6.2 Gate Pin Operations

#### MODE0 : Interrupt on Terminal Count

MODE1: Programmable One-Shot



MODE3 : Square Wave Generator



MODE4 : Software-Triggered Strobe



MODE2 : Rate Generator

MODE5 : Hardware-Triggered Strobe





# 7. PROGRAMMING THE TMP82C53

All of the MODEs for each counter are programmed by the systems software by simple I/O operations.

Each counter of the TMP82C53 is individually programmed by writing a control word into the Control Word Register.  $(\overline{CS}=0, A_0=A_1=1, \overline{WR}=0)$ 



Note. SC: Select Counter, RL: Read/Load, M: Mode, BCD: Binary Coded Decimal.

The programmer must write out to the TMP82C53 a Mode Control Word and the programmed number of count register bytes (1 or 2) prior to actually using the selected counter.

The actual order of the programming is quite flexible. Writing out of the Mode Control Word can be in any sequence of counter selection.

The loading of the Count Register with actual count value, however, must be done in exactly the sequence programmed in the Mode Control Word (RL0, RL1).

# 8. Counter Loading

The count register is not loaded until the count value is written (one or two bytes, depending on the mode selected by the RL bits), followed by a rising edge and a falling edge of the clock.

The count register must be loaded with the number of bytes programmed in the Mode Control Word. The one or two bytes to be loaded in the count register do not have to follow the associated Mode Control Word. They can be programmed at any time following the Mode Control Word loading as long as the correct number of bytes is loaded in order.

All counters are down counters. Loading all zeros will result in the maximum count  $(2^{16} \text{ for Binary or } 10^4 \text{ for BCD})$ . In MODE 0 and MODE 4, the new count will not restart until the load has been completed.

# 9. Read Operations

The TMP82C53 contains the circuit that will allow the programmer to easily read the contents of any of the three counters without distrubing the actual count in progress. There are two methods that the programmer can use to read the value of the counters. The first method involves the use of simple I/O read operations. By controlling the  $A_0$ ,  $A_1$  inputs to the TMP82C53, the programmer can select the counter to be read. The only requirement with this method is that in order to assure a stable count reading the actual this method is that in order to assure a stable count reading the actual operation of the selected counter must be inhibited either by controlling the GATE input or by external logic that inhibits the clock input.

The contents of the counter selected must be read in the sequence programmed in the Mode Control Word (RL0, RL1). When RL0, RL1 is 11. First I/O Read contains the least significant byte (LSB), second I/O Read contains the most significant byte (MSB), and the two bytes must be read before any loading WR command can be sent to the same counter.

The second method allows the programmer to read the contents of any counter without effecting or distrubing the count operation. When the programmer wishes to read the contents of a selected counter "On-the-fly", a special code should be written to the Mode register so that the counter holds an accurate, stable count value. The programmer then issues a normal read command to the selected counter. The contents of the latched register must be read in the sequence programmed in the Mode Control Word (RL0, RL1). This commands has no effect on the counters mode.

# 10. Program Example

| Set up sequence   | MVI  | A, 00110000B | #0, LSB-MSB, MODE 0, Binary           |
|-------------------|------|--------------|---------------------------------------|
| for counter #0    | OUT  | CWAD         | The address of Control Word Register  |
|                   | MVI  | A, 53H       | LSB for counter #0                    |
|                   | OUT  | CNTO         | The address of counter #0             |
|                   | MVI  | A. 82H       | MSB for counter #0                    |
|                   | OUT  | CNTO         | The address of counter #0             |
|                   |      | :            |                                       |
|                   |      | :            |                                       |
|                   |      |              |                                       |
| READ the contents | MVI  | A, OOOOXXXXB |                                       |
| of counter #0     | OUT  | CWAD         | Latching count                        |
|                   | IN   | CNTO         | Read LSB of counter #0                |
|                   | MOV  | L, A         |                                       |
| · ·               | IN   | CNTO         | Read MSB of counter #0                |
|                   | MOV  | Н, А         |                                       |
|                   | :    |              |                                       |
|                   | :    |              | · · · · · · · · · · · · · · · · · · · |
| RELOAD to         | MV/T | ۵ 28H        |                                       |
|                   | OUT  | A, LON       | I and I SD for according #0           |
| counter #0        | 001  | CNTU         | Load LSB for counter #0               |
|                   | MVI  | A, 53H       |                                       |
|                   | OUT  | CNTO         | Load MSB for counter $\#0$            |

# **11. ELECTRIC CHARACTERISTICS**

### 11.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL | ITEM                                           | RATING             | UNIT   |
|--------|------------------------------------------------|--------------------|--------|
| VCC    | Vcc Supply Voltage (with respect to Vss [GND]) | -0.5 to +7.0       | V      |
| VIN    | Input Voltage (with respect to Vss [GND])      | – 0.5 to Vcc + 0.5 | V      |
| VOUT   | Output Voltage (with respect to Vss [GND])     | – 0.5 to Vcc + 0.5 | V      |
| PD     | Power Dissipation                              | 250                | mW     |
| Tsol   | Soldering Temperature (Sodlering Time 10 sec)  | 260                | °C     |
| Tstg   | Storage Temperature                            | – 65 to + 150      | °C     |
| Topr   | Operating Temperature                          | - 40 to + 85       | °C     |
|        | · · · · · · · · · · · · · · · · · · ·          |                    | 050489 |

11.2 DC CHARACTERISTICS

 $Ta = -40^{\circ}C to + 85^{\circ}C, Vcc = 5V \pm 10\%, Vss(GND) = 0V$ 

| SYMBOL | PARAMETER                | TEST CONDITION                               | MIN.                     | TYP. | MAX.                     | UNIT |
|--------|--------------------------|----------------------------------------------|--------------------------|------|--------------------------|------|
| VIL    | Input Low Voltage        |                                              | - 0.5                    |      | 0.8                      | V    |
| VIH    | Input High Voltage       |                                              | 2.2                      |      | V <sub>CC</sub><br>+ 0.5 | V    |
| VOL    | Output Low Voltage       | IOL = 2.2mA                                  |                          |      | 0.45                     | V    |
| VOH1   | Output High Voltage      | IOH = - 400µА                                | 2.4                      |      |                          | V    |
| VOH2   | Output High Voltage      | IOH = - 100µA                                | V <sub>CC</sub><br>– 0.8 |      |                          | v    |
| IIL    | Inupt Leak Current       | $0V \leq VIN \leq Vcc$                       |                          |      | ± 10                     | μA   |
| IOFL   | Output Leak Current      | $0.45V \le VOUT \le Vcc$                     |                          |      | ± 10                     | μA   |
| ICC1   | Operating Supply Current | CLK = 5MHz<br>VIH = Vcc - 0.2V<br>VIL = 0.2V |                          |      | 5                        | mA   |
| ICC2   | Stand-by Supply Current  | CLK = DC<br>VIH = Vcc - 0.2V<br>VIL = 0.2V   |                          |      | 10                       | μA   |

### 11.3 AC CHARACTERISTICS

 $Ta = -40^{\circ}C TO + 85^{\circ}C$ ,  $Vcc = 5V \pm 10\%$ , Vss(GND) = 0V

| SYMBOL | PARAMETER                | TEST CONDITION | MIN. | TYP. | MAX. | UNIT |
|--------|--------------------------|----------------|------|------|------|------|
| tAR    | Address Set-up Time (RD) |                | 30   |      |      | ns   |
| tRA    | Address Hold Time (RD)   |                | 0    |      |      | ns   |
| tRR    | RD Pulse Width           |                | 180  |      |      | ns   |
| tRD    | Valid Data (RD)          | CL = 150pF     |      |      | 140  | ns   |
| tDF    | Data Floating (RD)       |                | 10   |      | 85   | ns   |
| tRV    | Recovery Time            |                | 250  |      |      | ns   |
| tAW    | Address Set-up Time (WR) |                | 0    |      |      | ns   |
| tWA    | Address Hold Time (WR)   |                | 30   |      |      | ns   |
| tWW    | WR Pulse Width           |                | 150  |      |      | ns   |
| tDW    | Data Set-up time (WR)    |                | 100  |      |      | ns   |
| tWD    | Data Hold Time (WR)      |                | 30   |      |      | ns   |
| tCLK   | Clock Period             |                | 200  |      | DC   | ns   |
| tPWH   | CLK High Pulse Width     |                | 80   |      |      | ns   |
| tPWL   | CLK Low Pulse Width      |                | 65   |      |      | ns   |
| tGW    | GATE Width High          |                | 50   |      |      | ns   |
| tGL    | GATE Width Low           |                | 50   |      |      | ns   |
| tGS    | GATE Set-up Time (CLK)   |                | 70   |      |      | ns   |
| tGH    | GATE Hold Time (CLK)     |                | 50   |      |      | ns   |
| tOD    | Output Delay From (CLK)  | CL = 150pF     |      |      | 200  | ns   |
| tODG   | Output Delay From (GATE) | CL = 150pF     |      |      | 200  | ns   |

Note : AC timings measurements are referenced to VIL=0.45V, VIH=2.4V, VOL=0.8V, VOH=2.2V.

050489

#### 11.4 INPUT CAPACITANCE

 $Ta = 25^{\circ}C$ , Vcc = Vss (GND) = 0V

| SYMBOL | PPRAMETER                | TEST CONDITION | MIN. | TYP. | MAX. | UNIT |
|--------|--------------------------|----------------|------|------|------|------|
| CI     | Input Capacitance        | fC = 1MHz      |      |      | 10   | ~F   |
| CI/O   | Input/Output Capacitance | 0V             |      |      | 20   | рг   |

050489

# 12. TIMING DIAGRAM



Figure 12.1 Read Timing



Figure 12.2 Write Timing





# 13. EXTERNAL DIMENSION VIEW

# 13.1 24 Pin PLASTIC DIP

DIP24-P-600



270289

Note: Lead pitch is 2.54mm and tolerance is  $\pm 0.25$ mm against theoretical center of each lead that is obtained on the basis of No.1 and No.24 leads.

# PROGRAMMABLE INTERVAL TIMER

### TMP82C54P-2 / TMP82C54M-2

The TMP82C54P-2 TMP82C54M-2 (hereafter called the TMP82C54) is a low power, CMOS general-purpose programmable timer/counter.

The TMP82C54 consists of 3 independent 16-bit counters to implement high-speed counting. It contributes to a greatly enhanced system throughput.

### 1. FEATURES

- (1) Pin compatible with the TMP82C53P-2 (TMP82C54P-2)
- (2) Three independent, 16-bit counters
- (3) Count data read is available.
- (4) Status read is available.
- (5) Six programmable Counter modes
- (6) Binary/decimal count selection
- (7) High-speed operation TMP82C54P-2/M-2 Clock input=10MHz Max.
- (8) Low power dissipation
  In operation 30mA max.
  In stand-by 10µA max.
- (9) Extended operating temperature  $-40^{\circ}$ C to  $+85^{\circ}$ C
- (10) Power supply voltage  $5V \pm 10\%$

050489

# 2. PIN CONNECTIONS (TOP VIEW)





# 3. BLOCK DIAGRAM



050489

Figure 3.1 Block Diagram

# 4. I/O SIGNAL DESCRIPTION

•  $\overline{\text{CS}}$  (Chip Select input)

A low this input enables the TMP82C54. Unless  $\overline{CS}$  is in the enabled state, the read/write operation is ignored. The  $\overline{CS}$  input does not affect the actual counter operation.

• A<sub>0</sub>, A<sub>1</sub> (Address inputs)

These inputs are used to select one of the 3 internal counters or the control word register.

• WR (Write input)

The low active write strobe signal for the TMP82C54 used, to set the mode or load data into the counters.

•  $\overline{\text{RD}}$  (Read input)

The low active read strobe signal for the  $\rm TMP82C54$  used, to read the value of the internal counter.

•  $D_0 - D_7$  (Data bus I/O)

The 8-bit bidirectional 3-state data bus pins connected to the microcomputer data bus.

• CLK <sub>0~3</sub> (Clock input)

The clock input pin for the counter. The counter starts decrementing at the falling edge of this signal.

• GATE 0~3 (Gate input)

The gate input pin for the counter. The function depends on the mode stored in the control word register.

• OUT  $_{0\sim3}$  (Out output)

The output pin form the counter. One of 6 different waveforms selected by the mode stored in the control word register is output.

# 5. OPERATIONAL DESCRIPTION

#### 5.1 DATA BUS BUFFER

This is the bidirectional 3-state 8-bit data buffer to interface with the microcomputer system data bus. The transfer of the control word for mode set, data write to the counter, and data read from the counter are all performed through this buffer.

#### 5.2 READ/WRITE LOGIC

This circuit receives the control signals  $(\overline{\text{RD}}, \overline{\text{WR}})$  form the system bus to generate the control signals for the entire TMP82C54 system operations.

The chip select input  $(\overline{CS})$  enables/desables these control signals. When the  $\overline{CS}$  is in the disabled state, the control signal states do not affect the internal operations.

#### 5.3 CONTROL WORD REGISTER

The control word register is selected when  $A_0 = 1$  and  $A_1 = 1$ .

The information from the data bus buffer is stored in this register to select the counter operation mode, binary or decimal counting, and control the specification of the counter loading method. The control word can be read by using the read-back command.

#### 5.4 COUNTERS #0-#2

These counters perform exactly the same operation independently.

The following description is made referring to only one counter for convenience. Figure 5.1 shows the block diagram of the counter.

The counter is the 16-bit presettable synchronous down-counter.

The status register, consisting of 8 bits, holds the current states of the control word register, output pin, and the null count flag information. (See "Read-back Command.")

The count latch, consisting of two 8 bits, normally follows the current value of the down-counter (non latch state). When the TMP82C54 receives an proper count latch command, the count latch holds the value of the down-counter at this time. When the latched data is read by the MPU, the latch is cleared and put in the non latch state again. After the count latch command, count value to be read is not the current value of the down-counter but the value of the count latch.

The count register consists of two 8 bits. When the count value is written to the counter, at first, the value is loaded into the counter register. Then the count value is loaded into the down-counter. Writing the count value to the count register is performed in units of 8 bits.

However, the count value is loaded into the down-counter in units of 16 bits.

When the counter value is written to the down-counter programmed in the read/load 1-byte mode, the other byte is automatically cleared to 00H.

The control logic is connected to the CLK input, GATE input, and OUT output signals. The operations of these signals specified by selecting one of modes 0.5 programmed in the control word register.



Figure 5.1 Block Diagram of Internal Counter

### 6. PROGRAMMING

The OUT output pin state, the counter mode, and the count register values of the TMP82C54 are still undefined immediately after the power is turned on.

This requires to program the counters to be used. However, the counters not to be used need not be programmed.

#### 6.1 MODE SETTING

The count modes of the TMP82C54 can be set with a simple I/O instruction. Each counter of TMP82C54 can be programmed separately by writing the control word to the control word register ( $\overline{CS}=0, A_0=1, A_1=1, \overline{WR}=0$ ).

### 6.1.1 Control Word

|                             | D7     | D <sub>6</sub>  | D <sub>5</sub>  | D4              | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |        |                  |        |
|-----------------------------|--------|-----------------|-----------------|-----------------|----------------|----------------|----------------|----------------|--------|------------------|--------|
|                             | $SC_1$ | SC <sub>0</sub> | RW <sub>1</sub> | RW <sub>0</sub> | M <sub>2</sub> | M <sub>1</sub> | M <sub>0</sub> | BCD            |        |                  |        |
|                             | +      | ¥               |                 |                 |                |                |                | ¥              |        |                  |        |
| Select Counter 0            | 0      | 0               |                 |                 |                |                |                | 0              | Binary | Counter 16 bits  |        |
| Select Counter 1            | 0      | 1               |                 |                 |                |                |                | 1              | BCD Co | unter (4 Decades | ;)     |
| Select Counter 2            | 1      | 0               |                 |                 |                | ¥              | ¥              | 1              |        | 1                |        |
| Read Back Command           | 1      | 1               |                 |                 | 0              | 0              | 0              | Mod            | e 0    |                  |        |
|                             | L      | L               | '↓              | ¥               | 0              | 0              | 1              | Mod            | e 1    |                  |        |
| Counter Latch Comr          | mand   |                 | 0               | 0               | ×              | 1              | 0              | Mod            | e 2    |                  |        |
| READ/LOAD LSB               |        |                 | 0               | 1               | ×              | 1              | 1              | Mod            | e 3    |                  |        |
| READ/LOAD MSB               |        |                 | 1               | 0               | 1              | 0              | 0              | Mod            | e 4    |                  |        |
| READ/LOAD LSB $\rightarrow$ | MSB    |                 | 1               | 1               | 1              | 0              | 1              | Mod            | e 5    |                  | 050400 |
|                             |        |                 |                 | ·               | L              |                |                |                |        | 1                | 050489 |

Note: 1. Read/Load least significant byte first, then most significant byte

2. Read/Load is  $\overline{RD}/\overline{WR}$ 

3. × : Don't care

## Figure 6.1 Control Word

There is no specified order in which the counters are selected for mode setting. Mode setting can start from any counter.

### 6.2 COUNTER WRITING

Paying attention to the following two points makes it possible to program the TMP82C54 in any sequence.

- (1) Writing of the control word to each counter must be performed before the count value is written.
- (2) The count value must be written in the format specified in the control word (bits  $RW_0$  and  $RW_1$ ).

- 6.3 PROGRAM SEQUENCE EXAMPLES (IN THE LSB-MSB 2-BYTE MODE)
- Counter 0: Control word Counter 0: Lower 8 bits Counter 0: Upper 8 bits Counter 1: Control word Counter 1: Lower 8 bits Counter 1: Upper 8 bits Counter 2: Control word Counter 2: Lower 8 bits Counter 2: Upper 8 bits
- (3) Counter 0: Control word Counter 1: Control word Counter 2: Control word Counter 0: Lower 8 bits Counter 0: Upper 8 bits Counter 1: Lower 8 bits Counter 1: Upper 8 bits Counter 2: Lower 8 bits Counter 2: Upper 8 bits
- (2) Counter 0: Control word Counter 1: Control word Counter 2: Control word Counter 0: Lower 8 bits Counter 1: Lower 8 bits Counter 2: Lower 8 bits Counter 0: Upper 8 bits Counter 1: Upper 8 bits Counter 2: Upper 8 bits
- (4) Counter 0: Control word Counter 0: Lower 8 bits Counter 1: Control word Counter 2: Control word Counter 1: Lower 8 bits Counter 0: Upper 8 bits Counter 1: Upper 8 bits Counter 2: Lower 8 bits Counter 2: Upper 8 bits

#### 6.4 COUNTER READING

The counter value of the TMP82C54 can be read without disturbing the on-going count value. The counter value are read in one of the three methods as described below.

- One is simple I/O Read of the counter selected by A<sub>0</sub> and A<sub>1</sub>. In this method, the GATE input must be controlled or the CLK input must be inhibited in order to read a stable count value. The procedure specified in the control word must always be followed. (That is, only the LSB 1 byte must be RW<sub>1</sub>/RW<sub>0</sub> read when only the LSB 1 byte is specified; only the MSB 1 byte must be read when only the MSB 1 byte is selected; and, in the case of the continuous bytes form LSB to MSB, the LSB 1 byte and MSB 1 byte (a total of 2 bytes) must be read.)
- The on-going, momentary count value is read without stopping the counter operation. This can be achieved by specifying the counter latch operation in the control word (the counter latch command).

When reading the value of the specified counter, a stable count value can be obtained by specifying the counter latch operation before reading the value of the specified counter. In this case, the procedure specified in the control word must be followed like the method shown above.

• The count latch is specified be the Read-Back command.

#### 6.4.1 Counter Latch Command



Figure 6.2 Counter Latch Command

The selected counter holds the value of the down-counter when the counter latch command is executed. The count value remains held until the value is read or the counter is reprogrammed.

If the counter latch command is written to the same counter twice, the second one is ignored. The value to be read is the counter value counted at the time the first count latch command was written.

When the counter is in the 2-byte mode, the 2 bytes must be read. The count value can be written as the following sequence :

- 1. Least significant byte: Read
- 2. Least significant byte: Write
- 3. Most significant byte : Read
- 4. Most significant byte : Write

#### 6.4.2 Read-back Command

The read-back command is used to get the count value, the mode output pin state, and the null count flag information.



050489



The read-back command can latch multiple counters simultaneously by selecting the counter by  $CNT_2$ - $CNT_0$  with the  $\overline{COUNT}$  bit  $D_5=0$  (multiple count latch). This will provide the same operation on each command as the operation in which a count latch command has been merely written to each counter. The count value remains held in the count latch until the value is read or the counter is reprogrammed.

Reading the count value from any counter does not clear the counter latch of the other counters.

When multiple count latch is performed on a counter twice, the second one is ignored. The value to be read is the counter value counted at the time the first multiple count latch was performed.

The read-back command can latch the status information by selecting a counter by  $CNT_2$ - $CNT_0$  with the STATUS bit  $D_4=0$ . The status information are as follows.



050489

Figure 6.4 Status Data Format

Bits  $D_5$ - $D_0$  are the low-order 6 bits of the control word register currently programmed in that counter. These bits are held in the status register when the mode is set in the control word register and remain unchanged until the control word register is rewritten.

OUTPUT bit  $D_7$  indicates the current OUT output pin state.

NULL COUNT bit  $D_6$  is the flag indicating whether the count value has been loaded from the count register into the down-counter. When this flag is "0", it indicates that the count value has been loaded into the down-counter; when it is "1", it indicates that the count value has not been loaded. The following shows the NULL COUNT flag changes.

- 1. Write to the control word register NULL COUNT=1
- 2. Write a count value to the count register (Note): NULL COUNT=1
- 3. Load from the count register into the down-counter: NULL COUNT = 0

Note: When the 2-byte mode is specified by the control word register, the NULL COUNT flag goes "1" upon writing the second byte.

The status latch is held until the status is read or the counter is reprogrammed. When the status latch is specified by the read-back command on a counter twice, the second one is ignored. The data to be read is the data present at the time the first status latch was performed.

The multiple count latch and status latch by the read-back command can be performed simultaneously by setting the  $\overline{\text{COUNT}}$  and  $\overline{\text{STATUS}}$  bits  $D_5$  and  $D_4$  to "0". This performs the same operation as the one in which multiple count latch and status latch are performed separately. Like the simultaneous latch, each latch in this case is held until it is read or the counter is reprogrammed.

If the multiple latch and status latch are performed on a counter twice, the second ones are ignored. The following shows a read-back command programming example.

| Road back command                   | Counter 0 latch |        | Counte  | r 1 latch | Counter 2 latch |        |
|-------------------------------------|-----------------|--------|---------|-----------|-----------------|--------|
| Read back command                   | Count           | Status | Count   | Status    | Count           | Status |
| Initial State                       | non             | non    | non     | non       | non             | non    |
| Counter 1<br>Status Latch           | non             | non    | non     | latch     | non             | non    |
| Counter 2 Count<br>& Status Latch   | non             | non    | non     | latch     | latch           | latch  |
| Counter 0, 2<br>Status Latch        | non             | latch  | non     | latch     | latch           | ignore |
| Counter 0<br>Count Latch            | latch           | latch  | non     | latch     | latch           | latch  |
| Counter 0 Status<br>Count Read      | non             | non    | non     | latch     | latch           | latch  |
| Counter 1 Count<br>& Status Latch   | non             | non    | · latch | ignore    | latch           | latch  |
| Counter 0, 2 Count<br>& State Latch | latch           | latch  | latch   | latch     | ignore          | ignore |

| Table 6.1 | Read-back | command | programn | ning example |
|-----------|-----------|---------|----------|--------------|
| Tuble 0.1 | neuu buck | communu | programm | ing example  |

050489

When both multiple count latch and status latch are performed by the read-back command, the status data is read in the first read of the counter regardless of the latch execution sequence. The value of the latched count register is read in the reading of the next 1 or 2 bytes (depending on the counter mode setting)

| CS | RD | WR | A <sub>1</sub> | A <sub>0</sub> | Function                  | 1         |
|----|----|----|----------------|----------------|---------------------------|-----------|
| 0  | 1  | 0  | 0              | 0              | Write Counter 0           | 1         |
| 0  | 1  | 0  | 0              | 1              | Write Counter 1           | 1         |
| 0  | 1  | 0  | 1              | 0              | Write Counter 2           | 1         |
| 0  | 1  | 0  | 1              | 1              | Write Control word        | 1         |
| 0  | 0  | 1  | 0              | 0              | Read Counter 0            | 1         |
| 0  | 0  | 1  | 0              | 1              | Read Counter 1            | 1         |
| 0  | 0  | 1  | 1              | 0              | Read Counter 2            | 1         |
| 0  | 0  | 1  | 1              | 1              | ,                         |           |
| 1  | ×  | ×  | ×              | ×              | Non Operation (3 – State) | X : Don't |
| 0  | 1  | 1  | ×              | ×              |                           |           |

Table 6.2 Read/Write Addressing

Care

# 7. MODE DESCRIPTION

The TMP82C54 has the 6 count modes. Each count mode has the following characteristics.

- When the control word is written, the output is initialized to the state unique to each mode.
- The GATE is sampled at each rising edge of CLK. In modes 0 and 4, the GATE operates by level sense; in modes 1 and 5, it operates by rising-edge sense; and in modes 2 and 3, it operates by level sense and rising-edge sense respectively.
- The down-counter performs count loading and decrement at the falling edge of CLK.
- The maximum counter value is 0. (2<sup>16</sup> in binary, 10<sup>4</sup> in decimal)
- The counter keeps decrementing until 0 (terminal count) is reached.
- In modes 0, 1, 4, and 5, count continues even if the count value reaches 0. In modes 2 and 3, the initial value is reloaded upon reaching the terminal count for repeated counting.

### Terminology

| Clock pulse    | : | From the rising edge to falling edge of CLK input.                    |  |  |  |  |  |
|----------------|---|-----------------------------------------------------------------------|--|--|--|--|--|
| Trigger        | : | The rising edge of the GATE input.                                    |  |  |  |  |  |
| Count loading  | : | Loading of count value from the count register into the down-counter. |  |  |  |  |  |
| Mode setting   | : | Writing of the control word.                                          |  |  |  |  |  |
| Terminal count | : | Reaching of the down-counter to 0.                                    |  |  |  |  |  |

The following sample waveform of each mode shows the binary count and read/write LSB programming case. The numbers indicate down-counter values.

#### 7.1 MODE 0: INTERRUPT ON TERMINAL COUNT

The output is initialized to the low level after setting the mode. The output remains low after count loading. When the GATE input is high, the down-counter starts counting.

When the terminal count has been reached, the output goes high, which is held until a new count value is written or another mode is set.

The GATE input only controls the down-counter operation: it does not affect the output state.

The count value is loaded to the counter by the clock pulse following the writing of the count value to the count register.

The down-counter continues counting after the terminal count has been reached. Rewriting to the count register during counting will cause the following actions.

- 1. When the first byte is written, the current count is suspended. The output is set to the low level.
- 2. When the second byte is written, count starts with the next clock pulse upon which the now counting starts.



#### 7.2 MODE 1: PROGRAMMABLE ONE-SHOT

The output is initialized to the high level after setting this mode and is reset to the low level by the clock pulse following the trigger. Then, the output goes high after the terminal count has been reached. The counter performs the following operations with the trigger:

- 1. Loading
- 2. Setting the output to the low level (reset)
- 3. Start counting

The one-shot pulse of GATE can be retriggered. Therefore, the output remians low until complete counting is made after triggering.

When a new count value is written while the output is low, the width of the one-shot pulse already output is not affected upon the next trigger.



#### 7.3 MODE 2: RATE GENERATOR

Division-by-N counter is performed.

The output is initialized to the high level after setting this mode, and goes low for 1 clock pulse when the counter has reached 1. Then, the output goes high again and the initial count is loaded for infinite counting.

When the GATE = 1, counting is enabled. When the GATE = 0, counting is disabled and the output is set to the high level. By the trigger, the initial value is loaded into the counter at the next clock pulse, starting new counting. Thus, the gate input can be used for counter synchronization. When mode 2 is set, the output goes high, which is held until count loading is performed, so that synchronization can be provided by software as well.

Rewriting to the count register being counted does not affect the current cycle. A new cycle starts after the end of the current cycle.

The minimum count of this mode is 2.



#### 7.4 MODE 3: SQUARE WAVE RATE GENERATOR

The output is initialized to the high level after setting this mode. The half of the count setting value (even number) becomes high and the other half becomes low. The rest is the same as mode 2.

When the GATE = 1, counting is enabled. When the GATE = 0, counting is disabled and the output is set to the high level.

When the count setting value is an even number, counting is performed by decrementing the counter by 2 at the falling edge of the clock input.

When the terminal count has been reached, the output is inverted, the count setting value is reloaded into the counter, the counter is decremented by 2, this process is repeated.

If the count value is an odd number and its output is high, the value which is the setting value - 1 is loaded into the down-counter, which is decremented by 2. The output goes low at the clock pulse following the terminal count and the setting value - 1 is loaded into the down-counter again. Then, the count has been reached, this process is repeated.

Thus, when the count value is odd, the output is high for  $(\mathrm{N}+1)/2$  and low for  $(\mathrm{N}-1)/2.$ 

The minimum count of this mode is 2.



#### 7.5 MODE 4: SOFTWARE-TRIGGERED STROBE

The output goes high after setting this mode. When the count value is loaded into the down counter and the GATE input is high, the down-counter starts counting.

When the terminal count has been reached, the output goes low for 1 clock pulse.

When GATE = 0, counting is disabled. When GATE = 1, counting is enabled. The GATE input dose not affect the output.

When the count value is written to the count register after setting the mode, count loading is performed with the next clock pulse.

When a new count value is written during counting, loading is performed with the following clock pulse and the counting continues with the new count value.

In the 2-byte mode, the following actions take place.

- 1. Writing of the first byte does not affect the counting.
- 2. With the clock pulse following the writing of the second byte, count loading starts.



#### 7.6 MODE 5: HARDWARE-TRIGGERED STROBE

The output is initialized to the high level after setting this mode. The counter starts counting after the GATE input is triggered. When the terminal count has been reached, the output goes low for 1 clock pulse.

Count loading starts with the clock pulse following the trigger after the mode is set and the count value is written.

The counter can be re-triggered.

The output remains high until a complete count is mode after triggering any GATE input.

If a new count value is written to the count register during counting, the current counting continues. If a trigger is encountered, the new count value is loaded with the following clock pulse and counting starts with the new count value.



| Status<br>Modes | Low or Going Low                                                                         | Low or Going Low Rising                                                             |                 |  |  |
|-----------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-----------------|--|--|
| 0               | Disables counting                                                                        | _                                                                                   | Enable counting |  |  |
| 1               | _                                                                                        | <ul><li>(1) Initiates counting</li><li>(2) Resets output after next clock</li></ul> | -               |  |  |
| 2               | <ul><li>(1) Disables counting</li><li>(2) Sets output</li><li>immediately High</li></ul> | Initiates counting                                                                  | Enable counting |  |  |
| 3               | <ul><li>(1) Disables counting</li><li>(2) Sets output<br/>immediately High</li></ul>     | Initiates counting                                                                  | Enable counting |  |  |
| 4               | Disables counting                                                                        | -                                                                                   | Enable counting |  |  |
| 5               | -                                                                                        | Initiates counting                                                                  | -               |  |  |

Table 7.1 Gate Input Operations

| Mode | Min count | Max count |
|------|-----------|-----------|
| 0    | 1         | 0 .       |
| 1    | 1         | 0         |
| 2    | 2         | 0         |
| 3    | 2         | 0         |
| 4    | 1         | 0         |
| 5    | 1         | 0         |
|      |           | 050489    |

Table 7.2 Minimum and Maximum Count Values

# 8. ELECTRIC CHARACTERISTICS

# 8.1 MAXIMUM RATINGS

| SYMBOL                          | ITEMS                 | TEST CONDITION  | RATING                   | UNIT |
|---------------------------------|-----------------------|-----------------|--------------------------|------|
| V <sub>CC</sub>                 | Suply Voltage         | - 0.5~ + 7.0    |                          | V    |
| V <sub>IN</sub>                 | Input Voltage         | With Respect To | $-0.5 \sim V_{CC} + 0.5$ | V    |
| V <sub>OUT</sub> Output Voltage |                       | GND.            | $-0.5 \sim V_{CC} + 0.5$ | V    |
| PD                              | Power Dissipation     |                 | 250                      | mW   |
| T <sub>sol</sub>                | Solder Temperature    |                 | 260 (10sec)              | Ĵ    |
| T <sub>stg</sub>                | Storage Temperature   |                 | - 65~ + 150              | Ĵ    |
| T <sub>opr</sub>                | Operating Temperature |                 | - 40~ + 85               | °C   |

050489

## 8.2 DC CHARACTERISTICS (TA = -40 to $+85^{\circ}$ C, VCC = 5V $\pm 10^{\circ}$ , VSS (GND) = 0V)

| SYMBOL           | ITEM                        | TEST CONDITION                                         | MIN.                  | TYP. | MAX.                  | UNIT |
|------------------|-----------------------------|--------------------------------------------------------|-----------------------|------|-----------------------|------|
| V <sub>IL</sub>  | Input Low Voltage           |                                                        | - 0.5                 | -    | 0.8                   | V    |
| V <sub>IH</sub>  | Input High Voltage          |                                                        | 2.2                   |      | V <sub>CC</sub> + 0.5 | V    |
| V <sub>OL</sub>  | Output Low Voltage          | I <sub>OL</sub> = 2.2mA                                |                       |      | 0.45                  | V    |
| V <sub>OH1</sub> | Output High Voltage         | I <sub>OH</sub> = -400µА                               | 2.4                   | _    | -                     | V    |
| V <sub>OH2</sub> | Output High Voltage         | I <sub>OH</sub> = - 100µА                              | V <sub>CC</sub> – 0.8 | -    | -                     | V    |
| lıL              | Input Leak Current          | $0V \leq V_{IN} \leq V_{CC}$                           | —                     | _    | ± 10                  | μA   |
| IOFL             | Output Leakage<br>Current   | $0.45V \leq V_{OUT} \leq V_{CC}$                       |                       |      | ± 10                  | μA   |
| ICC1             | Operating Supply<br>Current | $CLK = 10MHz$ $V_{IH} = V_{CC} - 0.2V$ $V_{IL} = 0.2V$ |                       |      | 30                    | mA   |
| I <sub>CC2</sub> | Stand-by Supply<br>Current  | $CLK = DC$ $V_{IH} = V_{CC} - 0.2V$ $V_{IL} = 0.2V$    |                       | -    | 10                    | μA   |

# 8.3 AC CHARACTERISTICS (TA = -40 to $+85^{\circ}$ C, VCC = 5V ± 10%, VSS(GND) = 0V)

# 8.3.1 Read/Write

| SVMPOL          | ITENA                    | P-2/M-2 |      | UNIT |
|-----------------|--------------------------|---------|------|------|
| STIVIBUL        |                          |         | MAX. |      |
| t <sub>AR</sub> | Address Set-up Time (RD) | 30      | -    | ns   |
| t <sub>SR</sub> | CS Set-up Time (RD)      | 0       | -    | ns   |
| t <sub>RA</sub> | Address Hold Time (RD)   | 20      |      | ns   |
| t <sub>RR</sub> | RD Pulse Width           | 95      | —    | ns   |
| t <sub>RD</sub> | Valid Data (RD)          | —       | 85   | ns   |
| t <sub>AD</sub> | Valid Data (Address)     |         | 185  | ns   |
| t <sub>DF</sub> | Data Floating (RD)       | 5       | 65   | ns   |
| t <sub>AW</sub> | Address Set-up Time (WR) | 0       | -    | ns   |
| t <sub>SW</sub> | CS Set-up Time (WR)      | 0       | _    | ns   |
| t <sub>WA</sub> | Address Hold Time (WR)   | 0       | —    | ns   |
| tww             | WR Pulse Width           | 95      | -    | ns   |
| t <sub>DW</sub> | Data Set-up Time (WR)    | 95      | _    | ns   |
| t <sub>WD</sub> | Data Hold Time (WR)      | 0       |      | ns   |
| t <sub>RV</sub> | Recovery Time            | 165     |      | ns   |

### 8.3.2 Clock/Gate

| SYMBOL           | ITEM                            |     | P-2/M-2 |    |
|------------------|---------------------------------|-----|---------|----|
| STINBOL          |                                 |     | MAX.    |    |
| t <sub>CLK</sub> | Clock Period                    | 100 | DC      | ns |
| t <sub>PWH</sub> | CLK High Pulse Width            | 30  | _       | ns |
| t <sub>PWL</sub> | CLK Low Pulse Width             | 30  | -       | ns |
| t <sub>R</sub>   | CLK Rise Time                   | -   | 25      | ns |
| t <sub>F</sub>   | CLK Fall Time                   | -   | 25      | ns |
| t <sub>GW</sub>  | GATE Width High                 | 50  | _       | ns |
| t <sub>GL</sub>  | GATE Width LOW                  | 50  | -       | ns |
| t <sub>GS</sub>  | GATE Set-up Time (CLK)          | 40  | _       | ns |
| t <sub>GH</sub>  | GATE Hold Time (CLK)            | 50  | -       | ns |
| t <sub>OD</sub>  | Output Delay From CLK           | -   | 100     | ns |
| t <sub>ODG</sub> | Output Delay From GATE          | -   | 100     | ns |
| t <sub>WC</sub>  | Count Loading Set-up Time (CLK) | 80  | -       | ns |
| t <sub>WG</sub>  | WR Set-up Time (GATE)           | 0   | _       | ns |
| t <sub>WO</sub>  | Output Delay From Command Write | -   | 240     | ns |
| t <sub>CL</sub>  | CLK Set-up Time (Count Latch)   | 68  | -       | ns |

050489

# 8.4 INPUT CAPACITY (TA = $25^{\circ}$ C, VCC = VSS (GND) = 0V)

| SYMBOL           | ITEMS                   | TEST CONDITION       | MIN. | TYP. | MAX. | UNIT |
|------------------|-------------------------|----------------------|------|------|------|------|
| C <sub>IN</sub>  | Input Capacitance       | fc = 1MHz Unmeasured |      |      | 10   | рF   |
| C <sub>I/O</sub> | Inut/Output Capacitance | pins, 0V             |      |      | 20   | рF   |

050489

### 8.5 AC TEST INPUT WAVEFORM



Figure 8.1 AC test input waveform

# 9. TIMING DIAGRAM



Figure 9.1 Read Operation









# **10. EXTERNAL DIMENSIONS**

# 10.1 24 PIN DIP EXTERNAL DIMENSIONS

DIP24-P-600



270289



Unit : mm
### 10.2 24 PIN SOP EXTERNAL DIMENSION

### SOP24-P-450B



270289

Note : Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

# PROGRAMMABLE INTERVAL TIMER

# TMP8253P-5

# 1. GENERAL DESCRIPTION

The TMP8253P-5 (hereinafter referred to as TMP8253) is a programmable counter/timer chip designed for use as the TLCS-85A microcomputer peripheral. It is organized as 3 independent 16 bit counters, each operates with a count rate of up to 2.6MHz. All modes of operation are software programmable.

## 2. FEATURES

- Count Binary or BCD
- 3 Independent 16 Bit Counters
- Single + 5V Supply
- Count rate DC to 2.6MHz
- 6 programmable Counter Modes
- Compatible with Intel's 8253-5
- 3. PIN CONNECTIONS

|                |   |    | · · · · ·  |    | - |                 |
|----------------|---|----|------------|----|---|-----------------|
| D7             | C | 1  | $\bigcirc$ | 24 | þ | V <sub>CC</sub> |
| D <sub>6</sub> | ۵ | 2  |            | 23 | þ | WR              |
| D5             | C | 3  |            | 22 | þ | RD              |
| D4             | ٢ | 4  |            | 21 | þ | CS              |
| D <sub>3</sub> | ۵ | 5  |            | 20 | þ | A <sub>1</sub>  |
| D <sub>2</sub> | C | 6  |            | 19 | þ | A <sub>0</sub>  |
| D <sub>1</sub> | ۵ | 7  |            | 18 | þ | CLK2            |
| Do             | C | 8  |            | 17 | þ | OUT2            |
| CLK0           | d | 9  |            | 16 | þ | GATE2           |
| OUTO           | ٢ | 10 |            | 15 | þ | CLK1            |
| GATE0          | C | 11 |            | 14 | þ | GATE1           |
| GND            | þ | 12 |            | 13 | þ | OUT1            |
|                |   |    |            |    |   |                 |

| ruble 5:1 Thirtuines  |  |  |  |  |
|-----------------------|--|--|--|--|
| Data Bus (8 bit)      |  |  |  |  |
| Counter Clock Input   |  |  |  |  |
| Counter Gate Input    |  |  |  |  |
| Counter Output        |  |  |  |  |
| Read Counter          |  |  |  |  |
| Write Command or Data |  |  |  |  |
| Chip Select           |  |  |  |  |
| Counter Select        |  |  |  |  |
| + 5V                  |  |  |  |  |
| Ground (0V)           |  |  |  |  |
|                       |  |  |  |  |

## Table 3.1 Pin Names

# 4. BLOCK DIAGRAM



# 5. PIN NAMES AND PIN DESCRIPTION

- GND (Power Supply) Ground
- V<sub>CC</sub> (Power Supply)

+5V during operation.

•  $\overline{\mathrm{CS}}$  (Input)

A low level input on this pin enables  $\overline{RD}$  and  $\overline{WR}$  communication between the MPU and the TMP8253. The  $\overline{CS}$  input has no effect upon the actual operation of the counters.

• A0, A1 (Input)

These inputs acts in conjunction with the  $\overline{CS}$ ,  $\overline{WR}$ , and  $\overline{RD}$  pins. This pin is used to select one of the three counters to be operated on and to address the control word register for mode selection.

• WR (Input)

A low level input on this pin when  $\overline{CS}$  is low enables the TMP8253 to accept mode information or loading counters from the MPU.

• RD (Input)

A low level input on this pin when  $\overline{\text{CS}}$  is low enables the TMP8253 to output a counter value onto the data bus for the MPU.

• D0~D7 (Input/Output)

Bidirectional Data Bus. Mode information, the information loading counter or the count values are transfered via this data bus.

• CLK0~CLK2 (Input)

Clock inputs to counters. Falling edge on this pin enables the counter to countdown.

• GATE0~GATE2 (Input)

Gate inputs to counters. The function of this pin differs by the mode selection of counter operation.

• OUT0~OUT2 (Output)

 $\mbox{Outputs}$  from the counters. The output signal from this pin differs by the mode seleciton of counter operation.

## 6. FUNCTIONAL DESCRIPTION

### [Block Description]

### Data Bus Buffer

This is 3-state, bidirectional, 8 bit buffer used for interfacing the TMP8253 to the system data bus. The Data Bus Buffer has three functions as follows. Programming the Modes of the TMP8253, Loading the count registers, and Reading the count values.

#### Read/Write Logic

The Read/Write logic accepts inputs from the system bus and in turn generates control signals for overall device operation.

| CS | RD | WR | A <sub>1</sub> | A <sub>0</sub> |                                     |
|----|----|----|----------------|----------------|-------------------------------------|
| 0  | 1  | 0  | 0              | 0              | Load Counter # 0                    |
| 0  | 1  | 0  | 0              | 1              | Load Counter # 1                    |
| 0  | 1  | 0  | 1              | 0              | Load Counter #2                     |
| 0  | 1  | 0  | 1              | 1              | Write Mode Word                     |
| 0  | 0  | 1  | 0              | 0              | Read Counter # 0                    |
| 0  | 0  | 1  | 0              | 1              | Read Counter # 1                    |
| 0  | 0  | 1  | 1              | 0              | Read Counter # 2                    |
| 0  | 0  | 1  | 1              | 1              |                                     |
| 1  | ×  | ×  | ×              | ×              | Data Bus is in High-impedance state |
| 0  | 1  | 1  | ×              | ×              |                                     |
|    |    |    |                |                | 050489                              |

| Fable 6.1 Addı | ressing |
|----------------|---------|
|----------------|---------|

#### Control Word Register

The Control Word Reginter is selected when A0, A1 are 11. It then accepts information from the data bus buffer and stores it in a register. The information stored in this register controls the operational Mode of each counter, selection of binary or BCD counting and the loading of each count register. No reading of the contents of the Control Word Register is available.

#### Counter #0, Counter #1, Counter #2

These three blocks are identical so only a single counter will be described. Each counter consists of a single, 16 bit, presettable, down counter. The counter can operate in either binary or BCD and its input, GATE and output are configured by the selection of Modes (Six MODES : MODE 0 to MODE 5) stored in the Control Word Register. Also the control word handles the loading of the count value so that software overhead can be minimized for these functions.

The reading of the contents of each counter is available to the programmer with simple read operations for event counting applications. Special commands and logic are included in the TMP8253 so that the contens of each count value can be read "on-the-fly" without having to inhibit the clock input.

### [MODE Definition]

MODE 0 : Interrupt on Terminal Count

The output will be initially low after the mode set operation. After the count is loaded into the selected count register, the output will remain low and the counter will count. When terminal count is reached the output will go high and remain high until the selected count register is reloaded with the mode or a new count is loaded. The counter continues to decrement after terminal count had been reached.

Rewriting a counter register during counting results in the following :

- (1) Write 1st byte stops the current counting.
- (2) Write 2nd byte starts the new count.

### MODE 1 : Programmable One Shot

The output will go low on the count following the rising edge of the GATE input.

The output will go high on the terminal count. If a new count value is loaded while the output is low it will not affect the duration of the one-shot pulse until the succeeding trigger. The current count can be read at any time without affecting the one-shot pulse.

The one-shot is retriggerable, hence the output will remain low for the full count after any rising edge of the GATE input.

### MODE 2 : Rate Generater

Divide by N counter. The output will be low for one period of the input clock. The period from one output pulse to the next equals the number of input counts in the count register. If the count register is reloaded between output pulses the present period will not be affected, but the subsequent period will reflect the new value.

The GATE input, when low, will force the output high. When the GATE input goes high, the counter will start form the initial count. Thus, the GATE input can be used to synchronize the counter.

When this mode is set, the output will remain high until after the count register is loaded. The output then can also be synchronized by software.

### MODE 3 : Square Wave Rate Generator

Similar to MODE 2 except that the output will remain high until one half the count has been completed (for even numbers) and go low for the other half of the count. This is accomplished by decrementing the counter by two on the falling edge of each clock pulse. When the counter reaches terminal count, the state of the output is changed and the counter is reloaded with the full count and the whole process is repeated.

If the count is odd and the output is high, the first clock pulse (after the count is loaded) decrements the count by 1. Subsequent clock pulses decrement the clock by 2. After timeout, the output goes low and the full count is reloaded. The first clock pulse (following the reload) decriments the counter by 3. Subsequent clock pulses decrement the count by 2 until timeout. Then the whole process is repeated. In this way, if the count is odd, the output will be high for (N + 1)/2 counts and low for (N - 1)/2 counts.

MODE 4 : Software Triggered Strobe

After the mode is set, the output will be high. When the count is loaded, the counter will begin counting. On terminal count, the output will go low for one input clock period, then will go high again.

If the count register is reloaded between output pulses, counting will continue from the new value, The count will be inhibited while the GATE input is low, Reloading the counter register will restart counting beginning with the new number.

#### MODE 5 : Hardware Triggered Strobe

The counter will start counting after the rising edge of the trigger input and will go low for one clock period when the terminal count is reached. The counter is retriggerable. The output will not go low until the full count after the rising edge of any trigger.

| Status<br>Modes | Low or Going Low                                                                         | Rising                                                                                     | High             |
|-----------------|------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|------------------|
| 0               | Disables counting                                                                        | -                                                                                          | Enables counting |
| 1               | -                                                                                        | <ol> <li>(1) Initiates counting</li> <li>(2) Resets output after<br/>next clock</li> </ol> | _                |
| 2               | <ul><li>(1) Disables counting</li><li>(2) Sets output</li><li>immediately High</li></ul> | Initiates counting                                                                         | Enables counting |
| 3               | <ul><li>(1) Disables counting</li><li>(2) Sets output<br/>immediately High</li></ul>     | Initiates counting                                                                         | Enables counting |
| 4               | Disables counting                                                                        | -                                                                                          | Enables counting |
| 5               | -                                                                                        | Initiates counting                                                                         | -                |

Table 6.2 Gate Pin Operaions



MODE 1: Programmable One-Short





MODE 3 : Square Wave Generator



MODE 4 : Software-Triggered Strobe





MODE 5 : Hardware-Triggered Strobe





## 7. PROGRAMMING THE TMP8253

All of the Modes for each counter are programmed by the systems software by simple I/O operations.

Each counter of the TMP8253 is individually programmed by writing a control word into the Control Word Register.  $(\overline{CS}=0, A0=A1=1, \overline{WR}=0)$ .



Note SC: Select Counter, RL: Read/Load, M: Mode, BCD: Binary Coded Decimal.

The programmer must write out to the TMP8253 a Mode Control Word and the programmed number of count register bytes (1 or 2) prior to actually using the selected counter.

The acctual order of the programming is quite flixible. Writing out ot the Mode Control Word can be in any sequence of counter selection.

The loading of the Count Register with actual count value, however, must be done in exactly the sequence programmed in the Mode Control Word (RL0, RL1).

## 8. COUNTER LOADING

The count register is not loaded until the count value is written (one or two bytes, depending on the mode selected by the RL bits), followed by a rising edge and a falling edge of the clock.

The count register must be loaded with the number of bytes programmed in the Mode Control Word. The one or two bytes to be loaded in the count register do not have to follow the associated Mode Control Word. They can be programmed at any time following the Mode Control Word loading as long as correct number of bytes is loaded in order.

All counters are down counters. Loading all zeros will result in the maximum count  $(2^{16} \text{ for Binary or } 10^4 \text{ for BCD})$ . In MODE 0 and MODE 4, the new count will not restart until the load has been completed.

## 9. READ OPERATIONS

The TMP8253 contains logic that will allow the programmer to easily read the contents of any of the three counters without disturbing the actual count in progress.

There are two methods that the programmer can use to read the value of the counters. The first method involves the use of simple I/O read operations. By controlling the A0, A1 inputs to the TMP8253, the programmer can select the counter to be read. The only requirement with this method is that in order to assure a stable count reading the actual operation of the selected counter must be inhibited either by controlling the GATE input or by external logic that inhibits the clock input.

The contents of the counter selected must be read in the sequence programmed in the Mode Control Word (RL0, RL1). When RL0, RL1 is 11. First I/O read contains the least significant byte (LSB), second I/O read contains the most significant byte (MSB), and the two bytes must be read before any loading WR command can be sent to the same counter.

The second method allows the programmer to read the contents of any counter without affecting or disturbing the counting operation. When the programmer wishes to read the contents of a selected counter "On-the-fly", he loads the MODE register with a special code which latches the present count value into a storage register so that its contents contain an accurate, stable quantity. The programmer then issues a normal read command to the selected counter. The contents of the latched register must be read in the sequence programmed in the Mode Control Word (RL0, RL1). This commands has no effect on the counters mode.

# 10. PROGRAM EXAMPLE

|                   | MVI   | A,00110000B |       | #0, LSB $\rightarrow$ MSB, MODE 0, Binary |
|-------------------|-------|-------------|-------|-------------------------------------------|
|                   | OUT   | CWAD        |       | The address of Control Word Register      |
| Set up sequence   | MVI   | A, 53H      |       | LSB for counter #0                        |
| for counter #0    | OUT   | CNT0        |       | The address of counter #0                 |
|                   | MVI   | A, 82H      |       | MSB for counter #0                        |
|                   | _OUT  | CNT0        |       | The address of counter #0                 |
|                   | _ :   |             |       |                                           |
|                   | MVI   | A,0000XXXXB |       |                                           |
| READ the contents | OUT   | CWAD        |       | Latching count                            |
| of counter #0     | IN    | CNT0        |       | Read LSB of counter #0                    |
|                   | MOV   | L, A        |       |                                           |
|                   | IN    | CNT0        |       | Read MSB of counter #0                    |
|                   | _mov  | Н, А        |       |                                           |
|                   |       |             |       |                                           |
|                   | IVIVI | А, 82Н      | ••••  |                                           |
| counter #0        | OUT   | CNT0        | ••••• | Load LSB for counter #0                   |
|                   | MVI   | A, 53H      |       |                                           |
|                   | _OUT  | CNT0        |       | Load MSB for counter #0                   |
|                   |       |             |       |                                           |

# **11. ELECTRIC CHARACTERISTICS**

## 11.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                                                      | RATING            |
|------------------|-----------------------------------------------------------|-------------------|
| V <sub>CC</sub>  | $V_{CC}$ Suply Voltage (with respect to GND ( $V_{SS}$ )) | – 0.5V to + 7.0V  |
| V <sub>IN</sub>  | Input Voltage (with respect to GND ( $V_{SS}$ ))          | - 0.5V to + 7.0V  |
| V <sub>OUT</sub> | Output Voltage (with respect to GND (Vss))                | – 0.5V to + 7.0V  |
| PD               | Power Dissipation                                         | 1 VV              |
| T <sub>sol</sub> | Soldering Temperature (Soldering Time 10 sec)             | 260°C             |
| T <sub>stg</sub> | Storage Temperature                                       | – 65°C to + 150°C |
| T <sub>opr</sub> | Operating Temperature                                     | 0°C to 70°C       |

050489

# 11.2 DC CHARACATERISTICS (Ta = 0°C to 70°C, $V_{CC}$ = 5.0V ± 5%, GND = 0V)

| SYMBOL           | PARAMETER           | TEST CONDITIONS                | MIN.  | TYP. | MAX.                  | UNIT |
|------------------|---------------------|--------------------------------|-------|------|-----------------------|------|
| VIL              | Input Low Voltage   |                                | - 0.5 |      | 0.8                   | V    |
| VIH              | Input High Voltage  |                                | 2.2   |      | V <sub>CC</sub> + 0.5 | V    |
| VOL              | Output Low Voltage  | I <sub>OL</sub> = 2.2mA        |       |      | 0.45                  | V    |
| V <sub>OH</sub>  | Output High Voltage | I <sub>OH</sub> = -400μA       | 2.4   |      |                       | V    |
| ١ <sub>١L</sub>  | Input Leak Current  | $0V \leq V_{IN} \leq V_{CC}$   |       |      | ± 10                  | μA   |
| I <sub>OFL</sub> | Output Leak Current | $0.45V \le V_{OUT} \le V_{CC}$ |       |      | ± 10                  | μA   |
| Icc              | Supply Current      |                                |       |      | 140                   | mA   |

050489

# 11.3 INPUT CAPACITANCE (Ta = $25^{\circ}$ C, V<sub>CC</sub> = GND = 0V)

| SYMBOL           | PARAMETER                    | TEST CONDITIONS        | MIN. | TYP. | MAX. | UNIT |
|------------------|------------------------------|------------------------|------|------|------|------|
| C <sub>IN</sub>  | Input Capacitance            | f <sub>C</sub> = 1 MHz |      |      | 10   | pF   |
| C <sub>I/O</sub> | Inputy/Output<br>Capacitance | Unmeasured pins, 0V    |      |      | 20   | pF   |

### **11.4 AC CHARACTERISTICS**

 $(Ta = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5.0V \pm 5\%, GND = 0V)$ 

| SYMBOL           | PARAMETER                                         | TEST CONDITIONS        | MIN. | TYP. | MAX. | UNIT |
|------------------|---------------------------------------------------|------------------------|------|------|------|------|
| t <sub>AR</sub>  | Address Set up Time (RD↓)                         |                        | 30   |      |      | ns   |
| t <sub>RA</sub>  | Address Hold Time ( $\overline{RD} \uparrow$ )    | ×                      | 5    |      |      | ns   |
| t <sub>RR</sub>  | RD Pulse Width                                    |                        | 300  |      |      | ns   |
| t <sub>RD</sub>  | Valid Data (RD↓)                                  | C <sub>L</sub> = 150pF |      |      | 200  | ns   |
| t <sub>DF</sub>  | Data Floating ( $\overline{RD} \uparrow$ )        |                        | 25   |      | 100  | ns   |
| t <sub>RV</sub>  | Recovery Time                                     |                        | 1    |      |      | μs   |
| t <sub>AW</sub>  | Address Set up Time ( $\overline{WR}\downarrow$ ) |                        | 30   |      |      | ns   |
| t <sub>WA</sub>  | Address Hold Time (₩R↑)                           |                        | 30   |      |      | ns   |
| tww              | WR Pulse Width                                    |                        | 300  |      |      | ns   |
| t <sub>DW</sub>  | Data Set up Time (₩R ↑ )                          |                        | 250  |      |      | ns   |
| t <sub>WD</sub>  | Data Hold Time (WR↑)                              |                        | 30   |      |      | ns   |
| t <sub>CLK</sub> | Clock Period                                      |                        | 380  |      | DC   | ns   |
| t <sub>PWH</sub> | CLK High Pulse width                              |                        | 230  |      |      | ns   |
| t <sub>PWL</sub> | CLK Low Pulse Width                               |                        | 150  |      |      | ns   |
| t <sub>GW</sub>  | GATE Width High                                   |                        | 150  |      |      | ns   |
| t <sub>GL</sub>  | GATE Width Low                                    |                        | 100  |      |      | ns   |
| t <sub>GS</sub>  | GATE Set up Time (CLK↑)                           |                        | 100  |      |      | ns   |
| t <sub>GH</sub>  | GATE Hold Time (CLK↑)                             |                        | 50   |      |      | ns   |
| t <sub>OD</sub>  | Output Delay From (CLK↓)                          | C <sub>L</sub> = 150pF |      |      | 400  | ns   |
| t <sub>ODG</sub> | Output Delay From (GATE↓)                         | C <sub>L</sub> = 150pF |      |      | 300  | ns   |

050489

Note : AC timings measured at  $V_{\rm OH}\!=\!2.2V, V_{\rm OL}\!=\!0.8V$ 

# 12. TIMING DIAGRAM



050489





Figure 12.2 Write Timing





# 13. EXTERNAL DIMENSION VIEW

## 13.1 24PIN DIP

DIP24-P-600

Unit : mm



270289

Note: Lead pitch is 2.54mm and tolerance is  $\pm 0.25$ mm against theoretical center of each lead that is obtained on the basis of No. 1 and No. 24 leads.

# CMOS PROGRAMMABLE PERIPHERAL INTERFACE

# TMP82C55AP-2/TMP82C55AM-2 TMP82C55AP-10/TMP82C55AM-10

# 1. GENERAL DESCRIPTION AND FEATURES

The TMP82C55A (hereinafter referred to as PPI) is a CMOS high Speed programmable input/output interface with three 8-bit I/O ports. 24 I/O Ports are divided into two groups (Port A and Port B) which are programmable independently by control words provided by MPU. The PPI has three operation modes (Mode 0, 1 and 2) and is copable of versatile interface between MPU and peripheral devices.

The TMP82C55A is fabricated using Toshiba's CMOS Silicon Gate Technology.

- (1) High Speed Version (TRD=100ns MAX: TMP82C55AP-10/AM-10)
- (2) Low power consumption
   2mA Type.
   10µA Max. (@5V, Stand-by)
- (3)  $5V \pm 10\%$  Single power supply
- (4) 24 programmable I/O ports
- (5) Three operation modes (Mode 0, Mode 1, Mode 2)
- (6) Bit set/reset capability
- Up to 8 output ports of port B and C are capable of driving a darlington transistor (Min.-1.0mA @VOH=1.5V)
- (8) Extended operating temperature: -40 °C to +85 °C
- (9) Available 40pin Standard DIP and SOP

### TOSHIBA

TMP82C55A

# 2. PIN CONNECTIONS (TOP VIEW)

|                         | the second second second second second second second second second second second second second second second se | 1                        |                           |
|-------------------------|-----------------------------------------------------------------------------------------------------------------|--------------------------|---------------------------|
| PA <sub>3</sub> [       | 1                                                                                                               | U 40                     | PA4                       |
| PA <sub>2</sub> [       | 2                                                                                                               | 39                       | PA5                       |
| PA <sub>1</sub> C       | 3                                                                                                               | 38                       | PA6                       |
| PA <sub>0</sub> [       | 4                                                                                                               | 37                       | PA7                       |
| RD                      | 5                                                                                                               | 36                       | ] WR                      |
| CS [                    | 6                                                                                                               | 35                       | RESET                     |
| (GND) V <sub>SS</sub> [ | 7                                                                                                               | 34                       | $D_0$                     |
| A1 [                    | 8                                                                                                               | 33                       | ] D1                      |
| A0 [                    | 9                                                                                                               | 32                       | D <sub>2</sub>            |
| PC7 [                   | 10                                                                                                              | 31                       | ] D3                      |
| PC <sub>6</sub> [       | 11                                                                                                              | 30                       | ] D4                      |
| PC5 [                   | 12                                                                                                              | 29                       | ] D5                      |
| PC4 [                   | 13                                                                                                              | 28                       | ] D <sub>6</sub>          |
| PC <sub>0</sub> [       | 14                                                                                                              | 27                       | ] D7                      |
| PC <sub>1</sub>         | 15                                                                                                              | 26                       | □ V <sub>CC</sub> ( + 5V) |
| PC <sub>2</sub>         | 16                                                                                                              | 25                       | PB7                       |
| · PC3 [                 | 17                                                                                                              | 24                       | ] PB6                     |
| PB <sub>0</sub> [       | 18                                                                                                              | 23                       | ] PB5                     |
| PB <sub>1</sub>         | 19                                                                                                              | 22                       | ] PB4                     |
| PB <sub>2</sub>         | 20                                                                                                              | 21                       | ] PB3                     |
| TN<br>TN                | 1P82C5<br>1P82C5                                                                                                | 5AP-2/AP-10<br>5AM-2/AM- | )<br>10                   |

# 3. BLOCK DIAGRAM



050489

#### MPU85-134

# 4. PIN NAMES AND PIN FUNCTIONS

| Pin Name                         | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                           |  |
|----------------------------------|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| D <sub>0</sub> ~D <sub>7</sub>   | 8                | I/O 3-state             | 3-state bidirectional 8-bit data bus. Used for data transfer with MPU. Also, used for transfer of control words to PPI and status information from PPI.                                                                                                                                                                                            |  |
| PA <sub>0</sub> ~PA <sub>7</sub> | 8                | I/O 3-state             | 3-state 8-bit I/O Port A.<br>Operation mode and input/output configuration are defined by<br>software. Port A contains the output latch buffer and input latch.                                                                                                                                                                                    |  |
| PB₀~PB7                          | 8                | I/O 3-state             | 3-state 8-bit I/O Port B.<br>Operation mode and input/output configuration are defined by<br>software. Port B contains the output latch buffer and input latch.                                                                                                                                                                                    |  |
| PC <sub>0</sub> ∼PC <sub>7</sub> | 8                | I/O 3-state             | 3-state 8-bit I/O Port C.<br>Operation mode and input/output configuration are defined by<br>software. Port C can be divided into two 4-bit ports by the mode<br>control and also, used as the control signal for Port A and Port B. In<br>this case, 3 bits of $PC_0$ to $PC_2$ are used for Port B and 5 bits of $PC_3$ to<br>$PC_7$ for Port A. |  |
| टड                               | 1                | Input                   | Chip select input.<br>When this terminal is at "L" level, data transfer PPI and MPU<br>becomes possible. At "H" level, the data bus is placed in the high<br>impedance state and control from the processor is ignored.                                                                                                                            |  |
| RD                               | 1                | Input                   | Read signal.<br>When this terminal is at "L" level, data that is input into the port is<br>transferred to MPU.                                                                                                                                                                                                                                     |  |
| WR                               | 1                | Input                   | Write signal.<br>When this terminal is at "L" level, data or control word is written<br>into PPI from MPU.                                                                                                                                                                                                                                         |  |
| A <sub>0</sub> , A <sub>1</sub>  | 2                | Input                   | Used for selecting Port A, B, C and the control registers. Normally, this terminal is connected to low order 2 bits of the address bus.                                                                                                                                                                                                            |  |
| RESET                            | 1                | Input                   | When this terminals is at "H" level, all internal registers including<br>the control register are cleared. In addition, all ports (Port A, B, C)<br>are placed in the input mode (high impedance) of mode 0.                                                                                                                                       |  |
| Vcc                              | 1                | Power Supply            | 5V                                                                                                                                                                                                                                                                                                                                                 |  |
| Vss                              | 1                | Power Supply            | GND                                                                                                                                                                                                                                                                                                                                                |  |

## 5. FUNCTIONAL DESCRIPTION

The PPI is a programmable peripheral interface device with three 8-bit ports (Port A, B and C) and two control registers. 24 I/O ports are divided into 12-bit group A and group B. Group A consists of Port A and high order 4 bits of Port C, while Group B consists of Port B and low order 4 bits of Port C. Each group is independently programmable by control words provided from MPU. There are three operation modes available for the PPI. In mode 0, two 8-bit I/O ports and two 4-bit I/O ports can be programmed as input or output ports, respectively. In mode 1, 24 I/O ports are divided into Group A and Group B. 8 bits of each group are used as input or output port and of the remaining 4 bits, 3 bits are used as handshaking and interrupt control signal. Mode 2 is applicable only to group A and the ports are used as a bidirectional 8-bit data bus and 5-bit control signal. In case of Port C being used as the output, any bits of Port C can be set/reset.

There are two control registers; one is used for mode setting and the other for bit set/reset control. The control registers can only be written into. Further, when the reset input (RESET) becomes "1", the control registers are reset and all I/O ports are placed in input mode (high impedance status).

| I | A <sub>1</sub> | A <sub>0</sub> | <u>CS</u> | RD | WR | Function                               |
|---|----------------|----------------|-----------|----|----|----------------------------------------|
| ſ | 0              | 0              | 0         | 0  | 1  | Data bus ← Port A                      |
|   | 0              | 1              | 0         | 0  | 1  | Data bus ← Port B                      |
| I | 1              | 0              | 0         | 0  | 1  | Data bus 🔶 Port C                      |
|   | 0              | 0              | 0         | 1  | 0  | Port A ← Data bus                      |
| I | 0              | 1              | 0         | 1  | 0  | Port B ← Data bus                      |
|   | 1              | 0              | 0         | 1  | 0  | Port C ← Data bus                      |
|   | 1              | 1              | 0         | 1  | 0  | Control register $\leftarrow$ Data bus |
| I | ×              | ×              | . 1       | ×  | ×  | Data bus = 3-state                     |
|   | ×              | ×              | 0         | 1  | 1  | Data bus = 3-state                     |
|   | 1              | 1              | 0         | 0  | 1  | inhibition of combination              |
|   |                |                |           |    |    | 050489                                 |

Table 5.1 Basic Operation of TMP82C55A

#### 5.1 MODE SELECTION

There are three basic modes of operation that can be selected by control words.

| Mode 0-Basic I/O                | (Group A, Group B)     |
|---------------------------------|------------------------|
| Mode 1-Strobe input/Strobe outp | out (Group A, Group B) |
| Mode 2-Two-way bus              | (Port A only)          |

Operation modes for Group A and Group B can be independently defined by the control word form the MPU. If  $D_7$  is set to "1" in writing a control word into the PPI, operation mode is selected, while of  $D_7 =$  "0", the set/reset function for Port C is selected.

### 5.1.1 Control word to define operation mode

Figure 5.1 shows the control words to define operation mode of the TMP82C55A.



Figure 5.1 Control Word for Mode Selection

### 5.1.2 Port C bit set/reset control word

Any bit of 8 bits of Port C can be set/reset by Port C bit set/reset control word. Fig. 5.2 shows the Port C bit set/reset control word.



Figure 5.2 Control Word for Bit Set/Reset

### 5.2 OPERATION MODES

#### 5.2.1 Mode 0 (Basic I/O)

This functional configuration is used for simple input or output operations. No 'handshaking' is required and data is simply written to or read from a specified part. Output data to the ports from MPU are latched out but input data from the ports are not latched.

In Mode 0, 24 I/O terminals are divided into four groups of Port A (8 bits), Port B (8 bits), high order 4 bits of Port C and low order 4 bits of Port C. Each port can be programmed to be input or output. The configuration of each port are determined according to the contents of Bit 4 ( $D_4$ ), 3 ( $D_3$ ), 1 ( $D_1$ ) and 0 ( $D_0$ ) of the control word for mode selection.

The I/O configuration of each port in Mode 0 are shown in Table 5.2.

| Mo | Mode Setting Control Word |                |                |           | Port C | Port B | Port C                              |
|----|---------------------------|----------------|----------------|-----------|--------|--------|-------------------------------------|
| D4 | D <sub>3</sub>            | D <sub>1</sub> | D <sub>0</sub> | (PC7~PC4) |        | TOILD  | (PC <sub>3</sub> ~PC <sub>0</sub> ) |
| 0  | 0                         | 0              | 0              | Out       | Out    | Out    | Out                                 |
| 0  | 0                         | 0              | 1              | Out       | Out    | Out    | In                                  |
| 0  | 0                         | 1              | 0              | Out       | Out    | In     | Out                                 |
| 0  | 0                         | 1              | 1              | Out       | Out    | In     | In                                  |
| 0  | 1                         | 0              | 0              | Out       | In     | Out    | Out                                 |
| 0  | 1                         | 0              | 1              | Out       | In     | Out    | In                                  |
| 0  | 1                         | 1              | 0              | Out       | In     | In     | Out                                 |
| 0  | 1                         | 1              | 1              | Out       | In     | In     | In                                  |
| 1  | 0                         | 0              | 0              | In        | Out    | Out    | Out                                 |
| 1  | 0                         | 0              | 1              | In        | Out    | Out    | In                                  |
| 1  | 0                         | 1              | 0              | In        | Out    | In     | Out                                 |
| 1  | 0                         | 1              | 1              | In        | Out    | In     | In                                  |
| 1  | 1                         | 0              | 0              | In        | In     | Out    | Out                                 |
| 1  | 1                         | 0              | 1              | In        | In     | Out    | In                                  |
| 1  | 1                         | 1              | 0              | ln        | In     | In     | Out                                 |
| 1  | 1                         | 1              | 1              | ln        | ln     | In     | In                                  |

Figure 5.3 Port Definition in Mode 0

#### 050489

### 5.2.2 Mode 1 (Strobe I/O)

In Mode 1, input/output of port data is performed in conjunction with the strobe signals or 'handshaking' signals. Port C is used to control Port A or Port B.

The basic operatings in Mode 1 are as follows:

- Mode 1 can be set for two groups of Group A and Group B.
- Each group consist of 8-bit data port and 4-bit control/data port.
- The 8-bit data port can be set as input or output port.
- The control/data port is used as control or status of the 8-bit data port.
- (1) When used as the input port in Mode 1:
  - <u>STB</u> (Strobe Input)

At "0", input data is loaded in the internal input latch in the port.

In this case, a control signal from MPU is not concerned and data is input from the port any time. This data is not read out on the data bus unless MPU executes an input instruction.

• IBF (Input Buffer Full F/F Output)

When data is loaded in the internal input latch from the port, this output is set to "1". IBF is set ("1") by  $\overline{\text{STB}}$  input being reset and is reset ("0") by the rising edge of  $\overline{\text{RD}}$  input.

• INTR (Interrupt Request Output)

Used for the interrupt process of data loaded in the internal input latch. When  $\overline{\text{STB}}$  input is at "0" if INTE (INTE flag) in the PPI is in the enabled state ("1"), IBF is set to "1". INTR is set to "1" immediately after the rising edge of this  $\overline{\text{STB}}$  input and reset to "0" by the falling edge of  $\overline{\text{RD}}$  input.

The INTE flag of Group A and Group B are controlled as follows:

INTEA-Control by bit set/reset of  $PC_4$ INTEB-Control by bit set/reset of  $PC_2$ 

- (2) When used as the output port in Mode 1:
  - OBF (Output Buffer Full F/F Output)

This is a flag which shows that MPU has written data into a specified port.  $\overline{OBF}$  is set to becomes "0" at the rising edge of  $\overline{WR}$  signal and is set to "1" at the falling edge of  $\overline{ACK}$  (Acknowledge input) signal.

• ACK (Acknowledge Input)

 $\overline{\text{ACK}}$  signal is sent to the PPI as a response from a peripheral device taht received data from the port.

• INTR (Interrupt Request Output)

When a peripheral device received data from MPU, INTR is set to "1" and the interrupt is requested to MPU. If  $\overline{ACK}$  signal is received when INTE flag is in the enable state,  $\overline{OBF}$  is set to "1" and INTR signal becomes "1" immediately after the rising edge of  $\overline{ACK}$  signal. Further, INTR is reset at the falling edge of  $\overline{WR}$  signal when data is written into the PPI by MPU.

The INTE flags of Group A and Group B are controlled as follows:

INTEA-Control by bit set/reset of PC<sub>6</sub> INTEB-Control by bit set/reset of PC<sub>2</sub>











#### 5.2.3 Mode 2 (Strobed Bidirectional Bus I/O)

In this mode, Port A is used as 8 bits bidirectional bus for data transfer with a peripheral device. This mode is applicable only to Group A, which consists of an 8-bit bidirectional bus (Port A 8-bit) and 5-bit control signals (high order 5 bits of Port C). The bidirectional bus (Port A) has both the internal input and output registers. When group A is set in Mode 2, Group B can be set independently. There are 5 control signals as follows when Group A is used in Mode 2.

• <u>OBF</u> (Output buffer Full F/F Output)

When MPU writes data into of Port A,  $\overline{OBF}$  is set to "0" to inform a peripheral device that the PPI is ready to output data. However, Port A is kept in the floating (high impedance) state until  $\overline{ACK}$  input signal is received.

• ACK (Acknowledge Input)

When ACK signal is set to "0", the data of the 3-state output buffer of Port A is send out. If ACK signal is at "1", Port A is in the high impedance state.

• <u>STB</u> (Strobe Input)

When  $\overline{\text{STB}}$  input is set to "0", the data from peripheral devices are held in the input latch. When the active  $\overline{\text{RD}}$  signal is input into the PPI, the latched input data are output on the system data bus  $(D_7-D_0)$ .

• IBF (Input Buffer Full F/F Output)

When data from peripheral devices are held in the input latch, IBF is set to "1".

• INTR (Interrupt Request Output)

INTR is the output to request the interrupt to MPU and its function is the same as that in Mode 1. There are two interrupt enable flip-flop (INTE), INTE1 corresponds to INTEA in Mode 1 output and INTE2 to INTEA in Mode 1 input.

- INTE 1-Used to generate INTR signal in conjunction with  $\overline{OBF}$  and  $\overline{ACK}$  signals, and is controlled by PC<sub>6</sub> bit set/reset.
- INTE 2-Used to generate INTR signal in conjunction with IBF and  $\overline{\text{STB}}$  signals, and is controlled by PC<sub>4</sub> bit set/reset.

Fig. 5.8 shows the operating example and the timing diagram in Mode 2.



Figure 5.8 Operating Example in Mode 2

050489









### 5.2.4 Precautions for use in mode 1 and 2

When used in Mode 1 and 2, bits which are not used as control or status in Port C can be used as follow.

If programmed as the input, they are accessed by normal Port C read.

If programmed as the output, high order bits of Port C ( $PC_7$ - $PC_4$ ) are accessed using the bit set/reset function. As to low order bits of Port C ( $PC_3$ - $PC_0$ ), in additions to access by the bit set/reset function, only 3 bits can be accessed by normal writing.

### 5.3 READING PORT C STATUS

When Port C is used as the control port, that is, when Port C is used in Mode 1 or Mode 2, the status information of the control word can be read out by a normal read operation of Port C.

| Data<br>Mode  | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4    | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|---------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|----------------|
| Mode 1 Input  | 1/0            | 1/0            | IBFA           | INTEA | INTRA          | INTEB          | IBFB           | INTRB          |
| Mode 1 Output | OBFA           | INTEA          | 1/0            | 1/0   | INTRA          | INTEB          | OBFB           | INTRB          |
| Mode 2        | OBFA           | INTE1          | IBFA           | INTE2 | INTRA          | By (           | Group B Mo     | ode            |

Table 5.2 Status Word Format of Port C

# 6. ELECTRICAL CHARACTERISTICS

## 6.1 ABSOLUTE MAXIMUM RATINGS

| Symbol           | ltem                           | Rating                         | Unit   |
|------------------|--------------------------------|--------------------------------|--------|
| V <sub>CC</sub>  | Supply Voltage                 | – 0.5 to 7.0                   | V      |
| V <sub>IN</sub>  | Input Voltage                  | – 0.5 to V <sub>CC</sub> + 0.5 | V      |
| PD               | Power Dissipation              | 250                            | mW     |
| TSOLDER          | Soldering Temperature (10 sec) | 260                            | °C     |
| T <sub>STG</sub> | Storage Temperature            | – 65 to + 150                  | °C     |
| T <sub>OPR</sub> | Operating Temperature          | – 40 to + 85                   | °C     |
|                  |                                |                                | 050489 |

### 6.2 DC ELECTRICAL CHARACTERISTICS

| $TA=-40^\circ\!\!C$ to $+85^\circ\!\!C$ , $V_{CC}=5V\pm10^\circ\!\!\%$ , $V_{SS}=0V$ |  |
|--------------------------------------------------------------------------------------|--|
|--------------------------------------------------------------------------------------|--|

| SYMBOL                     | ITEM                                          | TEST CONDITION                                                                                                                                      | MIN.                 | TYP. | MAX.                  | UNIT   |
|----------------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|------|-----------------------|--------|
| VIL                        | Input Low Voltage                             |                                                                                                                                                     | - 0.5                |      | 0.8                   | V      |
| VIH                        | Input High Voltage                            |                                                                                                                                                     | 2.2                  | -    | V <sub>CC</sub> + 0.5 | V      |
| Vol                        | Output Low Voltage                            | l <sub>OL</sub> = 2.5mA                                                                                                                             | -                    |      | 0.45                  | V      |
| V <sub>OH1</sub>           | Output High Voltage                           | I <sub>OH</sub> = -400µА                                                                                                                            | 2.4                  | _    | -                     | V      |
| V <sub>OH2</sub>           | Output High Voltage                           | l <sub>OH</sub> = -100µА                                                                                                                            | V <sub>CC</sub> -0.8 | —    | _                     | V      |
| IIL                        | Input Leak Current                            | $0 \leq V_{IN} \leq V_{CC}$                                                                                                                         | -                    |      | ± 10                  | μA     |
| ILO                        | Output Leak Current<br>(High Impedance State) | $0 \le V_{OUT} \le V_{CC}$                                                                                                                          |                      | -    | ± 10                  | μA     |
| (Note)<br>I <sub>DAR</sub> | Darlington Drive<br>Current                   | $V_{EXT} = 1.5V$<br>$R_{EXT} = 1.1k\Omega$                                                                                                          | - 1.0                |      | - 5.0                 | mA     |
| I <sub>CC1</sub>           | Operating Supply<br>Current                   | I / Ocycle Time<br>1µsec                                                                                                                            |                      | 2.0  | 5.0                   | mA     |
| Icc2                       | Stand-by Supply<br>Current                    | $\label{eq:constraint} \begin{split} \overline{CS} & \geq V_{CC}\text{-}0.2V \\ V_{IH} & \geq V_{CC}\text{-}0.2V \\ V_{IL} & \leq 0.2V \end{split}$ |                      | _    | 10                    | μА     |
|                            |                                               |                                                                                                                                                     |                      |      | -                     | 050489 |

Note: Applied for optional 8 I/O terminals in Port B and Port C.

## 6.3 AC ELECTRICAL CHARACTREISTICS

TA = -40°C to +85°C,  $V_{CC} = 5V \pm 10\%$ ,  $V_{SS} = 0V$ 

| SYMBOL           | PARAMETER                                                                                         |      | AP-2 / AM-2 |      | AP-10 / AM-10 |      |
|------------------|---------------------------------------------------------------------------------------------------|------|-------------|------|---------------|------|
| STINBOL          |                                                                                                   | MIN. | MAX.        | MIN. | MAX.          | UNIT |
| t <sub>AR</sub>  | Address set-up time for RD fall                                                                   | 0    |             | 0    | -             | ns   |
| t <sub>RA</sub>  | Address hold time for $\overline{RD}$ rise                                                        | 0    | -           | 0    | —             | ns   |
| t <sub>RR</sub>  | RD pulse width                                                                                    | 160  | -           | 150  | -             | ns   |
| t <sub>RD</sub>  | Delay from $\overline{RD}$ fall to decided data output                                            |      | 140         |      | 100           | ns   |
| t <sub>DF</sub>  | Time from $\overline{\text{RD}}$ rise to data bus floating                                        | 0    | 40          | 0    | 40            | ns   |
| t <sub>RV</sub>  | Time from $\overline{RD}$ or $\overline{WR}$ rise to next $\overline{RD}$ or $\overline{WR}$ fall | 200  | -           | 150  | —             | ns   |
| t <sub>AW</sub>  | Address set-up time for $\overline{WR}$ fall                                                      | 0    | -           | 0    | -             | ns   |
| t <sub>WA</sub>  | Address holding time for $\overline{WR}$ rise                                                     | 0    | -           | 0    | -             | ns   |
| t <sub>WW</sub>  | WR pulse width                                                                                    | 120  | -           | 120  | -             | ns   |
| t <sub>DW</sub>  | Bus data set-up time for WR rise                                                                  | 100  | -           | 100  | -             | ns   |
| t <sub>WD</sub>  | Bus data holding time for $\overline{WR}$ rise                                                    | 0    | -           | 0    | _             | ns   |
| t <sub>WB</sub>  | Delay from $\overline{WR}$ rise to decided data output                                            |      | 350         | -    | 350           | ns   |
| t <sub>IR</sub>  | Port data set-up time for RD fall                                                                 | 0    | _           | 0    | -             | ns   |
| t <sub>HR</sub>  | Port data holding time for $\overline{RD}$ rise                                                   | 0    | -           | 0    | -             | ns   |
| t <sub>AK</sub>  | ACK pulse width                                                                                   | 300  | -           | 300  | -             | ns   |
| t <sub>ST</sub>  | STB pulse width                                                                                   | 350  | -           | 350  | -             | ns   |
| t <sub>PS</sub>  | Port data set-up time for STB rise                                                                | 0    | -           | 0    | -             | ns   |
| t <sub>PH</sub>  | Port data holding time for STB rise                                                               | 150  | -           | 150  | -             | ns   |
| t <sub>AD</sub>  | Delay from $\overline{ACK}$ fall to decided data output                                           |      | 300         | -    | 300           | ns   |
| t <sub>KD</sub>  | Time from $\overline{\text{ACK}}$ rise up to port (Port A in Mode 2) floating                     | 25   | 250         | 20   | 250           | ns   |
| t <sub>WOB</sub> | Delay from $\overline{WR}$ rise to $\overline{OBF}$ fall                                          | _    | 300         | -    | 300           | ns   |
| t <sub>AOB</sub> | Delay from $\overline{ACK}$ fall to $\overline{OBF}$ rise                                         |      | 350         | -    | 350           | ns   |
| t <sub>SIB</sub> | Delay from STB fall to IBF rise                                                                   |      | 300         | -    | 300           | ns   |
| t <sub>RIB</sub> | Delay from $\overline{RD}$ fall to $\overline{IBF}$ rise                                          |      | 300         | -    | 300           | ns   |
| t <sub>RIT</sub> | Delay from RD fall to INTR fall                                                                   |      | 400         | -    | 400           | ns   |
| t <sub>SIT</sub> | Delay from ACK rise to INTR rise                                                                  |      | 300         | -    | 300           | ns   |
| t <sub>AIT</sub> | Delay from $\overline{ACK}$ rise to INTR rise                                                     |      | 350         | _    | 350           | ns   |
| t <sub>WIT</sub> | Delay from WR rise to INTR                                                                        | —    | 450         |      | 450           | ns   |

Note: 1. When the power supply is turned ON, reset pulse duration must be active for at least 500 ns or more.

2. AC Measuring Point Input Voltage  $V_{IH} = 2.4V$ ,  $V_{IL} = 0.45V$ Output Voltage  $V_{OH} = 2.2V$ ,  $V_{OL} = 0.8V$ CL = 150 pF.

## 6.4 CAPACITANCE

 $TA = 25^{\circ}C$ ,  $V_{CC} = V_{SS} = 0V$ 

| SYMBOL          | ITEM               | TEST CONDITION        | MIN. | TYP. | MAX. | UNIT   |
|-----------------|--------------------|-----------------------|------|------|------|--------|
| C <sub>IN</sub> | Input Capacitance  | f <sub>C</sub> = 1MHz | —    | —    | 10   | pF     |
| COUT            | Output Capacitance | (*)                   |      |      | 20   | pF     |
|                 |                    |                       |      |      |      | 050489 |

(\*): All terminals except that to be measured should be earthed.

# 7. TIMING DIAGRAM



Figure 7.1 Timing Diagram







# TOSHIBA

# 8. PACKAGE DIMENSION

## 8.1 PLASTIC PACKGE

DIP40-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located witchin  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.4 leads.

### 8.2 40PIN SMALL OUTLINE PACKAGE

# SSOP40-P-450

Unit : mm



# PROGRAMMABLE PERIPHERAL INTERFACE

## TMP8255AP-5

## 1. GENERAL DESCRIPTION AND FEATURES

The TMP8255A (hereinafter referred to as PPI) is a high Speed programmable input/output interface with three 8-bit I/O ports. 24 I/O ports are divided into two groups (Port A and Port B) which are programmable independently by control words provided by MPU. The PPI has three operation modes (Mode 0, 1 and 2) and is capable of versatile interface between MPU and peripheral devices.

- (1)  $5V \pm 5\%$  Single power supply
- (2) 24 programmable I/O ports
- (3) Three operation modes (Mode 0, Mode 1, Mode 2)
- (4) Bit set/reset capability

# 2. PIN CONNECTIONS (TOP VIEW)

|                         |     | <u>م</u>  | 1                |
|-------------------------|-----|-----------|------------------|
| PA <sub>3</sub> [       | 1   | U 40      | PA4              |
| PA <sub>2</sub> [       | 2   | 39        | DPA5             |
| PA <sub>1</sub>         | 3   | 38        | PA6              |
| PA <sub>0</sub> [       | 4   | 37        | ÞPA7             |
| RD                      | 5   | 36        | <u> WR</u>       |
| <u>CS</u> [             | 6   | 35        | D RESET          |
| (GND) V <sub>SS</sub> [ | 7   | 34        | þD₀              |
| A1 [                    | 8   | 33        | D1               |
| A0 [                    | 9   | 32        | ] D <sub>2</sub> |
| PC7 [                   | 10  | 31        | D <sub>3</sub>   |
| PC6 [                   | 11  | 30        | ] D4             |
| PC5 [                   | 12  | 29        | D <sub>5</sub>   |
| PC4 [                   | 13  | 28        | D <sub>6</sub>   |
| PC <sub>0</sub> [       | 14  | 27        | D7               |
| PC <sub>1</sub>         | 15  | 26        | Vcc ( + 5V)      |
| PC <sub>2</sub> [       | 16  | 25        | ] PB7            |
| PC <sub>3</sub>         | 17  | 24        | PB6              |
| РВ <sub>0</sub> [       | 18  | 23        | ] PB5            |
| PB <sub>1</sub> [       | 19  | 22        | DPB4             |
| PB <sub>2</sub> C       | 20  | 21        | PB3              |
| 1                       | TMF | P8255AP-5 | 1                |
|                         |     |           |                  |
# 3. BLOCK DIAGRAM



# 4. PIN NAMES AND PIN FUNCTIONS

| Pin Name                        | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                           |  |  |
|---------------------------------|------------------|-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| D <sub>0</sub> ~D <sub>7</sub>  | 8                | I/O<br>3-STATE          | 3-state bidirectional 8-bit data bus.<br>Used for data transfer with MPU. Also, used for transfer of control<br>words to PPI and status information from PPI.                                                                                                                                                                                      |  |  |
| PA7~PA0                         | 8                | I/O<br>3-STATE          | 3-state 8-bit I/O Port A.<br>Operation mode and input/output configuration are defined by<br>software. Port A contains the output latch buffer and input latch.                                                                                                                                                                                    |  |  |
| PB7~PB0                         | 8                | I/O<br>3-STATE          | 3-state 8-bit I/O Port B.<br>Operation mode and input/output configuration are defined b<br>software. Port B contains the output latch buffer and input latch.                                                                                                                                                                                     |  |  |
| PC7~PC0                         | 8                | I/O<br>3-STATE          | 3-state 8-bit I/O Port C.<br>Operation mode and input/output configuration are defined by<br>software. Port C can be divided into two 4-bit ports by the mode<br>control and also, used as the control signal for Port A and Port B. In<br>this case, 3 bits of $PC_0$ to $PC_2$ are used for Port B and 5 bits of $PC_3$ to<br>$PC_7$ for Port A. |  |  |
| <u>cs</u>                       | 1                | Input                   | Chip select input.<br>When this terminal is at "L" level, data transfer PPI and MPU<br>becomes possible. At "H" level, the data bus is placed in the high<br>impedance state and control from the processor is ignored.                                                                                                                            |  |  |
| RD                              | 1                | Input                   | Read signal.<br>When this terminal is at "L" level, data that is input into the port is<br>transferred to MPU.                                                                                                                                                                                                                                     |  |  |
| WR                              | 1                | Input                   | Write signal.<br>When this terminal is at "L" level, data or control word is written<br>into PPI from MPU.                                                                                                                                                                                                                                         |  |  |
| A <sub>0</sub> , A <sub>1</sub> | 2                | Input                   | Used for selecting Port A, B, C and the control registers. Nurmally, this terminal is connected to low order 2 bits of the address bus.                                                                                                                                                                                                            |  |  |
| RESET                           | 1                | Input                   | When this terminal is at "H" level, all internal registers including the control register are cleared. In addition, all ports (Port A, B, C) are placed in the input mode (high impedance) of mode 0.                                                                                                                                              |  |  |
| V <sub>CC</sub>                 | 1                | Power<br>Supply         | 5V                                                                                                                                                                                                                                                                                                                                                 |  |  |
| V <sub>SS</sub>                 | 1                | Power<br>Supply         | GND                                                                                                                                                                                                                                                                                                                                                |  |  |

# 5. FUNCTIONAL DESCRIPTION

The PPI is a programmable peripheral interface with three 8-bit ports (Port A, B and C) and two control registers. 24 I/O ports are divided into 12-bit group A and group B. Group A consists of Port A and high order 4 bits of Port C, while Group B consists of Port B and low order 4 bits of Port C. Each group is independently programmable by control words provided from MPU. There are three operation modes available for the PPI. In mode 0, two 8-bit I/O ports and two 4-bit I/O ports are divided into Group A and Group B. 8 bits of each group are used as input or output port and of the remaining 4 bits, 3 bits are used as handshaking and interrupt control signal. Mode 2 is applicable only to group A and the ports are used as a bidirectional 8-bit data bus and 5-bit control signal. In case of Port C being used as the output, any bits of Port C can be set/reset.

There are two control registers; one is used for mode setting and the other for bit set/reset control. The control registers can only be written into. Further, when the reset input (RESET) becomes "1", the control registers are reset and all I/O ports are placed in input mode (high impedance status).

| A <sub>1</sub> | A <sub>0</sub> | CS | RD | WR | Function                               |
|----------------|----------------|----|----|----|----------------------------------------|
| 0              | 0              | 0  | 0  | 1  | Data bus ← Port A                      |
| 0              | 1              | 0  | 0  | 1  | Data bus ← Port B                      |
| 1              | 0              | 0  | 0  | 1  | Data bus ← Port C                      |
| 0              | 0              | 0  | 1  | 0  | Port A ← Data bus                      |
| 0              | 1              | 0  | 1  | 0  | Port B ← Data bus                      |
| 1              | 0              | 0  | 1  | 0  | Port C ← Data bus                      |
| 1              | 1              | 0  | 1  | 0  | Control register $\leftarrow$ Data bus |
| ×              | ×              | 1  | ×  | ×  | Data bus = 3-state                     |
| ×              | ×              | 0  | 1  | 1  | Data bus = 3-state                     |
| 1              | 1              | 0  | 0  | 1  | inhibition of combination              |
|                |                |    |    |    | 050/89                                 |

|  | Table 5.1 | Basic O | peration | of <sup>-</sup> | TMP8 | 3255A |
|--|-----------|---------|----------|-----------------|------|-------|
|--|-----------|---------|----------|-----------------|------|-------|

#### 5.1 MODE SELECTION

There are three basic modes of operation that can be selected by control words.

| Mode 0-Basic I/O                  | (Group A, Group B) |
|-----------------------------------|--------------------|
| Mode 1-Strobe input/Strobe output | (Group A, Group B) |
| Mode 2-Two-way bus                | (Port A only)      |

Operation modes for Group A and Group B can be independently defined by the control word from the MPU. If  $D_7$  is set to "1" in writing a control word into the PPI, on operation mode is selected, while of  $D_7$ ="0", the set/reset function for Port C is selected.

## 5.1.1 Control word to define operation mode

Figure 5.1 shows the control words to define operation mode of the TMP8255A.



Figure 5.1 Control Word for Mode Selection

### 5.1.2 Port C bit set/reset control word

Any bit of 8 bits of Port C can be set/reset by Port C bit set/reset control word. Figure 5.2 shows the Port C bit set/reset control word.



Figure 5.2 Control Word for Bit Set/Reset

#### 5.2 OPERATION MODES

## 5.2.1 Mode 0 (Basic I/O)

This functional configuration is used for simple input or output operations. No 'handshaking' is required and data is simply written to or read from a specified part. Output data to the ports from MPU are latched out but input data from the ports are not latched.

In Mode 0, 24 I/O ports are divided into four groups of Port A (8 BITS), Port B (8 bits), high order 4 bits of Port C and low order 4 bits of Port C. Each port can be programmed to be input or output. The configuration of each port are determined according to the contents of Bit 4  $(D_4)$ , 3  $(D_3)$ , 1  $(D_1)$  and 0  $(D_0)$  of the control word for mode selection.

The I/O configuration of each port in Mode 0 are shown in Table 5.2.

| Noc | Node Setting Control Word |                |                | Port A | Port C    | Port P | Port C                              |
|-----|---------------------------|----------------|----------------|--------|-----------|--------|-------------------------------------|
| D4  | D <sub>3</sub>            | D <sub>1</sub> | D <sub>0</sub> | FOILA  | (PC7~PC4) | FOILD  | (PC <sub>3</sub> ~PC <sub>0</sub> ) |
| 0   | 0                         | 0              | 0              | Out    | Out       | Out    | Out                                 |
| 0   | 0                         | 0              | 1              | Out    | Out       | Out    | In                                  |
| 0   | 0                         | 1              | 0              | Out    | Out       | In     | Out                                 |
| 0   | 0                         | 1              | 1              | Out    | Out       | In     | In                                  |
| 0   | 1                         | 0              | 0              | Out    | In        | Out    | Out                                 |
| 0   | 1                         | 0              | 1              | Out    | In        | Out    | In                                  |
| 0   | 1                         | 1              | 0              | Out    | In        | In     | Out                                 |
| 0   | 1                         | 1              | 1              | Out    | In        | In     | In                                  |
| 1   | 0                         | 0              | 0              | In     | Out       | Out    | Out                                 |
| 1   | 0                         | 0              | 1              | In     | Out       | Out    | In                                  |
| 1   | 0                         | 1              | 0              | In     | Out       | In     | Out                                 |
| 1   | 0                         | 1              | 1              | In     | Out       | In     | In                                  |
| 1   | 1                         | 0              | 0              | In     | In        | Out    | Out                                 |
| 1   | 1                         | 0              | 1              | In     | In        | Out    | In                                  |
| 1   | 1                         | 1              | 0              | In     | In        | ln     | Out                                 |
| 1   | 1                         | 1              | 1              | In     | In        | In     | In                                  |

Figure 5.3 Port definition in Mode 0

#### 050489

## 5.2.2 Mode 1 (Strobe I/O)

In Mode 1, input/output of port data is performed in conjunction with the strobe signals or 'handshaking' signals. Port C is used to control Port A or Port B.

The basic operatings in Mode 1 are as follows:

- Mode 1 can be set for two groups of Group A and Group B.
- Each group consist of 8-bit data port and 4-bit control/data port.
- The 8-bit data port can be set as input or output port.
- The control/data port is used as control or status of the 8-bit data port.
- (1) When used as the input port in Mode 1:
  - <u>STB</u> (Strobe Input)

At "0", input data is loaded in the internal input latch in the port.

In this case, a control signal from MPU is not concerned and data is input from the port any time. This data is not read out on the data bus unless MPU executes an input instruction.

• IBF (Input Buffer Full F/F Output)

When data is loaded in the internal input latch from the port, this output is set to "1". IBF is set ("1") by  $\overline{\text{STB}}$  input being reset and is reset ("0") by the rising edge of  $\overline{\text{RD}}$  input.

• INTR (Interrupt Request Output)

Used for the interrupt process of data loaded in the internal input latch. When  $\overline{\text{STB}}$  input is at "0" if INTE (INTE flag) in the PPI is in the enabled state ("1"), IBF is set to "1". INTR is set to "1" immediately after the rising edge of this  $\overline{\text{STB}}$  input and reset to "0" by the falling edge of  $\overline{\text{RD}}$  input.

The INTE flags of Group A and Group B are controlled as follows: INTEA-Control by bit set/reset of  $PC_4$ INTEB-Control by bit set/reset of  $PC_2$ 

- (2) When used as the output port in Mode 1:
  - <u>OBF</u> (Output Buffer Full F/F Output)

This is a flag which shows that MPU has written data into a specified port.  $\overline{OBF}$  is set to becomes "0" at the rising edge of  $\overline{WR}$  signal and is set to "1" at the falling edge of  $\overline{ACK}$  (Acknowledge input) signal.

• ACK (Acknowledge Input)

 $\overline{\text{ACK}}$  signal is sent to the PP1 as a response from a peripheral device that received data from the port.

• INTR (Interrupt Request Output)

When a peripheral device received data from MPU, INTR is set to "1" and the interrupt is requested to MPU. If  $\overline{ACK}$  signal is received when INTE flag is in the enable state,  $\overline{OBF}$  is set to "1" and INTR signal becomes "1" immediately after the rising edge of  $\overline{ACK}$  signal. Further, INTR is reset at the falling edge of  $\overline{WR}$  signal when data is written into the PPI by MPU.

The INTE flags of Group A and Group B are controlled as follows:

INTEA-Control by bit set/reset of PC6

INTEB-Control by bit set/reset of PC<sub>2</sub>











#### 5.2.3 Mode 2 (Strobed Bidirectional Bus I/O)

In this mode, Port A is used as 8 bits bidirectional bus for data transfer with a peripheral device. This mode is applicable only to Group A, which consists of an 8-bit bidirectional bus (Port A 8-bit) and 5-bit control signals (high order 5 bits of Port C). The bidirectional bus (Port A) has both the internal input and output registers. When group A is set in Mode 2, Group B can be set independently. These are 5 control signals as follows when Group A is used in Mode 2.

• <u>OBF</u> (Output buffer Full F/F Output)

When MPU writes data into of Port A,  $\overline{OBF}$  is set to "0" to inform a peripheral device that the PPI is ready to output data. However, Port A is dept in the floating (high impedance) state until  $\overline{ACK}$  input signal is received.

• ACK (Acknowledge Input)

When ACK signal is set to "0", the data of the 3-state output buffer of Port A is send out. If ACK signal is at "1", Port A is in the high impedance state.

• <u>STB</u> (Strobe Input)

When  $\overline{\text{STB}}$  input is set to "0", the data from peripheral devices are held in the input latch. When the active  $\overline{\text{RD}}$  signal is input into the PPI, the latched input data are output on the system data bus  $(D_7-D_0)$ .

• IBF (Input Buffer Full F/F Output)

When data from peripheral devices are held in the input latch, IBF is set to "1".

• INTR (Interrupt Request Output)

INTR is the output to request the interrupt to MPU and its function is the same as that in Mode 1. There are two interrupt enable flip-flop (INTE), INTE1 corresponds to INTEA in Mode 1 output and INTE2 to INTEA in Mode 1 input.

- INTE 1-Used to generate INTR signal in conjunction with  $\overline{OBF}$  and  $\overline{ACK}$  signals, and is controlled by PC6 bit set/reset.
- INTE 2-Used to generate INTR signal in conjunction with IBF and  $\overline{\text{STB}}$  signals, and is controlled by PC<sub>4</sub> bit set/reset.

Figure 5.8 shows the operating example and the timing diagram in Mode 2.



Figure 5.8 Operating example in Mode 2

050489

Control Word in Mode 2 D<sub>7</sub> D<sub>6</sub> D<sub>5</sub> D<sub>4</sub> D<sub>3</sub>









#### 5.2.4 Pecautions for use in Mode 1 and 2

When used in Mode 1 and 2, bits which are not used as control or status in Port C can be used as follows.

If programmed as the input, they are accessed by normal Port C read.

If Programmed as the output, high order bits of Port C (PC<sub>7</sub>-PC<sub>4</sub>) are accessed using the bit set/reset function. As to low order bits of Port C (PC<sub>3</sub>-PC<sub>0</sub>), in additions ot access by the bit set/reset function, 3 bits only can be accessed by normal writing.

### 5.3 READING PORT C STATUS

When Port C is used as the control port, that is, when Port C is used in Mode 1 or Mode 2, the status information of the control word can be read out by a normal read operation of Port C.

| Data Mode     | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4    | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|---------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|----------------|
| Mode 1 Input  | 1/0            | 1/0            | IBFA           | INTEA | INTRA          | INTEB          | IBFB           | INTRB          |
| Mode 1 Output | OBFA           | INTEA          | 1/0            | 1/0   | INTRA          | INTEB          | OBFB           | INTRB          |
| Mode 2        | OBFA           | INTE1          | IBFA           | INTE2 | INTRA          | By (           | Group B M      | ode            |

Table 5.2 Status Word Format of Port C

# 6. ELECTRICAL CHARACTERISTICS

# 6.1 ABSOLUTE MAXIMUM RATINGS

| Symbol           | ltem                              | Rating                        | Unit   |
|------------------|-----------------------------------|-------------------------------|--------|
| Vcc              | Supply Voltage                    | – 0.5 to 7.0                  | V      |
| VIN              | Input Voltage                     | – 0.5to V <sub>CC</sub> + 7.0 | V      |
| PD               | Power Dissipation                 | 1                             | W      |
| TSOLDER          | Soldering Temperature (10sec) 260 |                               | °C     |
| T <sub>STG</sub> | Strobe Temperature                | - 65 to + 150                 | Ĉ      |
| TOPR             | Operating Temperature             | 0 to + 70                     | °C     |
|                  |                                   |                               | 050489 |

# 6.2 DC ELECTRICAL CHARACTERISTICS

# $TA = 0^{\circ}C \text{ to } 70^{\circ}C, V_{CC} = 5V \pm 5\%, V_{SS} = 0V$

| SYMBOL                       | ITEM                                          | TEST CONDITION                                         | MIN.       | TYP. | MAX.         | UNIT   |
|------------------------------|-----------------------------------------------|--------------------------------------------------------|------------|------|--------------|--------|
| VIL                          | Input Low Voltage                             |                                                        | - 0.5      | -    | 0.8          | V      |
| VIH                          | Input High Voltage                            |                                                        | 2.2        |      | Vcc          | v      |
| V <sub>OL</sub>              | Output Low Voltage (DB)<br>(PER)              | l <sub>OL</sub> = 2.5mA<br>l <sub>OL</sub> = 1.7mA     | -          |      | 0.45<br>0.45 | V<br>V |
| V <sub>OH</sub>              | Output High Voltage(DB)<br>(PER)              | l <sub>OH</sub> = - 400µA<br>l <sub>OH</sub> = - 200µA | 2.4<br>2.4 | -    | _            | V<br>V |
| IIL                          | Input Leak Current                            | $0 \le V_{IN} \le V_{CC}$                              | -          | —    | ± 10         | μА     |
| IOFL                         | Output Leak Current<br>(High Impedance State) | $0 \le V_{OUT} \le V_{CC}$                             | _          | _    | ± 10         | μА     |
| (Note 1)<br>I <sub>DAR</sub> | Darlington Drive Current                      | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 750Ω     | - 1.0      | _    | - 4.0        | mA     |
| Icc                          | Operating Supply Current                      | I/O cycle Time 1<br>usec                               |            |      | 120          | mA     |

050489

Note: Applied for optional 8 I/O terminals in Port B and Port C.

# 6.4 AC ELECTRICAL CHARACTREISTICS

#### TA = $0^{\circ}$ C to $70^{\circ}$ C, VCC = 5V ± 5%, VSS = 0V

| SYMBOL           | PARAMETER                                                                                         |      | 55AP-5 | UNIT   |
|------------------|---------------------------------------------------------------------------------------------------|------|--------|--------|
| STIVIBOL         |                                                                                                   | MIN. | MAX.   |        |
| t <sub>AR</sub>  | Address set-up time for RD fall                                                                   | 0    | -      | ns     |
| t <sub>RA</sub>  | Address hold time for $\overline{RD}$ rise                                                        | 0    | -      | ns     |
| t <sub>RR</sub>  | RD pulse width                                                                                    | 300  | -      | ns     |
| t <sub>RD</sub>  | Delay from $\overline{RD}$ fall to decided data output                                            | -    | 200    | ns     |
| t <sub>DF</sub>  | Time from RD rise to data bus floating                                                            | 10   | 100    | ns     |
| t <sub>RV</sub>  | Time from $\overline{RD}$ or $\overline{WR}$ rise to next $\overline{RD}$ or $\overline{WR}$ fall | 850  | -      | ns     |
| t <sub>AW</sub>  | Address set-up time for WR fall                                                                   | 0    | -      | ns     |
| t <sub>WA</sub>  | Address holding time for $\overline{WR}$ rise                                                     | 20   | -      | ns     |
| t <sub>WW</sub>  | WR pulse width                                                                                    | 300  | -      | ns     |
| t <sub>DW</sub>  | Bus data set-up time for $\overline{WR}$ rise                                                     | 100  | -      | ns     |
| t <sub>WD</sub>  | Bus data holding time for WR rise                                                                 | 30   | _      | ns     |
| t <sub>WB</sub>  | Delay from $\overline{WR}$ rise to decided data output                                            | -    | 350    | ns     |
| t <sub>IR</sub>  | Port data set-up time for RD fall                                                                 | 0    | -      | ns     |
| t <sub>HR</sub>  | Port data holding time for $\overline{RD}$ rise                                                   | 0    | -      | ns     |
| t <sub>AK</sub>  | ACK pulse width                                                                                   | 300  | -      | ns     |
| ts⊤              | STB pulse width                                                                                   | 500  | -      | ns     |
| tps              | Port data set-up time for STB rise                                                                | 0    | -      | ns     |
| t <sub>PH</sub>  | Port data holding time for STB rise                                                               | 180  | -      | ns     |
| t <sub>AD</sub>  | Delay from ACK fall to decided data output                                                        | -    | 300    | ns     |
| t <sub>KD</sub>  | Time from ACK rise up to port (Port A in Mode2) floating                                          | 20   | 250    | ns     |
| t <sub>WOB</sub> | Delay from WR rise to OBF fall                                                                    | -    | 650    | ns     |
| t <sub>AOB</sub> | Delay from $\overline{ACK}$ fall to $\overline{OBF}$ rise                                         | -    | 350    | ns     |
| t <sub>SIB</sub> | Delay from STB fall to IBF rise                                                                   | -    | 300    | ns     |
| t <sub>RIB</sub> | Delay from $\overline{RD}$ fall to $\overline{IBF}$ rise                                          | -    | 300    | ns     |
| t <sub>RIT</sub> | Delay from RD fall to INTR fall                                                                   | -    | 400    | ns     |
| t <sub>SIT</sub> | Delay from ACK rise to INTR rise                                                                  |      | 300    | ns     |
| t <sub>AIT</sub> | Delay from ACK rise to INTR rise                                                                  | -    | 350    | ns     |
| t <sub>WIT</sub> | Delay from $\overline{WR}$ rise to INTR fall                                                      | -    | 450    | ns     |
|                  |                                                                                                   |      | •      | 050489 |

Note : 1. When the power supply is turned ON, reset pulse duration must be active for at least 500 ns or more.

CL = 150 pF.

2. AC Measuring Point Input Voltage Output Voltage

 $\begin{array}{ll} V_{\rm IH}\!=\!2.0V, V_{\rm IL}\!=\!0.8V\\ V_{\rm OH}\!=\!2.0V, V_{\rm OL}\!=\!0.8V \end{array}$ 

### MPU85-167

# 6.4 CAPACITANCE

 $TA = 25^{\circ}C, V_{CC} = V_{SS} = 0V$ 

| SYMBOL           | ITEM              | TEST CONDITION        | MIN. | TYP. | MAX. | UNIT   |
|------------------|-------------------|-----------------------|------|------|------|--------|
| C <sub>IN</sub>  | Input Capacitance | f <sub>C</sub> = 1MHz | -    | -    | 10   | рF     |
| C <sub>I/O</sub> | I/O Capacitance   | (*)                   | -    | -    | 20   | pF     |
|                  |                   |                       |      |      |      | 050489 |

\* : All terminals except that to be measured should be earthed.

# 7. TIMING DIAGRAM



Figure 7.1 Timing diagram

MPU85-169



MODE 2 BIDIRECTION OPERATION





# 8. PACKAGE DIMENSION

## 8.1 PLASTIC PACKGE

DIP40-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No.1 and No.40 leads.

# TOSHIBA MOS TYPE DEGITAL INTEGRATED CIRCUIT Silicon Monolithic CMOS Silicon Gate

# TMP82C59AP-2/TMP82C59AM-2

# PROGRAMMABLE INTERRUPT CONTROLLER

# 1. GENERAL DESCRIPTION

TMP82C59AP-2/AM-2 (hereinafter referred to as TMP82C59A) is a programmable interrupt controller. It handles up to eight vectored priority interrupts for the MPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry.

#### FEATURES

- Eight Level Priority Controller.
- Expandable to 64 Level.
- Interrupt Modes, Interrupt Mask, Vectored Address Programmable.
- Single + 5V Power Supply.
- Supports 8085A, 8086 Microcomputer Interrupt Sequence.
- TTL Compatible.

# 2. PIN CONNECTIONS (TOP VIEW)

#### TMP82C59AP-2/TMP82C59AM-2

| CS                    | 1  | $\bigcirc$ | 28 | þ | V <sub>CC</sub>  |
|-----------------------|----|------------|----|---|------------------|
| WR                    | 2  |            | 27 | þ | A <sub>0</sub>   |
| RD                    | 3  |            | 26 | þ | INTA             |
| D7                    | 4  |            | 25 | þ | IR7              |
| D <sub>6</sub>        | 5  |            | 24 | þ | IR <sub>6</sub>  |
| D5                    | 6  |            | 23 | þ | IR <sub>5</sub>  |
| D4                    | 7  |            | 22 | þ | IR <sub>4</sub>  |
| D <sub>3</sub>        | 8  |            | 21 | þ | IR <sub>3</sub>  |
| D <sub>2</sub>        | 9  |            | 20 | þ | IR <sub>2</sub>  |
| D <sub>1</sub>        | 10 |            | 19 | þ | IR <sub>1</sub>  |
| Do                    | 11 |            | 18 | þ | IR <sub>0</sub>  |
| CAS <sub>0</sub>      | 12 |            | 17 |   | INT              |
| CAS <sub>1</sub>      | 13 |            | 16 | 口 | SP/EN            |
| V <sub>SS</sub> (GND) | 14 |            | 15 | b | CAS <sub>2</sub> |

050489

#### MPU85-172

# 3. PIN NAMES AND DESCRIPTION

Table 3.1

| Pin Name                                | Input/Output   | Function                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <u>cs</u>                               | Input          | Chip Select Input. A low on this pin enables $\overline{RD}$ and $\overline{WR}$ communication between the MPU and the TMP82C59A. INTA functions are independent of $\overline{CS}$ .                                                                                                                              |
| WR                                      | Input          | Write Control Input. A low on this pin when $\overline{\text{CS}}$ is low enables the TMP82C59A to receive command words from MPU.                                                                                                                                                                                 |
| RD                                      | Input          | Read Control Input. A low on this pin when $\overline{\text{CS}}$ is low enables the TMP82C59A to output status onto the data bus for the MPU.                                                                                                                                                                     |
| D <sub>0</sub> to D <sub>7</sub>        | Input / Output | Bidirectional Data Bus. Command status and interrupt-vector information is transferred via this bus.                                                                                                                                                                                                               |
| CAS <sub>0</sub> to<br>CAS <sub>2</sub> | Input / Output | Cascade Lines. The CAS lines from a private TMP82C59A bus to control a multiple TMP82C59A structure. These pins are outputs for a master TMP82C59A and inputs for a slave TMP82C59A.                                                                                                                               |
| SP / EN                                 | Input / Output | Slave Program / Enable buffer. This is a dual function pin. In the buffered mode, it can be used as an output to control buffer transceivers ( $\overline{EN}$ ). In the non-buffered mode, it is used as an input to designate a master TMP82C59A ( $\overline{SP} = 1$ ) or a slave one ( $\overline{SP} = 0$ ). |
| INT                                     | Output         | Interrupt Request Output. This pin goes high whenever a valid interrupt request is asserted. It is used to interrupt the MPU. It is connected to MPU's interrupt pin.                                                                                                                                              |
| IR <sub>0</sub> to IR <sub>7</sub>      | Input          | Interrupt Request Inputs. An interrupt request is executed by raising an IR input (low to high), and holding it high until it is acknowledged (Edge Triggered Mode), or just by a high level on a IR input (Level Triggered Mode. )                                                                                |
| INTA                                    | Input          | Interrupt Acknowledge Input. This pin is used to output interrupt-vector data onto the data bus by a sequence of interrupt acknowledge pulses issued by the MPU.                                                                                                                                                   |
| A <sub>0</sub>                          | Input          | Address Line. This pin acts in conjunction with the $\overline{CS}$ , $\overline{WR}$ and $\overline{RD}$ pins. It is used by the TMP82C59A to decipher various command words the MPU writes and status the MPU wishes to read. It is typically connected to the MPU A <sub>0</sub> address line.                  |
| VCC                                     |                | + 5V Power Supply                                                                                                                                                                                                                                                                                                  |
| VSS                                     |                | Ground                                                                                                                                                                                                                                                                                                             |

# 4. FUNCTIONAL DESCRIPTION





The TMP82C59A is connected to the system bus as shown in Figure 4.2 and operates as an interrupt controller.





## 4.1 GENERAL DESCRIPTION

Whenever an interrupt request is received via IRn, the TMP82C59A, judging its mask status and priority, set INT high for requesting interrupt to MPU. Then, according to response signal ( $\overline{INTA}$  signal) from MPU or the system controller, the TMP82C59A outputs CALL op-code and vectored address data on to the data bus. MPU starts the interrupt service routine and the TMP82C59A stores which interrupt request has been serviced. At the end of the service routine, MPU resets it and informs the TMP82C59A of its end.

| A <sub>0</sub>   | D4               | D <sub>3</sub>   | RD               | WR               | CS               | READ OPERATION                                                                                                                               |
|------------------|------------------|------------------|------------------|------------------|------------------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>1           |                  |                  | 0<br>0           | 1<br>1           | 0<br>0           | IRR, ISR or Interrupt request level $\rightarrow$ Data bus IMR $\rightarrow$ Data bus                                                        |
| A <sub>0</sub>   | D4               | D3               | RD               | WR               | <u>CS</u>        | WRITE OPERATION                                                                                                                              |
| 0<br>0<br>0<br>1 | 0<br>0<br>1<br>× | 0<br>1<br>×<br>× | 1<br>1<br>1<br>1 | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0 | Data bus $\rightarrow$ OCW2<br>Data bus $\rightarrow$ OCW3<br>Data bus $\rightarrow$ ICW1<br>Data bus $\rightarrow$ OCW1, ICW2, ICW3 or ICW4 |
| A <sub>0</sub>   | D4               | D <sub>3</sub>   | RD               | WR               | <u>CS</u>        | HIGH IMPEDANCE                                                                                                                               |
| ×<br>×           | ×<br>×           | ×<br>×           | 1<br>×           | 1<br>×           | 0<br>1           | Data bus (D7 to D0) High impedance<br>Data bus (D7 to D0) High impedance                                                                     |

#### 4.2 SYSTEM CONFIGURATION

The TMP82C59A consists of the following components.

- (1) Interrupt Request Register (IRR) and Inservice Register (ISR)
- (2) Priority Resolver
- (3) Interrupt Mask Register (IMR)
- (4) Data Bus Buffer
- (5) Read/Write Logic
- (6) Cascade Buffer/Comparator
- (7) Interrupt Request Register (IRR) and Inservice Register (ISR)

Interrupt requests from IRn inputs are processed by 2 registers, IRR and ISR. IRR holds interrupt request from the respective IRn inputs while ISR holds all interrupt levels that are being serviced by the MPU. Contents of IRR and ISR can be read out by the MPU.

#### (2) Priority Resolver

The priority resolver is the block that decides the interrupt request to be sent to MPU by judging priority. If the interrupt mask register (IMR) bit corresponding to IRn input is not set to 1, IRR sends the interrupt requests to the priority resolver.

Normally, when the interrupt request level having the highest priority among these interrupt request is higher than the content of ISR, that is, the priority of the interrupt request being serviced by the MPU, the TMP82C59A sends INT signal to the MPU. When INTA signal is input as a response from the MPU the TMP82C59A sends CALL op-code and the vectored address corresponding to an interrupt request of the highest priority to MPU, and resetting IRR bit corresponding to this interrupt request sets ISR bits. The MPU processes the interrupt service, sends a command to the TMP82C59A to accept interrupt requests of lower priority at the end of the interrupt service, and resets the corresponding ISR bits. The priority resolver has a register to assign the interrupt request input of lowest priority.

#### (3) Interrupt Mask Register (IMR)

The interrupt mask register normaly acts only on IRR, and disables interrupt requests from the masked IRn input. The mask for an interrupt request input does not affect its lower priority interrupt requests. In the special mask mode, this register also acts on ISR and enables acceptance of lower level interrupt requests than the interrupt request being serviced. The content of IMR can be read out.

#### (4) Data Bus Buffer

The data bus buffer consists of 8 bit 3 state bidirectional bus buffer interfacing with the system bus. Command words, status information CALL op-code and vectored addresses are transfered via this bus buffer.

#### (5) Read/Write Logic

This circuit controls the functions for decoding and accepting command words from MPU and for feeding status information to the data bus.

In addition, this circuit controls operations including ICW (Initialization Command Word) register and OCW (Operation Set Command Word) register.

- $\overline{CS}$  : Low level input to  $\overline{CS}$  enables  $\overline{RD}$  or  $\overline{WR}$  input operation.
- $\overline{WR}$ : When  $\overline{WR} = \overline{CS} = 0$ , a command write to the TMP82C59A is enabled.
- $\overline{RD}$ : When  $\overline{RD} = \overline{CS} = 0$ , the contents of ISR, IRR and IMR and interrupt level in the poll mode can be read.

- $A_0$ :  $A_0$  is used together with  $\overline{WR}$  and  $\overline{RD}$  signals for command write or status readout. It acts as a select signal for the one of command words or status information. It is normally connected to the one of address lines.
- (6) Cascade Buffer/Comparator

When programmed as a slave device, this block stores the identification code as the slave and compares this identification code with the data on the 3 bit cascade lines  $(CAS_{0-2})$ . When both agree, the slave interpretes that the slave itself is selected. In the case of the master, an identification signal corresponding to the accepted interrupt request inputs of the slave device are output for a period from the first  $\overline{INTA}$  signal to the last  $\overline{INTA}$  signal (second or third signal).

### 4.3 INTERRUPT SEQUENCE

- (1) When the 8085A is used as the MPU
  - (a) When one or more interrupt request become high level, IRR bits corresponding to that input are set.
  - (b) The TMP82C59A judges the mask status and priority of these interrupt and outputs INT signal to MPU as necessary.
  - (c) MPU outputs INTA signal in response to INT signal.
  - (d) Upon receipt of INTA signal, the TMP82C59A outputs CALL op-code on the data bus.
  - (e) Since 'CALL' is a 3-byte instruction, additional two INTA signals are consecutively sent from MPU.
  - (f) Upon receipt of these two INTA signals, the TMP82C59A outputs the programmed vector address corresponding to the highest priority interrupt request. The TMP82C59A outputs the low-order address and then, the high-order address. Furthermore, the TMP82C59A sets the ISR bit corresponding to the interrupt request and resets IRR bit.
  - (g) The above operations complete CALL instruction and MPU executes the interrupt service. In AEOI mode, ISR bits are automatically reset immediately after the above operations. Otherwise, ISR bits are kept in the set status till EOI command is input.

#### (2) When the 8086 is used as MPU

(a) to (c) Same as (a) to (c) for the 8085A.

- (d) Even when INTA signal is received, the TMP82C59A keeps the data bus in high impedance state.
- (e) Another INTA signal is sent from MPU. The TMP82C59A outputs 8 bit pointer on the data bus, and sets the corresponding ISR bit and resets the IRR bit.
- (f) The above operations complete the interrupt acknowledge cycle. In AEOI mode, the ISR bit is automatically reset after the final INTA signal is received. Otherwise, ISR bits are kept in the set status till EOI command is input.

Further, if there is no interrupt request at the time of step (d) of the above interrupt sequence, (i.e., the request was too short in duration), the TMP82C59A performs the same operations as those when interrupt request are generated at IR<sub>7</sub>, but ISR bits are not set.

#### 4.4 INTERRUPT SEQUENCE OUTPUT

(1) When the 8085A is used as the MPU

CALL op-code is output on the data bus upon receipt of the first INTA signal and the low-order vectored address and the high-order vectored address on the data bus upon receipt of the second and third INTA signals, respectively.

The vectored address  $A_5$  to  $A_{15}$  on Table 4.3, 4.4 must be programmed in advance on the TMP82C59A. The remaining bits of the vectored addresses are produced by the TMP82C59A corresponding to interrupt request.

(2) When the 8086 is used as the MPU

When the first  $\overline{INTA}$  signal is received, the data bus is placed in the high impedance state. When the second  $\overline{INTA}$  signals is received, 8 bit pointer is output on the data bus. The 8 bit pointers T<sub>7</sub> to T<sub>3</sub> shown in Table 4.5 must be programmed in advance on the TMP82C59A. The remaining bits are automatically produced by the TMP82C59A corresponding to interrupts.

### (1) 8085A MODE

|    | Table          | e 4.2 | For Fir | st INT         | Ā              |                |                |
|----|----------------|-------|---------|----------------|----------------|----------------|----------------|
| D7 | D <sub>6</sub> | $D_5$ | D4      | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
| 1  | 1              | 0     | 0       | 1              | 1              | 0              | 1              |

050489

## Table 4.3 For Second INTA

| IR              | INTERVAL = 4   |                |                |    |                |                |                |                |
|-----------------|----------------|----------------|----------------|----|----------------|----------------|----------------|----------------|
|                 | D7             | D <sub>6</sub> | D <sub>5</sub> | D4 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
| IR <sub>7</sub> | A7             | A <sub>6</sub> | A <sub>5</sub> | 1  | 1              | 1              | 0              | 0              |
| IR <sub>6</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | 1  | 1              | 0              | 0              | 0              |
| IR <sub>5</sub> | A7             | A <sub>6</sub> | A <sub>5</sub> | 1  | 0              | 1              | 0              | 0              |
| IR4             | A7             | A <sub>6</sub> | A <sub>5</sub> | 1  | 0              | 0              | 0              | 0              |
| IR <sub>3</sub> | A7             | A <sub>6</sub> | Α5             | 0  | 1              | 1              | 0              | 0              |
| IR <sub>2</sub> | A7             | A <sub>6</sub> | A <sub>5</sub> | 0  | 1              | 0              | 0              | 0              |
| IR <sub>1</sub> | A <sub>7</sub> | A <sub>6</sub> | A <sub>5</sub> | 0  | 0              | 1              | 0              | 0              |
| IR <sub>0</sub> | A7             | A <sub>6</sub> | A5             | 0  | 0              | 0              | 0              | 0              |

050489

| IR              |                |                |                | INTER | /AL = 8        |                |                |                |
|-----------------|----------------|----------------|----------------|-------|----------------|----------------|----------------|----------------|
|                 | D7             | D <sub>6</sub> | D <sub>5</sub> | D4    | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
| IR7             | A <sub>7</sub> | A <sub>6</sub> | 1              | 1     | 1              | 0              | 0              | 0              |
| IR <sub>6</sub> | A7             | A <sub>6</sub> | 1              | 1     | 0              | 0              | 0              | 0              |
| IR <sub>5</sub> | A <sub>7</sub> | A <sub>6</sub> | 1              | 0     | 1              | 0              | 0              | 0              |
| IR4             | A7             | A <sub>6</sub> | 1              | 0     | 0              | 0              | 0              | 0              |
| IR <sub>3</sub> | A7             | A <sub>6</sub> | 0              | 1     | 1              | 0              | 0              | 0              |
| IR <sub>2</sub> | A7             | A <sub>6</sub> | 0              | 1     | 0              | 0              | 0              | 0              |
| IR <sub>1</sub> | A7             | A <sub>6</sub> | 0              | 0     | 1              | 0              | 0.             | 0              |
| IR <sub>0</sub> | A7             | A <sub>6</sub> | 0              | 0     | 0              | 0              | 0              | 0              |

050489

# Table 4.2 For Third INTA

| D7              | D <sub>6</sub>  | D <sub>5</sub>  | D <sub>4</sub>  | D <sub>3</sub>  | D <sub>2</sub>  | D <sub>1</sub> | D <sub>0</sub> | _ |
|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------------|----------------|---|
| A <sub>15</sub> | A <sub>14</sub> | A <sub>13</sub> | A <sub>12</sub> | A <sub>11</sub> | A <sub>10</sub> | Ag             | A <sub>8</sub> |   |

050489

### (2) 8086 MODE

Table 4.5 Second INTA

|                 | D7             | D <sub>6</sub> | D <sub>5</sub> | D4             | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|-----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|----------------|
| IR7             | T7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 1              | 1              | 1              |
| IR <sub>6</sub> | T7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 1              | 1              | 0              |
| IR <sub>5</sub> | T7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 1              | 0              | 1              |
| IR4             | T <sub>7</sub> | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 1              | 0              | 0              |
| IR <sub>3</sub> | T7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 0              | 1              | 1              |
| IR <sub>2</sub> | T <sub>7</sub> | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 0              | 1              | 0              |
| IR <sub>1</sub> | T7             | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 0 ·            | 0              | 1              |
| IR <sub>0</sub> | T <sub>7</sub> | T <sub>6</sub> | T <sub>5</sub> | T <sub>4</sub> | T <sub>3</sub> | 0              | 0              | 0              |

#### 4.5 PROGRAMMING TMP82C59A

The TMP82C59A accepts the following 2 types of command words.

(1) Initialization Command Words (ICW)

Prior to operating the TMP82C59A, it is necessary to program this command.

(2) Operation Command Words (OCW)

This command is for operating the TMP82C59A in various operating modes and is programmable anytime during the TMP82C59A is in operation.

(1) ICW

There are 4 kinds of commands; ICW1, ICW2, ICW3 and ICW4.

Each of these command is not programmable independently. The initialization is made according to the initialization command sequence shown in Figure 4.3. ICW3 is used for cascade connection and ICW4 is for setting optional modes.



Figure 4.3 Initialization Command Sequence

# ICW1

When  $A_0=0$  and  $D_4=1$ , the initialization is interpreted as ICW1 and the initialization of following 5 items are made independently of content of the command:

- [1] The interrupt mask register (IMR) is cleared.
- [2] The interrupt request input IR<sub>7</sub> becomes the lowest priority.
- [3] The special mask mode is cleared and IRR is assigned as the register for reading status information.
- [4] When  $IC_4 = 0$ , all function bits of ICW4 are set at "0".
- [5] The edge detection circuit of the interrupt request terminal is cleared.

ICW1 makes the assignment of vector addresses  $A_7$  to  $A_5$ , assignment as to whether the interrupt request input is to be made in the edge trigger mode or the level trigger mode (LTIM), assignment of CALL address intervals when the 8085A is used as MPU (refer to Table 4.3) (ADI), assignment as to whether the cascade connection to be made (SNGL) and assignment as to whether ICW4 is needed (IC4).

# ICW2

ICW2 assigns high-order vector addresses  $A_8$  to  $A_{15}$  when the 8085A is used as MPU or 8-bit pointers  $T_3$  to  $T_7$  when the 8086 is used as MPU. TMP82C59A interpretes a command written with  $A_0$  input made to "H" level after ICW1 written as ICW2.





MPU85-182

### ICW3

This is a command required for cascade connection of plural number of the TMP82C59As. When SNGL=0 in ICW1, the TMP82C59A interpretes a command written with  $A_0$  input made at "H" level after ICW2 as ICW3.

[1] Master Mode

In the master mode, the TMP82C59A specifies individually as to whether a slave device is added to each interrupt request input.

If the 8085A is used as MPU when addition of a slave device is specified, the master device outputs CALL op-code on the data bus upon receipt of the first  $\overline{\text{INTA}}$  signal and simultaneously outputs the slave identification code to the cascade line.

The master device becomes high impedance at the second and third INTA signals, and the slave devices selected by the identification code outputs vector address on the data bus. When the 8086 is used as MPU, both the master and slave devices become high impedance at the first  $\overline{\text{INTA}}$  signal. Simultaneously, the master device outputs the slave identification code to the cascade line. The master device also become high impedance at the second  $\overline{\text{INTA}}$  signal and the selected slave device outputs a pointer on the data bus. When it is specified that no slave device is added, the master device outputs both CALL op-code and vector address as a response to  $\overline{\text{INTA}}$  signal and simultaneously outputs "L" signal to 3 cascade lines. This is the same as the identification code of the slave device connected to IR<sub>0</sub> and therefore, in the case of the interrupt request input without the slave device, added, no slave device can be added to IR<sub>0</sub>.

Further, to specify the master or slave, the  $\overline{SP/EN}$  terminal must be set at "H" level or BUF must be set at 1 and M/S at 1 by ICW4.

[2] Slave Mode

In the slave mode, the TMP82C59A specifies the slave identification code. The slave device compares its identification code with the identification code sent from the master device via the cascade line and if they agree, outputs vector addresses on the data bus upon receipt of the second and third  $\overline{\text{INTA}}$  signals. Further, to specify the slave mode, the  $\overline{\text{SP/EN}}$  terminal must be set at "L" level or BUF at 1 and M/S at 0 by ICW4.

ICW4

ICW4 is effective only when  $IC_4 = 1$  in ICW1.

Although ICW4 is effective for assignment of the special fully nested mode (SFNM), assignment of the buffer mode (BUF) and in the buffer mode, this command makes the assignment of the master/slave (M/S), automatic EOI (AEOI) and MPU mode. When  $IC_4 = 0$  in ICW1, all function bits of ICW4 are set at "0".

(2) OCW

There are 3 kinds of commands: OCW1, OCW2, and OCW3. Any time after ICW is programmed, these command can be programmed to set the TMP82C59A in various operation modes.

OCW1

After ICW is set, the TMP82C59A interpretes the operation set command to be OCW1when  $A_0=1$ . This command is used for setting the content of the interrupt mask register (IMR). The OCW1 format is shown in Figure 4.5.

OCW2

The TMP82C59A interpretes the operation set command to be OCW2 when  $A_0=0$ ,  $D_4=0$  and  $D_3=0$ . This command is used for outputting EOI.  $L_2$  to  $L_0$  are effective only in the case of specific EOI and specific rotation. The OCW2 format is shown in Figure 4.5.

OCW3

The TMP82C59A interpretes the operation set command to be OCW3 when  $A_0=0$ ,  $D_4=0$  and  $D_3=1$ . This command is used for assigning the special mask mode, the poll mode and register for status information readout, that is, assigning IRR or ISR. The OCW3 format is shown in Figure 4.5.



Figure 4.5 OCW Format

MPU85-185

#### 4.6 EXPLANATION OF MODES AND COMMANDS

#### (1) FULLY NESTED MODE

Unless the other modes are specified, the TMP82C59A operates in this mode. Under this mode,  $IR_0$  is the highest priority level and IR7 bocomes the lowest.

When INTA signal is input, vector address corresponding to an interrupt and request having the highest priority at the time is output together with CALL op-code on the data bus and furthermore, corresponding ISR bits are kept set till EOI command is input to the TMP82C59A before MPU returns from the service routine or to the final leading edge of INTA pulse in AEOI mode. As long as these ISR bits are kept set, lower priority interrupt requests are ignored. Priority can be changed by OCW2.

#### (2) EOI (END OF INTERRUPT)

EOI command is used to reset ISR bits. It is necessary for MPU to output EOI command before returning from the service routine.

When AEOI is set in ICW4, ISR bit are automatically reset at the leading edge of the final INTA pulse and it is therfore not necessary to output EOI command. As ISR bits are set in both the master and slave devices when cascade connected, it is necessary to output EOI command to both master device and the slave device corresponding to the master device.

EOI command is available in 2 kinds: non-specific EOI and specific EOI commands. When non-specific EOI command is output to the TMP82C59A, ISR bit having the highest priority among ISR bit is reset. However, in the special mask mode it is not possible to reset ISR bit that are masked by IMR by the non-specific EOI command, and ISR bit having the highest priority among the unmasked ISR bits is reset. On the other hand, it is possible to specify ISR bit to be reset by the specific EOI command by a program. EOI command is executed by OCW2.

#### (3) AEOI (AUTOMATIC EOI) MODE

In this mode, the non-specific EOI operation is automatically executed at the leading edge of the final INTA signal.

Therefore, this mode cannot be used for nested interruptions. In addition, this mode also cannot be used in the slave TMP82C59A. The TMP82C59A can be set in AEOI mode by setting AEOI bit in ICW4 to 1.

### (4) AUTOMATIC ROTATION

This mode is effective in the application to give equal priority to the interrupt devices. In this mode, whenever the interrupt service ends, priority of each interrupt request is updated so that the serviced interrupt request is set at the lowest priority. Priority of interrupt request input IRn (n=0 to 7) that has been serviced becomes the lowest priority level 7 and becomes high in order toward IR<sub>0</sub> and then, IR<sub>7</sub> and next IR<sub>n+1</sub> become the highest priority level 0. (Rotation Priority)

For instance, when the interrupt request  $IR_4$  is seviced as shown in Figure 4.6, the priority of each interrupt request input is updated.

This mode specifies R=1, SL=0 and EOI=1 by OCW2 at the end of service. Further, in case of AEOI mode, when R=1, SL=0 and EOI=0 are specified by OCW2, the internal flip-flop is set and the TMP82C59A operates in this mode. If R=0, SL=0 and EOI=0 are specified by OCW2, this mode is cleared.

before Rotation (highest priority interrupt request IR4 is being serviced.)



After ROTATION (Interrupt request IR4 is being serviced.)



050489

Figure 4.6 The Example of Interrupt Priority Transition in Automatic Rotation Mode

### (5) SPECIFIC ROTATION

In the automatic rotation mode, priority of each interrupt request input is updated whenever interrupt requests are serviced. Under this mode it is possible to change priority by specifying an interrupt request input to be set at the lowest priority by a program. Priority is determined according to the ratation priority. In this mode, R and SL are set at 1 by OCW2 and interrupt request input that is to be lowest priority at  $L_2$  to  $L_0$  is specified. Priority can be changed simultaneously with EOI command or independently regardless of EOI command.

#### (6) INTERRUPT MASK

Each interrupt request input can be masked individually by the interrupt mask register (IMR). Content of IMR can be specified by OCWI.

#### (7) SPECIAL MASK MODE

Normally when an interrupt service routine is being executed, lower priority interrupt requests than the interrupt request being serviced are ignored unless ISR bits are reset by EOI command. This special mode is used for an application in which an interrupt request of lower priority is approved during the service. In this mode, IMR also acts as the mask for ISR. That is, the TMP82C59A processes an interrupt request by assuming that ISR bit and IRR bit corresponding to IMR bit set at "1" have not been set. This mode is set by setting ESMM = 1 and SMM = 1 by OCW3.

Further, when ESMM=1 and SMM=0 are assigned by OCW3, this mode is cleared to the normal mode. The IMR programming is made by OCW1.

#### (8) POLL COMMAND

This mode is used in a state where the internal interrupt enable flip-flop of MPU is disabled and no interrupt is authorized. The service to the device is made by using the poll command. The poll command specifies P=1 in OCW3. The mode becomes now the poll mode. When the read operation ( $\overline{RD}=0$ ,  $\overline{CS}=0$ ) is made on the TMP82C59A, the following output is made on the data bus:

| D7 | D <sub>6</sub> | $D_5$ | D4 | D <sub>3</sub> | D <sub>2</sub> | D <sub>1</sub> | D <sub>0</sub> |
|----|----------------|-------|----|----------------|----------------|----------------|----------------|
| 1  | -              | -     | -  | -              | W <sub>2</sub> | W1             | W <sub>0</sub> |

 $\label{eq:W2} W_0 \sim W_2 ~:~ \mbox{Binary code of highest priority interrupt request among} $$ interrupt requests to the interrupt request inputs. $$$ 

I : There is an interrupt request to MPU when I = 1.

050489

#### Figure 4.7 Poll Mode Data Format

The TMP82C59A interpretes  $\overline{\text{RD}}$  signal as the interrupt acknowledge and when  $D_7=1$  is output, sets corresponding ISR bit. This poll mode is valid for a period from  $\overline{\text{WR}}$  (P=1 in OCW3) to next  $\overline{\text{RD}}$  ( $\overline{\text{CS}}=0$ ). Further, an interrupt request to be serviced is determined at the time when the mode is made to the poll mode and end even when a new or high priority interrupt request is sent between  $\overline{\text{WR}}$  and  $\overline{\text{RD}}$ , it is not accepted.

### (9) READING STATUS

MPU is capable of reading the contents of 3 registers (IRR, ISR, IMR). When the reading operation is made at  $A_0 = 0$ , the content of IRR or ISR can be read out. Selection of IRR and ISR is made by OCW3. When RR is set at 1 and RIS at 0, IRR is assigned and when RR and RIS are set at 1, ISR is assigned.

This assignment is kept stored without necessity for performing at every reading operation. IMR is read when  $A_0=1$ . If the poll mode is specified before the reading operation, the poll command has priority.

### (10) EDGE TRIGGERED MODE / LEVEL TRIGGERED MODE

#### This mode is selected by LTIM of ICWI.

When LTIM is 0, the edge triggered mode is selected and interrupt request is triggered at the leading edge of the interrupt request signal and kept continued by holding "H" level. When LTIM is 1, the level triggered mode is selected and interrupt request is recognized by "H" level of the interrupt request signal. For both modes it is necessary to hold the interrupt request input at "H" level by triggering it till the fast  $\overline{INTA}$  signal is output from MPU. If the interrupt request input is at "L" level when  $\overline{INTA}$  signal is output from MPU, the same operations as those when interrupt requests are generated at IR<sub>7</sub> are performed but ISR bits are not set.

### (11) SPECIAL FULLY NESTED MODE

This mode is used to give priority to the interrupt request input for the slave devices when they are cascade connected.

This mode is assigned to the master TMP82C59A when SFNM is 1 in ICW4.

With the exception of the following 2 points, this mode is identical to the fully nested mode.

- [1] Even when an interrupt request from a slave device is being serviced, the master device accepts a higher priority interrupt request from the same slave device without ignoring it. (In the fully nested mode, a higher priority interrupt request from the slave device that is now being serviced is ignored and interrupt requests from a higher priority slave device only are accepted.)
- [2] When an interrupt request from a slave device is being serviced, it is necessary to check by a software as to whether the interrupt request is only one interrupt request from that slave device.

When the service ended, after the non-specific EOI is output to that slave device, MPU has to check whether all ISR bits of that slave device are "0". If they are all "0", that slave has no interrupt request being serviced and therefore, the non-specific EOI is output to the master device to allow acceptance of interrupt request from the lower priority slave devices.

Otherwise, the non-specific EOI must not be output to the master device.
#### (12) BUFFERED MODE

This mode is to output an enable signal to a data bus buffer from the <u>SP/EN</u> terminal when the data bus buffer is needed for the data bus on a large system. Under this mode, "L" level signal is output to the <u>SP/EN</u> terminal whenever the data bus output of the TMP82C59A is enabled. The assignment of this mode is made by ICW4 simultaneously with the assignment of the master/slave devices.

#### (13) CASCADE MODE

The TMP82C59A is able to process interrupt requests up to 64 levels by one master and 8 slave devices.

The cascading is shown in Figure 4.8. The master TMP82C59A selects the slave devices by the identification codes fully using 3 cascade lines. INT output of each slave device is connected to the interrupt request inputs of the master device. Further, the identification codes corresponding to respective connections are assigned for the slave devices by ICW3.

When interrupt request are generated at the interrupt request inputs of the slave devices and accepted, the master device outputs the identification code to the slave device at the first  $\overline{\text{INTA}}$  signal trailing edge to output vector address or pointer. This identification code is kept maintained to the leading edge of the final  $\overline{\text{INTA}}$  signal. Normally, the master device outputs "L" level signal to all cascade line. EOI command must be output twice; to the master and second, to the slave corresponding to the interrupt service. Further, an address decoder is required to activate to the  $\overline{\text{CS}}$  input of each TMP82C59A.



050489



MPU85-191

### 5.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL | ITEM                                           | RATING                         |
|--------|------------------------------------------------|--------------------------------|
| VCC    | VCC Supply Voltage (with respect to VSS (GND)) | -0.5 to +7V                    |
| VIN    | Input Voltage                                  | -0.5 to V <sub>CC</sub> + 0.5V |
| VOUT   | Output Voltage                                 | -0.5 to V <sub>CC</sub> + 0.5V |
| PD     | Power Dissipation                              | 250mW                          |
| Tsol   | Soldering Temperature (Soldering Time 10 sec)  | 260℃                           |
| Tstg   | Storage Temperature                            | -65℃ to +150℃                  |
| Topr   | Operating Temperature                          | -40℃ to +85℃                   |
|        |                                                | 050489                         |

### 5.2 DC CHARACTERISTICS

## $Ta = -40 \text{ to } + 85^{\circ}\text{C}$ , VCC = 5 ± 10%, Vss (GND) = 0V, Unless otherwise noted.

| SYMBOL | PARAMETER                   | TEST CONDITION                                  | MIN.    | TYP. | MAX.      | UNIT |
|--------|-----------------------------|-------------------------------------------------|---------|------|-----------|------|
| VIL    | Input Low Voltage           |                                                 | -0.5    | _    | 0.8       | V    |
| VIH    | Input High Voltage          |                                                 | 2.2     | —    | VCC + 0.5 | V    |
| VOL    | Output Low Voltage          | IOL = 2.2mA                                     | _       | —    | 0.45      | V    |
| VOH1   | Output High Voltage         | IOH1 = -400µA                                   | 2.4     | —    | _         | V    |
| VOH2   | Output High Voltage         | IOH2 = -100µА                                   | VCC-0.8 |      | -         | V    |
| IIL    | Input Leak Current          | $0V \leq VIN \leq VCC$                          | —       | —    | ± 10      | μA   |
| IIOFL  | Output Leak Current         | $0.45V \le VIN \le VCC$                         | _       | _    | ± 10      | μA   |
|        | Input Current (IP)          | VIN = 0V                                        | —       | —    | -300      | μA   |
| ILIN   | Input Current (IR)          | VIN = VCC                                       | -       | _    | 10        | μA   |
| ICC1   | Operating Supply<br>Current | I/O CYCLE = 1µS<br>VIH = VCC-0.2V<br>VIH = 0.2V | _       | _    | 5         | mA   |
| ICC2   | Stand-by Supply<br>Current  | VIH = VCC-0.2V<br>VIL = 0.2V                    | _       | -    | 10        | μА   |

050489

### 5.3 INPUT CAPACITANCE

 $Ta = 25^{\circ}C, VCC = VSS (GND) = 0V$ 

| SYMBOL | PARAMETER                  | TEST<br>CONDITIONS | MIN. | TYP. | MAX. | UNIT |
|--------|----------------------------|--------------------|------|------|------|------|
| CIN    | INPUT CAPACITANCE          | fC = 1 MHz         | _    |      | 10   | рF   |
| CI/O   | INPUT / OUTPUT CAPACITANCE | pins, 0V           | —    | —    | 20   | pF   |

### 5.4 AC CHARACTERISTICS

 $Ta = -40^{\circ}C to + 85^{\circ}C, VCC = 5V \pm 10\%, VSS (GND) = 0V$ 

| SYMBOL | PARAMETER                                                | TEST<br>CONDITION     | MIN. | TYP. | MAX. | UNIT |
|--------|----------------------------------------------------------|-----------------------|------|------|------|------|
| TAHRL  | $A_0/\overline{CS}$ Setup Time ( $\overline{RD}$ )       |                       | 0    | -    | -    | ns   |
| TRHAX  | $A_0/\overline{CS}$ Hold Time ( $\overline{RD}$ )        |                       | 0    | _    | -    | ns   |
| TRLRH  | RD Pulse Width                                           |                       | 160  | -    | -    | ns   |
| TAHWL  | $A_0/\overline{CS}$ Setup Time (WR)                      |                       | 0    | -    | -    | ns   |
| TWHAX  | $A_0/\overline{CS}$ Hold Time ( $\overline{WR}$ )        |                       | 0    | -    | -    | ns   |
| TWLWH  | WR Pulse Width                                           |                       | 120  | -    | -    | ns   |
| TDVWH  | $D_0$ to $D_7$ Setup Time (WR)                           |                       | 120  | _    | -    | ns   |
| TWHDX  | $D_0$ .to $D_7$ Hold Time (WR)                           |                       | 0    | -    | -    | ns   |
|        | Input IR Low Level Pulse width                           |                       | 100  |      |      |      |
| 11[11] | (Edge Trigger Mode)                                      |                       | 100  | -    | _    | ns   |
|        | Casecade Setup Time                                      |                       | 10   |      |      |      |
| TCVIAL | (Second or Third INTA)                                   |                       | 40   |      |      | 115  |
| TRHRL  | RD to Next Command                                       |                       | 160  | -    | —    | ns   |
| TWHWL  | WR to Next Command                                       |                       | 190  | —    | -    | ns   |
|        | End of Command to next Command                           |                       |      |      |      |      |
| TCHCL  | (Not Same)                                               |                       | 250  | —    | _    | ns   |
|        | End of INTA sequence to next INTA                        |                       |      |      |      |      |
|        | sequence                                                 |                       |      |      |      |      |
| TRLDV  | Valid Data Delay (RD / INTA)                             | D7 to D0              | -    | -    | 120  | ns   |
| TRHDZ  | Data Floating (RD / INTA)                                | CL = 100pF            | 10   | -    | 85   | ns   |
| нінст  | Interrupt Output Delay (IR)                              | INT                   |      |      | 300  | ns   |
| TIALCV | Valid Cascade Delay (INTA)                               | CL = 100pF            | -    |      | 360  | ns   |
| TRLEL  | Enable Active (RD / INTA)                                | CAS <sub>0</sub> to 2 |      |      | 100  | ns   |
| TRHEH  | Enable Inactive (RD / INTA)                              | CL = 100pF            | -    |      | 150  | ns   |
| TAHDV  | Valid Data Delay (A <sub>0</sub> / <del>CS</del> )       |                       | _    | _    | 200  | ns   |
| TCVDV  | Valid Data Delay (CAS <sub>0</sub> to CAS <sub>2</sub> ) | 1                     | —    | —    | 200  | ns   |

### AC CHARACTERISTICS TEST CONDITION



AC Testing Load Circuit



### MPU85-193

## 6. TIMING WAVEFORMS

WRITE OPERATION



#### READ AND INTA OPERATION





OTHER TIMING





## 7. EXTERNAL DIMENSION VIEW

## 7.1 28 pins PRASTIC DIP

DIP28-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical position with respect to NO. 1 and NO. 28 leads.

MPU85-196

7.2 28 pins SMALL OUTLINE PACKAGE

## SOP28-P-450



270289

Note : Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

# TOSHIBA MOS TYPE DEGITAL INTEGRATED CIRCUIT Silicon Monolithic N-Channel Silicon Gate MOS

## TMP8259AP

## PROGRAMMABLE INTERRUPT CONTROLLER

## 1. GENERAL DESCRIPTION

TMP8259AP is a programmable interrupt controller. It handles up to eight vectored priority interrupts for the MPU. It is cascadable for up to 64 vectored priority interrupts without additional circuitry.

#### FEATURES

- Eight Level Priority Controller.
- Expandable to 64 Level.
- Interrupt Modes, Interrupt Mask, Vectored Address Programmable.
- Single + 5V Power Supply.
- Supports 8085A, 8086 Microcomputer Interrupt Sequence.

## 2. PIN CONNECTIONS (TOP VIEW)

| INP8259AP | TMP8259, | AP |
|-----------|----------|----|
|-----------|----------|----|

| CS               | Ц | 1  | $\bigcirc$ | 28 | Ь | vcc              |
|------------------|---|----|------------|----|---|------------------|
| WR               |   | 2  |            | 27 | Ь | A <sub>0</sub>   |
| RD               |   | 3  |            | 26 | 白 | INTA             |
| D7               | Ц | 4  |            | 25 |   | IR7              |
| D6               | Ц | 5  |            | 24 | Þ | IR <sub>6</sub>  |
| $D_5$            |   | 6  |            | 23 | 白 | IR <sub>5</sub>  |
| D4               |   | 7  |            | 22 | Þ | IR4              |
| D3               |   | 8  |            | 21 | Þ | IR <sub>3</sub>  |
| D2               | Ц | 9  |            | 20 | þ | IR <sub>2</sub>  |
| D <sub>1</sub>   |   | 10 |            | 19 | þ | IR <sub>1</sub>  |
| $D_0$            |   | 11 |            | 18 | þ | IR <sub>0</sub>  |
| CAS <sub>0</sub> |   | 12 |            | 17 | þ | INT              |
| CAS <sub>1</sub> |   | 13 |            | 16 | þ | SP / EN          |
| VSS              |   | 14 |            | 15 | Þ | CAS <sub>2</sub> |

## 3. PIN NAMES AND PIN DESCRIPTION

| Pin Name                                | Input / Output | Function                                                                                                                                                                                                                                                                                                               |
|-----------------------------------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CS                                      | Input          | Chip Select Input. A low on this pin enables $\overline{RD}$ and $\overline{WR}$ communication beween the MPU and the TMP8259AP. INTA functions are independent of $\overline{CS}$ .                                                                                                                                   |
| WR                                      | Input          | Write Control Input. A low on this pin when $\overline{\text{CS}}$ is low enables the TMP8259AP to accept command words from MPU.                                                                                                                                                                                      |
| RD                                      | Input          | Read Control Input. A low on this pin when $\overline{\text{CS}}$ is low enables the TMP8259AP to release status onto the data bus for the MPU.                                                                                                                                                                        |
| D <sub>0</sub> to D <sub>7</sub>        | Input/Output   | Bidirectional Data Bus. Command status and interrupt-vector information is transferred via this bus.                                                                                                                                                                                                                   |
| CAS <sub>0</sub> to<br>CAS <sub>2</sub> | Input / Output | Casecade Lines. The CAS lines from a private TMP8259AP bus to control a multiple TMP8259AP structure. These pins are outputs for a master TMP8259AP and inputs for a slave TMP8259AP.                                                                                                                                  |
| SP / EN                                 | Input / Output | Slave Program / Enable buffer. This is a dual function pin. When in the buffered mode is can be used as on Output to control buffer transceivers ( $\overline{EN}$ ). When not in the buffered mode it is used as an input to designate a master TMP8259AP ( $\overline{SP} = 1$ ) or a slave ( $\overline{SP} = 0$ ). |
| INT                                     | Output         | Interrupt Request Output. This pin goes high whenever a valid interrupt request is asserted. It is used to interrupt the MPU. It is connected to MPU's interrupt pin.                                                                                                                                                  |
| $IR_0$ to $IR_7$                        | Input          | Interrupt Request Inputs. An interrupt request is executed by raising an IR input<br>(low to high), and holding it high until it is acknowledged (Edge Triggered<br>Mode), or just by a high level on a IR input (Level Triggered Mode.)                                                                               |
| ĪNTA                                    | Input          | Interrupt Ackowledge INPUT. This pin is used to enable TMP8259AP interrupt-<br>vector data onto the data bus by a sequence of interrupt ackowledged pulses<br>issued by the MPU.                                                                                                                                       |
| A <sub>0</sub>                          | Input          | $A_0$ address line. This pin acts in conjunction with the $\overline{CS}$ , $\overline{WR}$ and $\overline{RD}$ pins. It is used by the TMP8259AP to decipher various command words the MPU writes and status the MPU wishes to read. It is typically connected to the MPU $A_0$ address line.                         |
| VCC                                     |                | + 5V Power Supply                                                                                                                                                                                                                                                                                                      |
| VSS                                     |                | Ground                                                                                                                                                                                                                                                                                                                 |

## 4. BLOCK DIAGRAM



## 5.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL | ITEM                                           | RATING        |
|--------|------------------------------------------------|---------------|
| VCC    | VCC Supply Voltage (with respect to VSS (GND)) | -0.5 to +7V   |
| VIN    | Input Voltage                                  | -0.5 to +7V   |
| PD     | Power Dissipation                              | 1W            |
| Tsol   | Soldering Temperature (Soldering Time 10 sec)  | 260℃          |
| Tstg   | Storage Temperature                            | -65℃ to +150℃ |
| Topr   | Operating Temperature                          | 0℃ to 70℃     |

050489

## 5.2 DC CHARACTERISTICS

## Ta = 0 to + 70°C, VCC = 5V $\pm$ 10%, Vss (GND) = 0V

| SYMBOL | PARAMETER                    | TEST CONDITION          | MIN. | TYP. | MAX.      | UNIT |
|--------|------------------------------|-------------------------|------|------|-----------|------|
| VIL    | Input Low Voltage            |                         | -0.5 | _    | 0.8       | V    |
| VIH    | Input High Voltage           |                         | 2.2  |      | VCC + 0.5 | V    |
| VOL    | Output Low Voltage           | IOL = 2.2mA             | _    | _    | 0.45      | V    |
| VOH    | Output High Voltage          | IOH = -400µА            | 2.4  | -    | -         | V    |
| VOH    | Output High Voltage<br>(INT) | IOH = -100µА            | 3.5  | -    | -         | V    |
| (INT)  |                              | IOH = -400µА            | 2.4  | _    | ·         | V    |
| IIL    | Input Leak Current           | $0V \leq VIN \leq VCC$  |      | _    | ± 10      | μA   |
| liofl  | Output Leak Current          | $0.45V \le VIN \le VCC$ | _    | —    | ± 10      | μA   |
| מווו   | Input Current (ID)           | VIN = 0V                | _    | -    | -300      | μA   |
| ILIK   | Input Current (IR)           | VIN = VCC               | -    |      | 10        | μA   |
| ICC    | Operating Supply<br>Current  |                         | _    | _    | 85        | mA   |

050489

## 5.3 INPUT CAPACITANCE

 $Ta = 25^{\circ}C, VCC = VSS$ 

| SYMBOL | PARAMETER                  | TEST<br>CONDITIONS | MIN. | TYP. | MAX. | UNIT |
|--------|----------------------------|--------------------|------|------|------|------|
| CIN    | INPUT CAPACITANCE          | fC = 1 MHz         | —    | -    | 10   | рF   |
| CI/O   | INPUT / OUTPUT CAPACITANCE | pins, 0V           | -    | -    | 20   | pF   |

050489

### MPU85-201

## 5.4 AC CHATACTERISTICS

 $Ta = 0^{\circ}C to + 70^{\circ}C, VCC = 5V \pm 10\%, VSS = 0V$ 

| SYMBOL | PARAMETER                                          | TEST<br>CONDITION                | MIN. | TYP. | MAX. | UNIT |
|--------|----------------------------------------------------|----------------------------------|------|------|------|------|
| TAHRL  | $A_0/\overline{CS}$ Setup Time ( $\overline{RD}$ ) |                                  | 0    | -    | -    | ns   |
| TRHAX  | $A_0/\overline{CS}$ Hold Time ( $\overline{RD}$ )  |                                  | 0    | -    | -    | ns   |
| TRLRH  | RD Pulse Width                                     |                                  | 235  | -    |      | ns   |
| TAHWL  | $A_0/\overline{CS}$ Setup Time (WR)                |                                  | 0    | -    | -    | ns   |
| TWHAX  | $A_0/\overline{CS}$ Hold Time (WR)                 |                                  | 0    | -    |      | ns   |
| TWLWH  | WR Pulse Width                                     |                                  | 290  | -    | -    | ns   |
| TDVWH  | $D_0$ to $D_7$ Setup Time (WR)                     |                                  | 240  |      | -    | ns   |
| TWHDX  | $D_0$ to $D_7$ Hold Time (WR)                      |                                  | 0    | -    | -    | ns   |
|        | Input IR Low Level Pulse width                     |                                  | 100  |      |      |      |
| 11010  | (Edge Trigger Mode)                                |                                  | 100  |      | _    | ns   |
| ΤΟΛΙΔΙ | Casecade Setup Time                                |                                  |      |      |      |      |
| ICVIAL | (Second or Third INTA)                             |                                  | 55   | _    |      | ns   |
| TRHRL  | RD to Next Command                                 |                                  | 160  | -    | -    | ns   |
| TWHWL  | WR to Next Command                                 |                                  | 190  | -    | -    | ns   |
|        | End of Command to next Command                     |                                  |      |      |      |      |
| *TCHCL | (Not Same)                                         |                                  | 500  |      | _    | ns   |
|        | End of INTA sequence to next INTA                  |                                  |      |      |      |      |
|        | sequence                                           |                                  |      |      |      |      |
| TRLDV  | Valid Data Delay (RD / INTA)                       | D <sub>7</sub> to D <sub>0</sub> | -    | -    | 200  | ns   |
| TRHDZ  | Data Floating (RD / INTA)                          | CL = 100pF                       | 10   | -    | 100  | ns   |
| нініт  | Interrupt Output Delay (IR)                        | INT                              | —    | -    | 350  | ns   |
| TIALCV | Valid Cascade Delay (INTA)                         | CL = 100pF                       | -    | -    | 565  | ns   |
| TRLEL  | Enable Active (RD / INTA)                          | CAS <sub>0</sub> to 2            | -    | -    | 125  | ns   |
| TRHEH  | Enable Inactive (RD / INTA)                        | CL = 100pF                       | -    | _    | 150  | ns   |
| TAHDV  | Valid Data Delay (A <sub>0</sub> / <del>CS</del> ) |                                  | -    | -    | 200  | ns   |
| TCVDV  | Valid Data Delay (CAS $_0$ to CAS $_2$ )           | -                                | -    | —    | 300  | ns   |

050489

 Worst case timing for TCHCL in an actual microprocessor system is typically much greater than 500 ns (i.e. 8085A=1.6µs, 8085A-2=1µs, 8086=1µs, 8086-2=625µs)

#### AC CHARACTERISTICS TEST CONDITION



## 6. TIMING WAVEFORMS

WRITE OPERATION



READ AND INTA OPERATION









## 7. EXTERNAL DIMENSION VIEW

28 pins PRASTIC DIP

DIP28-P-600



270289

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical position with respect to No.1 and No.28 leads.

## MULTIMODE DMA CONTROLLER

## TMP82C37AP-5/TMP82C37AM-5/TMP82C37AT-5

## 1. GENERAL DESCRIPTION

The TMP82C37AP-5/AM-5/AT-5 (hereinafter referred to as TMP82C37A) is a multimode direct memory access (DMA) controller. The TMP82C37A improves the system function by directly transferring information between the system memory and external devices. Memory-to-Memory data transfer capability is also provided.

The TMP82C37A is provided with versatile programmable control functions in order to improve data throughput.

The TMP82C37A is used with an 8-bit address register connected externally. The TMP82C37A has four built-in independent channels and it is possible to expand channels through cascade connection.

There are three basic data transfer modes which are programmable by the user. Each channel is programmable individually and autoinitialization is possible by End of Process  $(\overline{\text{EOP}})$  signal.

Each channel has the maximum 64K capability for both address and word count.  $\overline{\text{EOP}}$  signal is capable of terminating data transfer between DMA and memories.  $\overline{\text{EOP}}$  signal is useful for block search or verify or for terminating erroneous service.

## 2. FEATURES

- Four independent DMA channels available
- Three transfer modes available; block, demand, and single transfer modes
- Independent auto initialize function provided to each of all channels
- Memory-to-Memory transfer
- Address increment or decrement
- All DMA request disabled by disabling the master system
- Individual DMA request enable/disable control
- Unrestricted channel expansion by cascade connection
- End of Process (EOP) input for terminating transfer
- Software DMA Request
- Polarity control provided for DREQ signal and DACK signal
- Option for increasing transfer speed up to 2.5M word/sec (@5MHz)
- Single + 5V power supply
- Low power consumption 5mA TYP. @5MHz
- Extend operating temperature  $-40^{\circ}$ C to  $+85^{\circ}$ C

## 3. PIN CONNECTION (TOP VIEW)

3.1 TMP82C37AP-5 (DIP), TMP82C37AM-5 (SOP)

|                                             |    | 1 /        |    |                                      |
|---------------------------------------------|----|------------|----|--------------------------------------|
| ior 🔸                                       | 1  | $\bigcirc$ | 40 | $\rightarrow A_7$                    |
| IOW 🔸                                       | 2  |            | 39 | □> A <sub>6</sub>                    |
| MEMR 🔶 🛛                                    | 3  |            | 38 | □> A5                                |
| MEMW 🔶 🛛                                    | 4  |            | 37 | □> A4                                |
| note → 🛛                                    | 5  |            | 36 | ] ↔ EOP                              |
| READY [                                     | 6  |            | 35 | □> A3                                |
| HLDA 🔶 🛙                                    | 7  |            | 34 | □ <del>&lt;&gt;</del> A <sub>2</sub> |
| adstb 🗲 [                                   | 8  |            | 33 | ] → A1                               |
| AEN 🔫 🗆                                     | 9  |            | 32 | □> A0                                |
| HRQ 🔶 🛛                                     | 10 |            | 31 | ] V <sub>CC</sub> ( + 5V)            |
| $\overline{\text{CS}} \rightarrow \text{C}$ | 11 |            | 30 | D ↔ DB0                              |
| CLK 🔶 🛛                                     | 12 |            | 29 | D ↔ DB1                              |
| RESET> [                                    | 13 |            | 28 | ] ↔ DB2                              |
| DACK2 🖛 🛛                                   | 14 |            | 27 | DB3 ↔ DB3                            |
| DACK3 🖛 🛛                                   | 15 |            | 26 | ] ↔ DB4                              |
| $DREQ_3 \rightarrow C$                      | 16 |            | 25 | DACK0                                |
| $DREQ_2 \rightarrow C$                      | 17 |            | 24 | DACK1                                |
| $DREQ_1 \rightarrow C$                      | 18 |            | 23 | D ↔ DB5                              |
| $DREQ_0 \rightarrow C$                      | 19 |            | 22 | ] → DB6                              |
| (GND)Vss [                                  | 20 |            | 21 | DB7 → DB7                            |
|                                             |    |            |    |                                      |

Note : PIN 5 must be connected to  $V_{CC}$  or opened.

3.2 TMP82C37AT-5 (PLCC)



050489

Note: PIN 5 must be connected to Vcc or must be opened. NC: No Connection

#### MPU85-208





## 4. PIN NAME & FUNCTION

• V<sub>CC</sub>

+5V power supply

• V<sub>SS</sub>

Ground

• CLK (Clock, Input)

This input controls the internal operation and data transfer rate of the TMP82C37A.

•  $\overline{\mathrm{CS}}$  (Chip Select, Input)

This input is low active and used to select the TMP82C37A as an I/O device during an I/O read or I/O write by the host MPU. If  $\overline{IOR}$  or  $\overline{IOW}$  is toggled following each transfer when a host MPU and the TMP82C37A are transferring data mutually,  $\overline{CS}$  may be kept at LOW.

• RESET (Reset, Input)

This input is asynchronous input to clear the command, status, request and temporary registers. In addition, this input is used to clear First/Last flip-flops and set the mask register. Following the reset, the TMP82C37A is placed in the idle cycle.

• READY (Ready, Input)

This input is used to extend the memory or I/O read and write pulses in DMA cycle in order to adapt to low speed memories or I/O peripheral devices.

• HLDA (Hold Acknowledge, Input)

By this signal, the TMP82C37A knows that the system bus control is turned over from MPU.

• DREQ<sub>0</sub>-DREQ<sub>3</sub> (DMA Request, Input)

DMA request signals are input from peripheral circuits. If priority is fixed, the highest priority is given to  $DREQ_0$  and the lowest priority to  $DREQ_3$ . Polarity of DREQ is programmable. DREQ becomes high active by RESET.

• DB<sub>0</sub>-DB<sub>7</sub> (Data Bus, Input/Output)

The Data Bus are bidirectional 3-state lines connecnted to the system data bus. During MPU is in I/O read state, output is enabled and contents of the registers (address, status, temporary and word count) are output to MPU. During MPU is in I/O write state, the data bus serves as input and it becomes possible to program the control register of the TMP82C37A.

During the DMA cycle, the most significant 8 bits of address are output on the data bus and latched by ADSTB signal externally. During the Memory-to-Memory transfer, the data of the source memory location are loaded into the temporary register of the TMP82C37A by the read operation and the contents of the temporary register are output to the destination memory location by the write operation.

• IOR (I/O Read, Input/Output)

I/O read is a bidirectional, low active and 3-state signal. During the idle cycle, this signal serves as an input control signal used by MPU to read the control registers of the TMP82C37A. During the active cycle, this signal serves as an output control signal used by the TMP82C37A to access data from the peripheral circuit during the DMA read and transfer.

• <u>IOW</u> (I/O Write, Input/Output)

I/O write is a bidirectional, low active, 3-state signal. During the idle cycle, this signal serves as an input control signal used by MPU to load the information to the TMP82C37A. During the active cycle, this signal served as an output control signal used by TMP82C37A to load the data to the peripheral. For write to the TMP82C37A by MPU, the leading edge of the write signal ( $\overline{IOW}$ ) is required for every data transfer. It is not possible to write more than two data by toggling  $\overline{CS}$  while holding the  $\overline{IOW}$  pin at low level.

• EOP (End of Process, Input/Output)

 $\overline{\text{EOP}}$  (End of Process) is a signal relative to the end of DMA service, and is a low active, bidirectional and open drain signal. When the channel word count reaches from 0000H to FFFFH, the TMP82C37A outputs low pulse of  $\overline{\text{EOP}}$  to peripheral devices as the end signal.

In addition, it is also possible to pull  $\overline{\text{EOP}}$  to the low level by peripheral device in order to cause the end of process.

When EOP is received (internally or externally), the channel which is presently active terminates the service, sets that TC bit of the status register and resets that request bit.

If that channel is programmed for auto initialization, that current register is updated from the base register. In all other cases, mask bit is set and the content of that register remains unchanged.

During the Memory-to-Memory transfer,  $\overline{EOP}$  is output when TC of channel 1 is produced.  $\overline{EOP}$  is always used for channels with active DACK and external  $\overline{EOP}$  has no connection when DACK<sub>0</sub>-DACK<sub>3</sub> are all inactive.

**EOP** is an open drain signal and therefore, requires an external pull-up resistor.

• A<sub>0</sub>-A<sub>3</sub> (Address, Input/Output)

The four least significant address lines are the bidirectional 3-state signals. In the idle cycle, these lines serve as the input signals and used by MPU for write/read of the control register. In the active cycle, they serve as the output signals and become low order 4 bits of output address.

• A<sub>4</sub>-A<sub>7</sub> (Address, Output)

The four most significant address lines are 3-state output signals. These lines are enabled for the period of DMA service only.

• HRQ (Hold Request, Output)

This is the hold request signal to MPU, and is used to request the system bus control. HRQ is output by the TMP82C37A according to a software request or unmasked DREQ.

• DACK<sub>0</sub>-DACK<sub>3</sub> (DMA Acknowledge, Output)

The DMA acknowledge lines indicate that channels are active. Normally, these are used for selecting peripheral devices. Only one DACK becomes active but it does not become active unless DMA is controlling the system bus. Polarity of these lines are programmable. After reset, they initialize low active.

• AEN (Address Enable, Output)

Address Eanble is a high active signal and used to enable output of the external latch which holds high order byte of address and to disable the system bus during the DMA cycle.

During the DMA transfer, HLDA and AEN are used to disable all I/O except programmed I/O. The TMP82C37A disables  $\overline{CS}$  input for DMA transfer to prevent itself from being selected automatically.

• ADSTB (Address Strobe, Output)

This signal is a strobe output to an external latch circuit and is used to latch high order 8-bit address from  $DB_0$ - $DB_7$ .

• <u>MEMR</u> (Memory Read, Outputd)

This is a low active 3-state output used for transferring data from a memory to a peripheral device or for data accessing from a selected memory during the Memory-to-Memory transfer.

• <u>MEMW</u> (Memory Write, Output)

This is a low active 3-state output used for transferring data from a peripheral device to a memory or for writing data into a selected memory during the Memory-to-Memory transfer.

## 5. OPERATIONAL DESCRIPTION

#### 5.1 DMA OPERARTION

The TMP82C37A has two operations; idle cycle and active cycle. Each of these cycles consists of several states.

On the TMP82C37A, it is possible to consider 7 states each of which consists of one clock cycle. State I (SI) is an idle state. This is such a state as there is no valid DMA request pending. SI is a program condition state which is programmable by MPU.

State 0 (S0) is the first DMA service state. This is a state that the TMP82C37A made a hold request to MPU but not yet received the acknowledge signal from MPU. When the acknowledge signal is received from MPU, the transfer is started.

S1, S2, S3 and S4 are the DMA service states. If more time is required by the transfer, it is possible to insert the wait state (SW) before S4 by READY input to the TMP82C37A.

In the Memory-to-Memory transfer, in order to assure complete transfer, read from the memory and write to the memory are required. 8 states are necessary for one transfer. The first four states (S11, S12, S13 and S14) are read from the memory and the latter four state (S21, S22, S23 and S24) are write to the memory.

The temporary data register is used as an intermediate storage area of memory bytes.

#### 5.2 IDLE CYCLE

When DMA service is not requested by channels, the TMP82C37A enters into the idle cycle and is placed in SI state. In order to check if the channels request DMA service, the TMP82C37A samples DREQ for every clock.

The TMP82C37A also samples  $\overline{CS}$  to check if MPU is requesting read or write of internal registers. When  $\overline{CS}$  is low and HLDA is also low, the TMP82C37A is placed in the program condition.

At this time, MPU is able to change or check the content of any internal register through read or write from that register.

Address lines  $A_0$ - $A_3$  are input signals and used for selecting a register being read or written.  $\overline{IOR}$  and  $\overline{IOW}$  are used for selecting read or write and decide read/write timing.

The internal flip-flop is used for generating address extension bits according to number and size of internal registers. (First/Last flip-flop) This bit is used for deciding high or low order byte of 16-bit address and word count register.

The flip-flop is reset by the master clear or reset. In addition, this flip-flop also can be reset by an independent software command. On a special software command, the execution in the TMP82C37A program conditon is possible. These commands are decoded as in the address setting when both  $\overline{CS}$  and  $\overline{IOW}$  are active.

The data bus is not used for this command. This command is available in three types; clear First/Last flip-flop, master clear and clear mask register.

## 5.3 ACTIVE CYCLE

When the TMP82C37A is in idel cycle and the channels are requesting DMA service, the TMP82C37A outputs HRQ to MPU and goes into the active cycle. In this cycle, the DMA service for any one of 4 modes is executed.

## 5.3.1 Single Transfer Mode:

In this mode, the TMP82C37A performs a single byte transfer during each HRQ/HLDA handshake. When DREQ becomes active, HRQ becomes active. After MPU responds by driving HLDA active, a single byte transfer will take place. After the transfer HRQ becomes inactive, its word count is decreased, and address is increased or decreased. When word count changes from 0000H to FFFFH, a terminal signal is generated and if the channels are programmed, the auto initialization is made.

To execute the single byte transfer, it is necessary to hold DREQ until DACK corresponding each DREQ becomes active. If DREQ is continuously active, HRQ becomes inactive following each transfer and then, becomes active again, and the new single byte is executed following the leading edge of HLDA.

On the 8085A system, one machine cycle can be executed during the DMA transfer.

## 5.3.2 Block Transfer Mode:

In this mode the TMP82C37A continues the transfer until terminal count (TC) is generated or an external End of Process signal ( $\overline{\text{EOP}}$ ) is encountered. Here, TC is produced when the word count changes from 0000H to FFFFH.

What is required for DREQ is to hold it in active state until DACK becomes active. Auto initialization (if so programmed) is taken place at the end of DMA service.

## 5.3.3 Demand Transfer Mode:

In this mode the TMP82C37A continues the transfer until TC is produced or  $\overline{\text{EOP}}$  is or DREQ becomes inactive. Thus, it is possible for a device, which is requesting the DMA service, to suspend the transfer by making DREQ inactive. The service is resumed when DREQ is made active again. It is possible to read an intermediate value of address and word count from the current address and current word count register of the TMP82C37A while the system bus is returned to MPU during execution of the DMA service.

The auto initialization is taken place following TC or  $\overline{\text{EOP}}$  at the end of DMA service. In order to perform a new DMA service following the auto initialization, the active edge of DREQ is necessary.

#### 5.3.4 Cascade Mode:

This mode is used when the TMP82C37A is cascade connected for a simple system expansion. HRQ and HLDA of the additional TMP82C37A are connected to DREQ and DACK of the first TMP82C37A. DMA request to the TMP82C37A which is added for the purpose of system expansion is authorized by the priority circuit of the first TMP82C37A.

If the priority is already decided, the additional device must wait till the acknowledge request. The cascade channel of the first TMP82C37A is used only for deciding priority of the additional TMP82C37A and therefore, the channel itself does not output address nor control signal. This is to prevent the added device from colliding with output of the cascade channel. On the TMP82C37A, DACK respond to DREQ. However all other outputs except HRQ are disabled.

The state of cascade connection is shown in Figure 5.1. In Figure 5.1, two levels of DMA are formed. To further expand the TMP82C37A, it is possible to add it to the second level using the TMP82C37A, it is possible to add it to the second level using the remaining channel of the first TMP82C37A. To further add another TMP82C37A, the third level can be formed by cascade connecting it to the second level.



050489

Figure 5.1 Example of Cascade Connection of TMP82C37A

#### 5.4 TRANSFER FORMAT

3 different transfer format are available for 3 active transfer modes.

They are read, write and verify. In the write transfer, data is transferred from I/O device to memory by  $\overline{\text{MEMW}}$  and  $\overline{\text{IOR}}$ . In the read transfer, data is transferred from memory to I/O device by  $\overline{\text{MEMR}}$  and  $\overline{\text{IOW}}$ .

The verify transfer is a pseudo transfer. The TMP82C37A perform such operations as address generation for read or write transfer, answer to  $\overline{\text{EOP}}$ , etc. However, memory or I/O control line does not become active.

### 5.5 MEMORY-TO-MEMORY TRANSFER:

The TMP82C37A has the ability of block movement and is capable of transferring data block from one memory address location to another location. When Bit 0 of the command register is programmed at Logic 1, Channel 0 and 1 operate as the Memory-to-Memory transfer channels. Channel 0 serves as source address and Channel 1 as a destination address, and the word count of Channel 1 is used. The Memory-to-Memory transfer is executed when software DMA request is set for Channel 0.

The Memory-to-Memory transfer must use the block transfer mode.

When Channel 0 is programmed as a fixed source address, it is possible to write single source words into a memory block.

When the TMP82C37A is programmed for the Memory-to-Memory transfer, Channel 0 and Channel 1 must be masked. The same value as that is set for Channel 1 must be set for the word count of Channel 0. During the Memory-to-Memory transfer, AEN became active but DACK does not become active.

During the Memory-to-Memory transfer, the TMP82C37A respond to external  $\overline{\text{EOP}}$  signal. In the block search, the data comparator uses this ( $\overline{\text{EOP}}$ ) input to terminate the DMA service when match is found. The Memory-to-Memory transfer timing is shown in Timing Diagram 4.

### 5.6 AUTO INITIALIZATION:

When Bit 4 of the mode register is set to 1, the channels are set up for the auto initialization. During the auto initialization, data are loaded into the current address and current word count registers from the base address and base word count registers, respectively, following EOP. The base registers are loaded by MPU simultaneously with the current registers and remain unchanged during the DMA service.

When the channels are under the auto initialization, mask bit is not set by  $\overline{\text{EOP}}$ .

Following the auto initialization, that channel is prepared to execute the service without interposition of MPU.

### 5.7 PRIORITY:

The TMP82C37A has two types of priority which can be selected by software. The first type is the fixed priority. Channel priority is fixed by channel number. The lowest priority is channel 3, followed by 2, 1, and the highest priority is channel 0.

The second type is the rotating priority. In this type, an accepted channels is then given with the lowest priority .

On the rotating priority in the singel chip DMA system, the highest priority of any one channel comes after no more than three higher priority services have occurred. This rotating priority prevent a specific channel from occupying the system all the time. (See the following below diagram.)



The priority judging circuit selects a channel with the highest priority requesting the DMA service for every active edge of HLDA. Once the channel starts the service, that operation will not be suspended even when the service is demanded by another channel with higher priority. A channel with higher priority can get the control right only after a channel with lower priority relinquished HRQ. Whenever the control is transferred from a channel to another channel, MPU gets the system bus control right. This assures the leading edge of HLDA which is used for selecting a channel with the highest priority.

#### 5.8 COMPRESSED TRANSFER TIMING:

In order to accomplish greater throughput allowed by system characteristics, the TMP82C37A is capable of compressing the transfer time to 2 clock cycles. As can be seen from Timing Diagram 3, State S3 is used to extend readout pulse access time. When State S3 is removed, readout pulse width becomes equal to write pulse width. Then, the transfer will consist of State S2 for changing address and State S4 for executing read/write. State S1 is produced when  $A_8$  to  $A_{15}$  are updated (refer to Address Generation). Compressed transfer timing is shown in Timing Diagram 5.

During Memory-to-Memory transfer, compressed transfer is not available.

#### 5.9 ADDRESS GENERATION:

To reduce number of pins, the TMP82C37A has the multiplexed address/data bus. State S1 is used to output high order address byte to the external latch. The trailing edge of ADSTB is used to load the address byte from the data line on the external latch circuit. AEN is used to enable latch outputs from 3 states. Low order address byte is ditectly output by the TMP82C37A.

 $A_0$  to  $A_7$  are connected to address bus. Timing Diagram 3 show the relationship among CLK, AEN, ADSTB, DB<sub>0</sub> to DB<sub>7</sub> and A<sub>0</sub> to A<sub>7</sub>.

Address produced during the block and demand transfers are sequential. For many transfer the same address data will be held in the external address latch. This address data changes only when carry or borrow from  $A_7$  to  $A_8$  is produced in the normal sequence. To raise system throughput, on the TMP82C37A, S1 state is executed only for updating  $A_8$  to  $A_{15}$  requiring the external latch.

## 6. DESCRIPTION OF REGISTERS

| Register Name                 | Size   | Number |
|-------------------------------|--------|--------|
| Base address register         | 16-bit | 4      |
| Base word count register      | 16-bit | 4      |
| Curren address register       | 16-bit | 4      |
| Current word count register   | 16-bit | 4      |
| Temporary address register    | 16-bit | 1      |
| Temporary word count register | 16-bit | 1      |
| Status register               | 8-bit  | 1      |
| Command register              | 8-bit  | 1      |
| Temporary register            | 8-bit  | 1      |
| Mode register                 | 6-bit  | 4      |
| Mask register                 | 4-bit  | 1      |
| Request register              | 4-bit  | 1      |
|                               |        | 050489 |

Figure 6.1 Internal Registers

## 6.1 CURRENT ADDRESS REGISTER:

Each channel has a 16-bit current address register. This register holds addresses that are used during the DMA transfer. After each transfer, this register is automatically incremented or decremented, and intermediate address values are stored in the current address register during the transfer. Write or read of this register is made by MPU. An original value is initialized again by the auto initialization.

The auto initialization is taken place only after  $\overline{\text{EOP}}$ .

## 6.2 CURRENT WORD COUNT REGISTER:

Each channel has a 16-bit current word count register. For this register, the number of words to be transferned that is one less than that to be transferred must be programmed. The word counter is decremented after each transfer. Intermediate values of word count are stored in this register during the transfer. When the register value goes from 0000H to FFFFH, TC (Terminal Count) is produced.

When this register is in the program condition, load or read is made by MPU. Following the end of DMA service, this register is initialized to original values again by the auto initialization.

The auto initialization is taken place only when  $\overline{\text{EOP}}$  is produced. Note that the content of the word count register becomes FFFFH following internally produced  $\overline{\text{EOP}}$ .

#### 6.3 BASE ADDRESS REGISTER, BASE WORD COUNT REGISTER:

Each channel has a pair of registers; the base address register and base word count register. These 16-bit registers store original values of related current registers. These registers are used to store original values of current registers at time of the auto initialization. Write to the base register is made at the same time of write into equivalent current registers during the programming by MPU. Therefore, write into the current registers which store intermediate values are made over these intermediate values. The base register cannot be read out by MPU.

#### 6.4 COMMAND REGISTER:

This 8-bit register controls the operation of TMP82C37A. This command register is programmed (clear or reset) by MPU when it is in the program condition. The figure below show the functions of command bits. For address codes, refer to Figure 6.2.



050489

## 6.5 MODE REGISTER:

All channels have a 6-bit mode register, respectively. This mode register is written by MPU when it is in the program condition, and Bit 0 and 1 select the channel to be programmed.



### 6.6 REQUEST REGISTER:

The TMP82C37A is capable of responding to DMA service request by software similar to DREQ. Each channel has a single bit request register which cannot be masked. Further, priority is given by the priority encode circuit.

Bit of each register is set or cleared by software and further, cleared by generation of TC or external  $\overline{\text{EOP}}$ . All registers are cleared by reset. In order to set or reset bit, a proper form of data word is loaded by software.

Address codes are shown in Figure 6.2. DMA service request by software is accepted only when the channels are in the block mode. In the Memory-to-Memory transfer, DMA service request only to Channel 0 by this software command becomes valid.





#### 6.7 MASK REGISTER:

For each channel, mask bit are allocated to the mask register to disable DREQ input. If the auto initialization has not been programmed for the channels, the channel corresponding to a mask bit is set when  $\overline{\text{EOP}}$  is produced. Each bit of the 4-bit mask register is also set or cleared by the software command. All bits are also set by reset. This will disable all DMA requests until the clear mask register command is enabled.

Command addressing is shown in Figure 6.2.



All four bits of the mask register can be written also by a single command.



### 6.8 STATUS REGISTER:

This register is read out by MPU through the TMP82C37A. Status information of the TMP82C37A at time of readout is included. Information as to which channel reaches the terminal count (TC) and which channel is pending the DMA request are included in this information. Bits 0 to 3 are set every time when a channel reaches TC including the auto initialization.

These bits are cleared by reset or when each status is read out. Bits 4 to 7 are always set when corresponding channels are requesting the DMA service



### 6.9 TEMPORARY REGISTER:

This register is used for holding data during the Memory-to-Memory transfer. A last word transferred following the end of transfer is read out by MPU that is in the program condition. Unless cleared by reset, this register contains the last word transferred during the preceding Memory-to-Memory transfer.

#### 6.10 SOFTWARE COMMANDS:

These commands are the special software commands which are executed in the program condition and do not depend upon the specified bit pattern on the data bus. These commands are available in following three commands:

6.10.1 Clear First/Last Flip-Flop

This command is executed prior to write or read of address information or word count information of the TMP82C37A. Furthermore, this command is used when low order or high order 8 bits of register are accessed.

#### 6.10.2 Master Clear

This software command has the same effect as the hardware reset. The command, status, request, temporary, and internal First/Last flip-flop registers are all cleared by this command, and the mask register is set.

The TMP82C37A enters into the idle cycle.

#### 6.10.3 Clear Mask Register

This command clears all mask bits of four channels, enabling acceptance of the DMA service requests. Address codes of the software command are shown in Figure 6.2.

| Signal         |                |                |                |     |     |                                 |  |  |  |  |  |
|----------------|----------------|----------------|----------------|-----|-----|---------------------------------|--|--|--|--|--|
| A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | IOR | ĪOW | Operation                       |  |  |  |  |  |
| 1              | 0              | 0              | 0              | 0   | 1   | Read of status register         |  |  |  |  |  |
| 1              | 0              | 0              | 0              | 1   | 0   | Write to command register       |  |  |  |  |  |
| 1              | 0              | 0              | 1              | 0   | 1   |                                 |  |  |  |  |  |
| 1              | 0              | 0              | 1              | 1   | 0   | Write to request register       |  |  |  |  |  |
| 1              | 0              | 1              | 0              | 0   | 1   | -                               |  |  |  |  |  |
| 1              | 0              | 1              | 0              | 1   | 0   | Bit set, reset of mask register |  |  |  |  |  |
| 1              | 0              | 1              | 1              | 1   | 0   | -                               |  |  |  |  |  |
| 1              | 0              | 1              | 1              | 1   | 0   | Write to mode register          |  |  |  |  |  |
| 1              | 1              | 0              | 0              | 0   | 1   | -                               |  |  |  |  |  |
| 1              | 1              | 0              | 0              | 1   | 0   | Clear First/Last fip-flop       |  |  |  |  |  |
| 1              | 1              | 0              | 1              | 0   | 1   | Read of temporary register      |  |  |  |  |  |
| 1              | 1              | 0              | 1              | 1   | 0   | Master clear                    |  |  |  |  |  |
| 1              | 1              | 1              | 0              | 0   | 1   | _                               |  |  |  |  |  |
| 1              | 1              | 1              | 0              | 1   | 0   | Clear mask register             |  |  |  |  |  |
| 1              | 1              | 1              | 1              | 0   | 1   | -                               |  |  |  |  |  |
| 1              | 1              | 1              | 1              | 1   | 0   | All bit write of mask register  |  |  |  |  |  |

050489

Note: The oblique lined codes denote illegal codes.

Figure 6.2 Register and Function Addressing

| Chan- | Register                                                       | Operation              |                       |                       | S                     | ligna            | (*)              | Data Bus              |                       |                       |                                                                                                                      |
|-------|----------------------------------------------------------------|------------------------|-----------------------|-----------------------|-----------------------|------------------|------------------|-----------------------|-----------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------|
| nel   |                                                                |                        | CS                    | IOR                   | IOW                   | A <sub>3</sub>   | A <sub>2</sub>   | A <sub>1</sub>        | A <sub>0</sub>        | (^)                   | DB <sub>0</sub> ~DB <sub>7</sub>                                                                                     |
| 0     | Base & Current<br>Address<br>Current Address<br>Base & Current | Write<br>Read<br>Write | 0<br>0<br>0<br>0<br>0 | 1<br>1<br>0<br>0<br>1 | 0<br>0<br>1<br>1<br>0 | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>0 | 0<br>0<br>0<br>0<br>1 | 0<br>1<br>0<br>1<br>0 | $\begin{array}{rrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrrr$                                                                 |
|       | Address<br>Current Address                                     | Read                   | 0<br>0<br>0           | 1<br>0<br>0           | 0<br>1<br>1           | 0<br>0<br>0      | 0<br>0<br>0      | 0<br>0<br>0           | 1<br>1<br>1           | 1<br>0<br>1           | $W_8 \sim W_{15}$ $W_0 \sim W_7$ $W_8 \sim W_{15}$                                                                   |
| 1     | Base & Current<br>Address                                      | Write                  | 0<br>0<br>0           | 1<br>1<br>0           | 0<br>0<br>1           | 0<br>0<br>0      | 0<br>0<br>0      | 1<br>1<br>1           | 0<br>0<br>0           | 0<br>1<br>0           | $\begin{array}{rrrr} A_0 & \sim & A_7 \\ A_8 & \sim & A_{15} \\ A_0 & \sim & A_7 \end{array}$                        |
|       | Base & Current<br>Address                                      | Write                  | 0<br>0<br>0<br>0      | 0<br>1<br>1<br>0      | 1<br>0<br>0<br>1      | 0<br>0<br>0<br>0 | 0<br>0<br>0<br>0 | 1<br>1<br>1<br>1      | 0<br>1<br>1<br>1      | 1<br>0<br>1<br>0      | $\begin{array}{rrrr} A_8 & \sim & A_{15} \\ W_0 & \sim & W_7 \\ W_8 & \sim & W_{15} \\ W_0 & \sim & W_7 \end{array}$ |
|       | Current Address                                                | кеаа                   | 0                     | 0                     | 1                     | 0                | 0                | 1                     | 1                     | 1                     | $W_8 \sim W_{15}$                                                                                                    |
| 2     | Base & Current<br>Address                                      | Write                  | 0<br>0                | 1                     | 0<br>0                | 0<br>0           | 1                | 0<br>0                | 0<br>0                | 0<br>1                | $\begin{array}{rrrr} A_0 & \sim & A_7 \\ A_8 & \sim & A_{15} \end{array}$                                            |
|       | Current Address                                                | Read                   | 0                     | 0                     | 1<br>1                | 0<br>0           | 1                | 0                     | 0                     | 0<br>1                | $\begin{array}{c} A_0 \ \sim \ A_7 \\ A_8 \ \sim \ A_{15} \end{array}$                                               |
|       | Base & Current<br>Address                                      | Write                  | 0                     | 1<br>1<br>0           | 0<br>0<br>1           | 0<br>0<br>0      | 1                | 0 0 0                 | 1 1 1 1               | 0<br>1<br>0           | $W_0 \sim W_7$ $W_8 \sim W_{15}$ $W_0 \sim W_7$                                                                      |
|       | Current Address                                                | Read                   | 0                     | 0                     | 1                     | 0                | 1                | 0                     | 1                     | 1                     | $W_8 \sim W_{15}$                                                                                                    |
| 3     | Base & Current<br>Address                                      | Write                  | 0                     | 1                     | 0<br>0                | 0<br>0           | 1                | 1                     | 0<br>0                | 0                     | $\begin{array}{rcl} A_0 & \sim & A_7 \\ A_8 & \sim & A_{15} \end{array}$                                             |
|       | Current Address                                                | Read                   | 0                     | 0<br>0                | 1                     | 0<br>0           | 1                | 1                     | 0                     | 0                     | $\begin{array}{ccc} A_0 & \sim & A_7 \\ A_8 & \sim & A_{15} \end{array}$                                             |
|       | Base & Current                                                 | Write                  | 0                     | 1                     | 0<br>0                | 0<br>0           | 1                | 1                     | 1                     | 0<br>1                | $\begin{array}{l} W_0 \ \sim \ W_7 \\ W_8 \ \sim \ W_{15} \end{array}$                                               |
|       | Current Address                                                | Read                   | 0                     | 0<br>0                | 1                     | 0<br>0           | 1                | 1                     | 1                     | 0                     | $W_0 \sim W_7$<br>$W_8 \sim W_{15}$                                                                                  |

(\*) : Internal First/Last Flip-Flop

Figure 6.3 Word Count, Address Registers


## 7. PROGRAMMING

If HLDA of MPU is inactive it is possible to program the TMP82C37A by MPU even when HRQ is active.

However, it is necessary for MPU to take care that programming of the TMP82C37A and anser of HLDA are taken place simultaneously.

It requires care when the DMA service is requested to an unmasked channel during the programming of the TMP82C37A.

It is considered that an embarrassing trouble may be caused in this case.

For instance, if MPU is going to rewrite the address register of channel 2 and in addition, the TMP82C37A is enabled and channel 2 is not masked when channel 2 received a DMA request. The DMA service will be started after one byte of the address register is written. Such a problem as exampled above can be taken place.

To avoid such problems as this, it is better to disable the controller or mask unmasked channels before reprogramming any register.

It is better to enable the controller or clear the masking when the programming is completed.

#### Example of Program Set (CH2)

| DI  |             | : | Interrupt disable                                |
|-----|-------------|---|--------------------------------------------------|
| OUT | MCLR        | : | Master clear                                     |
| MVI | A,XXXXXXXB  |   |                                                  |
| OUT | CMND        | : | Command register set-up                          |
| MVI | A,XXXXXX10B |   |                                                  |
| OUT | MODE        | : | Mode register set-up                             |
| MVI | A,37H       |   |                                                  |
| OUT | ADR2        | : | CH2 Address Reg. (low order)                     |
| MVI | A,82H       |   |                                                  |
| OUT | ADR2        | : | CH2 Address Reg. (high order)                    |
| MVI | A,17H       |   |                                                  |
| OUT | WCNT2       | : | CH2 Word count register (low order)              |
| MVI | A,95H       |   |                                                  |
| OUT | WCNT2       | : | $CH2 \ Word \ count \ register \ (high \ order)$ |
| MVI | A,0000010B  |   |                                                  |
| OUT | MSKB        | : | CH2 Mask clear (signal bit)                      |
| EI  |             | : | Interrupt enable                                 |

# 8. ELECTRIC CHARACTERISTICS

## 8.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEMS                 | TEST CONDITION | RATING                         | UNIT   |
|------------------|-----------------------|----------------|--------------------------------|--------|
| V <sub>CC</sub>  | Supply Voltage        |                | -0.5 to +7.0                   | V      |
| VIN              | Input Voltage         | With Respect   | – 0.5 to V <sub>CC</sub> + 0.5 | V      |
| V <sub>OUT</sub> | Output Voltage        |                | – 0.5 to V <sub>CC</sub> + 0.5 | V      |
| PD               | Power Dissipation     | -              | 250                            | mW     |
| T <sub>sol</sub> | Soder Temperature     | -              | 260 (10sec)                    | °C     |
| T <sub>stg</sub> | Strage Temperature    | -              | – 65 to + 150                  | °C     |
| T <sub>opr</sub> | Operating Temperature | -              | - 40 to + 85                   | °C     |
|                  |                       |                |                                | 050489 |

## 8.2 DC CHARACTERISTICS

 $Ta = -40^{\circ}C \text{ to } + 85^{\circ}C, VCC = 5V \pm 10\%, VSS (GND) = 0V$ 

| SYMBOL           | ITEMS                       | CONDTION                                                  | MIN.                  | TYP. | MAX.                  | UNIT |
|------------------|-----------------------------|-----------------------------------------------------------|-----------------------|------|-----------------------|------|
| V <sub>IL</sub>  | Input Low Voltage           |                                                           | - 0.5                 | -    | 0.8                   | V    |
| VIH              | Input High Voltage          |                                                           | 2.2                   | -    | V <sub>CC</sub> + 0.5 | V    |
| V <sub>OL</sub>  | Output Low Voltage          | I <sub>OL</sub> = 3.2mA                                   | -                     | -    | 0.45                  | V    |
| V <sub>OH1</sub> | Output High Voltage         | I <sub>OH1</sub> = -400µА                                 | 2.4                   | -    | -                     | V    |
| V <sub>OH2</sub> | Output High Voltage         | I <sub>OH2</sub> = - 100μA                                | V <sub>CC</sub> – 0.8 | -    | -                     | V    |
| Ι <sub>ΙL</sub>  | Input Leak Current          | $0V \leq V_{IN} \leq V_{CC}$                              | -                     | _    | ± 10                  | μA   |
| IOFL             | Output Leak Current         | $0.45V \le V_{OUT} \le V_{CC}$                            | -                     | -    | ± 10                  | μA   |
| I <sub>CC1</sub> | Operating Supply<br>Current | CLK = 5MHz<br>$V_{1H} = V_{CC} - 0.2V$<br>$V_{1L} = 0.2V$ | -                     | -    | 10                    | mA   |
| ICC2             | Stand-by Supply<br>Current  | $CLK = DC$ $V_{1H} = V_{CC} - 0.2V$ $V_{1L} = 0.2V$       | -                     | _    | 10                    | μА   |

050489

MPU85-227

## 8.3 AC CHARACTERISTICS

## 8.3.1 Active Cycle (Notes : 2 and 9)

## Ta = $-40^{\circ}$ C to $+85^{\circ}$ C, V<sub>CC</sub> = 5V ± 10%, V<sub>SS</sub> (GND) = 0V (1/2)

| SYMBOL             | PARAMETER                                | MIN.     | MAX.    | UNIT |    |
|--------------------|------------------------------------------|----------|---------|------|----|
| T <sub>AEL</sub>   | AEN HIGH from CLK LOW (\$1) Delay time   | -        | 200     | ns   |    |
| TAET               | AEN LOW from CLK HIGH (SI) Delay time    |          | -       | 130  | ns |
| TAFAB              | ADR Active to Float Delay from CLK HIGH  |          | -       | 90   | ns |
| TAFC               | READ or WRITE Float Delay from CLK HIGH  |          | -       | 120  | ns |
| TAFDB              | DB Active to Float Delay from CLK HIGH   |          | -       | 170  | ns |
| T <sub>AHR</sub>   | ADR from READ HIGH Hold Time             |          | TCY-100 | -    | ns |
| T <sub>AHS</sub>   | DB from ADSTB LOW Hold Time              |          | 30      | -    | ns |
| T <sub>AHW</sub>   | ADR from WRITE HIGH Hold Time            |          | TCY-50  | -    | ns |
|                    | DACK Valid from CLK LOW Delay Time       |          | -       | 170  | ns |
| TAK                | EOP HIGH from CLK HIGH Delay Time        |          | -       | 170  | ns |
|                    | EOP LOW from CLK HIGH Delay Time         |          | -       | 170  | ns |
| TASM               | ADR Stable from CLK HIGH                 |          | -       | 170  | ns |
| T <sub>ASS</sub>   | DB to ADSTB LOW Setup Time               |          | 100     | -    | ns |
| Т <sub>СН</sub>    | Clock HIGH Level Width                   |          | 68      | -    | ns |
| * T <sub>CL</sub>  | Clock LOW Level Width                    | 100      | -       | ns   |    |
| T <sub>CY</sub>    | Clock Cycle Time                         |          | 200     | -    | ns |
| TDCL               | CLK HIGH to READ or WRITE LOW Delay Time | (NOTE 3) | -       | 190  | ns |
| T <sub>DCTR</sub>  | READ HIGH from CLK HIGH (S4) Delay Time  | (NOTE 3) | -       | 190  | ns |
| T <sub>DCTW</sub>  | WRITE HIGH from CLK HIGH (S4) Delay Time | (NOTE 3) | -       | 130  | ns |
| T <sub>DQ1</sub>   | HPO Valid from CLK HIGH Dolay Time       |          | -       | 120  | ns |
| * T <sub>DQ2</sub> |                                          | (NOTE 4) | -       | 140  | ns |
| T <sub>EPS</sub>   | EOP Low from CLK LOW Setup Time          |          | 40      | -    | ns |
| T <sub>EPW</sub>   | EOP pulse width                          |          | 220     | -    | ns |
| T <sub>FAAB</sub>  | DB Float to Active Dilay from CLK HIGH   |          | -       | 170  | ns |
| T <sub>FAC</sub>   | READ or WRITE Active from CLK HIGH       |          | -       | 150  | ns |
| T <sub>FADB</sub>  | DB Float to Active Dilay from CLK HIGH   |          | -       | 200  | ns |
| T <sub>HS</sub>    | HLDA Valid to CLK HIGH Setup Time        |          | 75      | -    | ns |
| TIDH               | Input Data from MEMR HIGH Hold Time      |          | 0       | -    | ns |
| T <sub>IDS</sub>   | Input Data to MEMR HIGH Setup Time       | ·····    | 170     | -    | ns |
| TODH               | Output Data from MEMW HIGH Hold Time     |          | 10      | -    | ns |
| T <sub>ODV</sub>   | Output Data Valid to MEMW HIGH           |          | 125     | -    | ns |
| * T <sub>QS</sub>  | DREQ to CLK LOW (SI, S4) Setup Time      | , A.,    | 30      | -    | ns |
| T <sub>RH</sub>    | CLK to READY LOW Hold Time               |          | 20      | -    | ns |

050489

| $1a = -40^{\circ}C$ to $+85^{\circ}C$ , $V_{CC} = 5V \pm 10^{\circ}$ , $V_{SS}$ (GND) $= 0V$ | ' (2/2) |  |
|----------------------------------------------------------------------------------------------|---------|--|
|----------------------------------------------------------------------------------------------|---------|--|

| SYMBOL           | PARAMETER                           | MIN. | MAX. | UNIT   |
|------------------|-------------------------------------|------|------|--------|
| T <sub>RS</sub>  | READY to CLK LOW Setup Time         | 60   | -    | ns     |
| T <sub>STL</sub> | ADSTB HIGH from CLK HIGH Delay Time | -    | 130  | ns     |
| T <sub>STT</sub> | ADSTB LOW from CLK HIGH Delay Time  | -    | 90   | ns     |
|                  |                                     |      |      | 050489 |

Note 1 : TCL and TDQ2.

The following AC specification can be also guaranteed under the conditions  $: Ta = -40^\circ C$  to  $50^\circ C$ 

Vcc = 5V + 5%

Vss = 0V

Note 2 : Value with \* is different from AC specification of N-MOS part.

8.3.2 Program Condition (Idle Cycle) (Notes : 2, 8 and 9)

 $Ta = -40^{\circ}C to + 85^{\circ}C, V_{CC} = 5V \pm 10\%, V_{SS} (GND) = 0V$ 

| SYMBOL            | ITEM                                      | MIN. | MAX. | UNIT |
|-------------------|-------------------------------------------|------|------|------|
| T <sub>AR</sub>   | ADR Valid or CS LOW to READ LOW           | 50   | -    | ns   |
| T <sub>AW</sub>   | ADR Valid or WRITE HIGH Setup Time        | 130  | -    | ns   |
| T <sub>CW</sub>   | CS LOW to WRITE HIGH Setup Time           | 130  | -    | ns   |
| T <sub>DW</sub>   | Data Valid to WRITE HIGH Setup Time       | 130  | -    | ns   |
| T <sub>RA</sub>   | ADR or CS Hold from READ HIGH             | 0    | -    | ns   |
| T <sub>RDE</sub>  | Data Access from READ LOW (Note 7)        | -    | 140  | ns   |
| T <sub>RDF</sub>  | Data Bus Float Delay from READ HIGH       | 0    | 70   | ns   |
| T <sub>RSTD</sub> | Power Supply HIGH to RESET LOW Setup Time | 500  | -    | ns   |
| T <sub>RSTS</sub> | RESET to First IOWR                       | 2    | -    | ТСҮ  |
| T <sub>RSTW</sub> | RESET pulse width                         | 300  | -    | ns   |
| T <sub>RW</sub>   | READ pulse width                          | 200  | -    | ns   |
| Twa               | ADR from WRITE HIGH Hold Time             | 20   | -    | ns   |
| Twc               | CS HIGH from WRITE HIGH Hold Time         | 20   | -    | ns   |
| T <sub>WD</sub>   | Data from WRITE HIGH Hold Time            | 30   | -    | ns   |
| Twws              | WRITE pulse width                         | 160  | -    | ns   |

050489

## Capacity Ta = $25^{\circ}$ C, V<sub>CC</sub> = GND = 0V

| SYMBOL           | PARAMETER          | TEST CONDITION                | MIN. | TYP. | MAX. | UNIT |
|------------------|--------------------|-------------------------------|------|------|------|------|
| с <sub>о</sub>   | Output Capacitance |                               | -    | -    | 8    |      |
| CI               | Input Capacitance  | $f_{C} = 1.0MHz$ , Input = 0V | -    | -    | 15   | рF   |
| C <sub>I/O</sub> | I/O Capacitance    |                               | -    | -    | 20   |      |

050489

Note 1. TYP. value is that when rated voltage is applied at  $Ta = 25^{\circ}C$ .

Note 2. Test conditions; à) Unless otherwise specified, timing defining signal voltage are;

Input High level = 2.4V, Low level = 0.45V

- Output High level=2.2V, Low level=0.8V
- b) Input rising and falling times are below 20ns.
- c) Unless otherwise spesified, 1×TTL gate and 150 pF load are provided to output.
- Note 3. Normal write pulse width is TCY-100 ns. Extension write pulse width is 2TCY-100 ns. Read pulse width is 2TCY-50 ns, and compressed read pulse width is TCY-50 ns.
- Note 4. TDQ is measured at two different high levels.
  - TDQ1 = 2.2V, TDQ2 = 3.3V.
- Note 5. It is necessary to keep DREQ active until DACK is received.
- Note 6. Both low active and high active level are available for DREQ and DACK.
- Note 7. Output load of the data bus are provided with 1 ×TTL gate and 15 pf as the minimum value, and 1×TTL gate and 150 pF as the maximum value.
- Note 8. Successive read or/and write operations by the MPU to program must be timed to allow at least 400ns as recovery time between active read or write pulses.
- Note 9. Signal READ and WRITE are IOR and MEMW for the DMA operations from peripheral devices to the memory. In the DMA operations from the memory to peripheral devices, they are MEMR and IOW.
- Note 10. When N state wait is added at time of write to memory in the latter half memory-tomemory transfer, this parameter increases by N (TCY) at a time.

# 9. TIMING DIAGRAM



050489

# Timing Diagram 1 Program Condition Write Timing



Timing Diagram 2 Program Condition Read Cycle





MPU85-232



MPU85-233





# 10. EXTERNAL DIMENSION

## 10.1 40PIN DIP EXTERNAL DIMENSION

DIP40-P-600



270289

Note : Each pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoretical positions with respect to No. 1 and No. 40 leads.

10.2 40PIN SOP EXTERNAL DEMENSION

### SSOP40-P-450

```
Unit : mm
```



270289

Note: Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm. 10.3 44PIN PLCC EXTERNAL DEMENSION

1.27

15.76±0.2

## QFJ44-P-S650



270289



0.1

## 11. EXAMPLE OF APPLICATION CIRCUIT

The connecting method of the TMP82C37A and MPU is shown in Figure 11.1.

The multimode DMA controller outputs a hold request whenever valid DMA request is produced from peripheral device. When MPU answers by the hold acknowledge signal, the TMP82C37A receives the control right of the address bus, data bus, and control bus. In the first transfer, address (the least significant 8 bits of the address bits and the most significant 8 bits on the data bus) is output.

The content of the data bus is latched by the 8-bit latch (TC74HC373P) to make the address bus complete. After execution of the first transfer, that latched data is updated only when carry or borrow is produced on the least significant address byte. When one TMP82C37A is used, four DMA channels are provided.



Figure 11.1 Basic System Connection Diagram

Figure 11.2 shows the expansion method for number of DMA channels. It is possible to realize net 7 DMA channels by connecting the second TMP82C37A to one of the DMA channels of the first TMP82C37A.

Two DMA chips commonly use the same 8-bit latch. Thus, any channel is used for expansion.



MPU85-239

# MULTIMODE DMA CONTROLLER TMP8237AP-5

## 1. GENERAL DESCRIPTION

The TMP8237AP-5 (hereinafter referred to as TMP8237A) is a multimode direct memory access (DMA) controller. The TMP8237A improves the system function by directly transferring information between the system memory and external devices. Memory-to-Memory data transfer capability is also provided.

The TMP8237A is provided with versatile programmable control functions in order to improve data throughput.

The TMP8237A is used with an 8-bit address register connected externally.

The TMP8237A has four built-in independent channels and it is possible to expand channels through cascade connection.

There are three basic data transfer modes which are programmable by the user. Each channel is programmable individually and autoinitialization is possible by End of Process  $(\overline{\text{EOP}})$  signal.

Each channel has the maximum 64K capability for both address and word count.  $\overline{\text{EOP}}$  signal is capable of terminating data transfer between DMA and memories.  $\overline{\text{EOP}}$  signal is useful for block search or verify or for terminating erroneous service.

## 2. FEATURES

- Four independent DMA channels
- Three transfer modes; block, demand, and single transfer modes
- Independent auto initialize function provided to each of all channels
- Memory-to-Memory transfer
- Address increment or decrement
- All DMA request disabled by disabling the master system
- Individual DMA request enable/disable control
- Unrestricted channel expansion by cascade connection
- End of Process (EOP) input for terminating transfer
- Software DMA Request
- Polarity control provided for DREQ signal and DACK signal
- Option for increasing transfer speed up to 2.5M word/sec
- Single +5V power supply

#### MPU85-240

# 3. PIN CONNECTIONS (TOP VIEW)

|                        |    |    | 1                             |
|------------------------|----|----|-------------------------------|
| ior 🔸                  | 1  | 40 | ] → A7                        |
| IOW 🔸                  | 2  | 39 | $\square \longrightarrow A_6$ |
| MEMR 🔶                 | 3  | 38 | D → A5                        |
| MEMW 🔶 [               | 4  | 37 | ] → A4                        |
| (note) 🔶 🛽             | 5  | 36 | ] ↔ EOP                       |
| READY [                | 6  | 35 | ] ↔ A3                        |
| HLDA [                 | 7  | 34 | ] ↔ A2                        |
| ADSTB 🖛 🛛              | 8  | 33 | ]                             |
| AEN 🛶 🛛                | 9  | 32 | þ → A0                        |
| HRQ 🔶 🗌                | 10 | 31 | V <sub>CC</sub> ( + 5V)       |
| <u>⊂s</u> → [          | 11 | 30 | DB₀                           |
| CLK 🔶 [                | 12 | 29 | $D \leftrightarrow DB_1$      |
| RESET 🔶 🛛              | 13 | 28 | $\Rightarrow DB_2$            |
| DACK2 🖛 🛛              | 14 | 27 | DB₃ ↔ DB3                     |
| DACK3 🖛 🛛              | 15 | 26 | ] ↔ DB4                       |
| $DREQ_3 \rightarrow C$ | 16 | 25 | D→ DACK0                      |
| $DREQ_2 \rightarrow C$ | 17 | 24 | DACK1                         |
| $DREQ_1 \rightarrow C$ | 18 | 23 | DB₅                           |
| $DREQ_0 \rightarrow C$ | 19 | 22 | $\Rightarrow DB_6$            |
| (GND)V <sub>SS</sub> [ | 20 | 21 | ] ↔ DB7                       |

Note: PIN 5 must be connected to VCC or opened

Figure 3.1 Pin Connections

050489

A0~A3 INCDREMENTER DECREMENTER I/OBUFFER DECREMENTER **TEMPORARY ADDRESS TEMPORARY COUNT** EOP ----**REGISTER (16) REGISTER (16)** RESET - $\overline{CS} \longrightarrow$ A4~A7 N OUTPUT READY ----TIMING BUFFER CLK -**READ/WRITE BUFFER READ BUFFER** CONTROL AEN 🔫 CURRENT BASE BASE CURRENT ADSTB 🔫 WORD WORD ADDRESS ADDRESS COUNT COUNT ~ A15 MEMR -(16)(16) (16) (16) MEMW -COMMAND A8 IOR ++ CONTROL IOW ->c READ WRITE BUFFER BUFFER DB<sub>0</sub>~DB<sub>1</sub> DB0~DB7 COMMAND I/OBUFFER  $DREQ_0 \sim DREQ_3 \xrightarrow{4} \rightarrow$ INTERNAL DATA BUS PRIORITY (8) ENCODER HLDA -MASK HRQ 🔫 ROTATING (4) READ/ PRIORITY DACK0~DACK3 4 WRITE LOGIC STATUS TEMPORARY MODE REQUEST (8) (8)  $(4 \times 6)$ 050489 (4)

Figure 3.2

Block Diagram of TMP8237A

TOSHIBA

TMP8237A

## 4. PIN NAME & FUNCTION

• VCC

+5V power supply

• VSS

Ground

• CLK (Clock, Input)

This input controls the internal operation and data transfer rate of the TMP8237A.

•  $\overline{\text{CS}}$  (Chip Select, Input)

This input is low active and used to select the TMP8237A as an I/O device during an I/O read or I/O write by the host MPU. If  $\overline{\text{IOR}}$  or  $\overline{\text{IOW}}$  is toggled following each transfer when a host MPU and the TMP8237A are transferring data mutually,  $\overline{\text{CS}}$  may be kept at low.

• RESET (Reset, Input)

This input is asynchronous input to clear the command, status, request and temporary registers. In addition, this input is used to clear First/Last flip-flops and set the mask register. Following the reset, the TMP8237A is placed in the idle cycle.

• READY (Ready, Input)

This input is used to extend the memory or I/O read and write pulses in DMA cycle in order to adapt to low speed memories or I/O peripheral devices.

HLDA (Hold Acknowledge, Input)

By this signal, the TMP8237A knows that the system bus control is turned over from MPU.

• DREQ<sub>0</sub>-DREQ<sub>3</sub> (DMA Request, Input)

DMA request signals are input from peripheral circuits. If priority is fixed, the highest priority is given to  $DREQ_0$  and the lowest priority to  $DREQ_3$ . Polarity of DREQ is programmable. DREQ becomes high active by RESET.

• DB<sub>0</sub>-DB<sub>7</sub> (Data Bus, Input/Output)

The data bus are bidirectional 3-state lines connected to the system data bus. During MPU is in I/O read state, output is enabled and contents of the registers (address, status, temporary and word count) are output to MPU. During MPU is in I/O read state, the data bus serves as input and it becomes possible to program the control register of the TMP8237A.

During the DMA cycle, the most significant 8 bits of address are output on the data bus and latched by ADSTB signal externally. During the Memory-to-Memory transfer, the data of the source memory location are loaded into the temporary register of the TMP8237A by the read operation and the contents of the temporary register are output to the destination memory location by the write operation.

• IOR (I/O Read, Input/Output)

I/O read is a bidirectional, low active and 3-state signal. During the idle cycle, this signal serves as an input control signal used by MPU to read the control registers of the TMP8237A. During the active cycle, this signal serves as an output control signal used by the TMP8237A to access data from the peripheral circuit during the DMA read and transfer.

• IOW (I/O Write, Input/Output)

I/O write is a bidirectional, low active, 3-state signal. During the idle cycle, this signal serves as an input control signal used by MPU to load the information to the TMP8237A. During the active cycle, this signal served as an output control signal used by TMP8237A to load the data to the peripheral. For write to the TMP8237A by MPU, the leading edge of the write signal ( $\overline{IOW}$ ) is required for every data transfer. It is not possible to write more than two data by toggling  $\overline{CS}$  while holding the  $\overline{IOW}$  pin at low level.

#### • EOP (End of Process, Input/Ouptut)

 $\overline{\text{EOP}}$  (End of Process) is a signal relative to the end of DMA service, and is a low active, bidirectional and open drain signal. When the channel word count reaches from 0000H to FFFFH, the TMP8237A output low pulse of  $\overline{\text{EOP}}$  to peripheral devices as the end signal.

In addition, it is also possible to pull  $\overline{\text{EOP}}$  to the low level by peripheral device in order to cause the end of process.

When  $\overline{\text{EOP}}$  is received (internally or externally), the channel which is presently active terminates the service, sets that TC bit of the status register and resets that request bit.

If that channel is programmed for auto initialization, that current register is updated from the base register. In all other cases, mask bit is set and the content of that register remains unchanged. During the Memory-to-Memory transfer,  $\overline{\text{EOP}}$  is output when TC of channel 1 is produced.  $\overline{\text{EOP}}$  is always used for channels with active DACK and external  $\overline{\text{EOP}}$  has no connection when DACK<sub>0</sub>-DACK<sub>3</sub> are all inactive.

 $\overline{\text{EOP}}$  is an open drain signal and therefore, requires an external pull-up resistor.

• A<sub>0</sub>-A<sub>3</sub> (Address, Input/Output)

The four least significant address lines are the bidirectional 3-state signals. In the idle cycle, these lines serve as the input signals and used by MPU for write/read of the control register. In the active cycle, they serve as the output signals and become low order 4 bits of output address.

• A<sub>4</sub>-A<sub>7</sub> (Address, Output)

The four most significant address lines are 3-state output signals. These lines are enabled for the period of DMA service only.

• HRQ (Hold Request, Output)

This is the hold request signal to MPU, and is used to request the system bus control. HRQ is output by the TMP8237A according to a software request or unmasked DREQ.

• DACK<sub>0</sub>-DACK<sub>3</sub> (DMA Acknowledge, Output)

The DMA acknowledge lines indicate that channels are active. Normally, these are used for selecting peripheral devices.

Only one DACK becomes active but it does not become active unless DMA is controlling the system bus. Polarity of these lines are programmable. After reset, they initialize low active.

• AEN (Address Enable, Output)

Address Enable is a high active signal and used to enable output of the external latch which holds high order byte of address and to disable the system bus during the DMA cycle.

During the DMA transfer, HLDA and AEN are used to disable all I/O except programmed I/O. The TMP8237A disables  $\overline{\text{CS}}$  input for DMA transfer to prevent itself from being selected automatically.

• ADSTB (Address Strobe, Output)

This signal is a strobe output to an external latch circuit and is used to latch high order 8-bit address from  $DB_0$ - $DB_7$ .

• <u>MEMR</u> (Memory Read, Output)

This is a low active 3-state output used for transferring data from a memory to á peripheral device or for data accessing from a selected memory during the Memory-to-Memory transfer.

• <u>MEMW</u> (Memory Write, Output)

This is a low active 3-state output used for transferring data from a peripheral device to a memory or for writing data into a selected memory during the Memory-to-Memory transfer.

## 5. OPERATIONAL DESCRIPTION

### 5.1 DMA OPERATION

The TMP8237A has two operations; idle cycle and active cycle. Each of these cycles consists of several states.

On the TMP8237A, it is possible to consider 7 states each of which consists of one clock cycle. State I (SI) is an idle state. This is such a state as there is no valid DMA request pending. SI is a program condition state which is programmable by MPU.

State 0 (S0) is the first DMA service state. This is a state that the TMP8237A made a hold request to MPU but not yet received the acknowledge signal from MPU. When the acknowledge signal is received from MPU, the transfer is started.

S1, S2, S3 and S4 are the DMA service states. If more time is required by the transfer, it is possible to insert the wait state (SW) before S4 by READY input to the TMP8237A.

In the Memory-to-Memory transfer, in order to assure complete transfer, read from the memory and write to the memory are required. 8 states are necessary for one transfer. The first four status (S11, S12, S13 and S14) are read from the memory and the latter four state (S21, S22, S23 and S24) are write to the memory.

The temporary data register is used as an intermediate storage area of memory bytes.

## 5.2 IDLE CYCLE

When DMA service is not requested by channels, the TMP8237A enters into the idle cycle and is placed in SI state. In order to check if the channels request DMA service, the TMP8237A samples DREQ for every clock.

The TMP8237A also samples  $\overline{CS}$  to check if MPU is requesting read or write of internal registers. When  $\overline{CS}$  is low and HLDA is also low, the TMP8237A is placed in the program condition.

At this time, MPU is able to change or check the content of any internal register through read or write from that register.

Address lines  $A_0$ - $A_3$  are input signals and used for selecting a register being read or written.  $\overline{IOR}$  and  $\overline{IOW}$  are used for selecting read or write and decide read/write timing.

The internal flip-flop is used for generating address extension bits according to number and size of internal registers. (First/Last flip-flop) This bit is used for deciding high or low order byte of 16-bit address and word count register.

The flip-flop is reset by the master clear or reset. In addition, this flip-flop also can be reset by an idependent software command.

On a special software command, the execution in the TMP8237A program condition is possible. These commands are decoded as in the address setting when both  $\overline{\text{CS}}$  and  $\overline{\text{IOW}}$  are active.

The data bus is not used for this command. This command is available in three types; clear First/Last flip-flop , master clear and clear mask register.

### 5.3 ACTIVE CYCLE

When the TMP8237A is in the idle cycle and the channels are requesting DMA service, the TMP8237A outputs HRQ to MPU and goes into the active cycle. In this cycle, the DMA service for any one of 4 modes is executed.

### 5.3.1 Single Transfer Mode:

In this mode, the TMP8237A performs a single byte transfer during each HRQ/HLDA handshake. When DREQ becomes active, HRQ becomes active.

After MPU responds by driving HLDA active, a single byte transfer will take place. After the transfer HRQ becomes inactive, its word count is decreased, and address is increased or decreased. When word count changes from 0000H to FFFFH, a terminal signal is generated and if the channels are programmed, the auto initialization is made.

To execute the single byte transfer, it is necessary to hold DREQ until DACK corresponding each DREQ becomes active. If DREQ is continuously active, HRQ becomes inactive following each transfer and then, becomes active again, and the new single byte is executed following the leading edge of HLDA.

On the 8085A system, one machine cycle can be executed during the DMA transfer.

### 5.3.2 Block Transfer Mode:

In this mode the TMP8237A continues the transfer until terminal count (TC) is generated or an external End of Process signal ( $\overline{\text{EOP}}$ ) is encountered. Here, TC is produced when the word count changes from 0000H to FFFFH.

What is requied for DREQ is to hold it in active state until DACK becomes active. Auto initialization (if so programmed) is taken place at the end of DMA service.

#### 5.3.3 Demand Transfer Mode:

In this mode the TMP8237A continues the transfer until TC is produced or  $\overline{EOP}$  is or DREQ becomes inactive. Thus, it is possible for a device, which is requesting the DMA service, to suspend the transfer by making DREQ inactive. The service is resumed when DREQ is made active again. It is possible to read an intermediate value of address and word count from the current address and current word count register of the TMP8237A while the system bus is returned to MPU during execution of the DMA service.

The auto initialization is taken place following TC or  $\overline{\text{EOP}}$  at the end of DMA service. In order to perform a new DMA service following the auto initialization, the active edge of DREQ is necessary.

050489

## 5.3.4 Cascade Mode:

This mode is used when the TMP8237A is cascade connected for a simple system expansion. HRQ and HLDA of the additional TMP8237A are connected to DREQ and DACK of the first TMP8237A. DMA request to the TMP8237A which is added for the purpose of system expansion is authorized by the priority circuit of the first TMP8237A.

If the priority is already decided, the additional device must wait till the acknowledge request. The cascade channel of the first TMP8237A is used only for deciding priority of the additional TMP8237A and therefore, the channel itself does not output address nor control signal. This is to prevent the added device from colliding with output of the cascade channel. On the TMP8237A, DACK respond to DREQ.

However all other outputs except HRQ are disabled.

The state of cascade connection is shown in Figure 5.1. In Figure 5.1, two levels of DMA are formed. To further expand the TMP8237A, it is possible to add it to the second level using the remaining channel of the first TMP8237A. To further add another TMP8237A, the third level can be formed by cascade connecting it to the second level.



Figure 5.1 Example of Cascade Connection of TMP8237A

## 5.4 TRANSFER FORMAT

3 different transfer format are available for 3 active transfer modes.

They are read, write and verify. In the write transfer, data is transferred from I/O device to memory by  $\overline{\text{MEMW}}$  and  $\overline{\text{IOR}}$ . In the read transfer, data is transferred from memory to I/O device by  $\overline{\text{MEMR}}$  and  $\overline{\text{IOW}}$ .

The verify transfer is a pseudo transfer. The TMP82C37A perform such operations as address generation for read or write transfer, answer to  $\overline{\text{EOP}}$ , etc. However, memory or I/O control line does not become active.

#### 5.5 MEMORY-TO-MEMORY TRANSFER:

The TMP8237A has the ability of block movement and is capable of transferring data block from one memory address location to another location. When Bit 0 of the command register is programmed at Logic 1, Channel 0 and 1 operate as the Memory-to-Memory transfer channels.

Channel 0 serves as a source address and Channel 1 as a destination address, and the word count of Channel 1 is used. The Memory-to-Memory transfer is executed when software DMA request is set for Channel 0.

The Memory-to-Memory transfer must use the block transfer mode.

When Channel 0 is programmed as a fixed source address, it is possible to write single source words into a memory block.

When the TMP8237A is programmed for the Memory-to-Memory transfer, Channel 0 and Channel 1 must be masked. The same value as that is set for Channel 1 must be set for the word count of Channel 0. During the Memory-to-Memory transfer, AEN became active but DACK does not become active.

During the Memory-to-Memory trnasfer, the TMP8237A respond to external  $\overline{\text{EOP}}$  signal. In the block search, the data comparator uses this ( $\overline{\text{EOP}}$ ) input to terminate the DMA service when match is found. The Memory-to-Memory transfer timing is shown in Timing Diagram 4.

#### 5.6 AUTO INITIALIZATION:

When Bit 4 of the mode register is set to 1, the channels are set up for the auto initialization. During the auto initialization, data are loaded into the current address and current word count registers from the base address and base word count registers, respectively, following  $\overline{\text{EOP}}$ . The base registers are loaded by MPU simultaneously with the current registers and remain unchanged during the DMA service.

When the channels are under the auto initialization, mask bit is not set by  $\overline{\text{EOP}}$ .

Following the auto initialization, that channel is prepared to execute the service without interposition of MPU.

#### 5.7 PRIORITY:

The TMP8237A has two types of priority which can be selected by software. The first type is the fixed priority. Channel priority is fixed by channel number. The lowest priority is channel 3, followed by 2, 1, and the highest priority is channel 0.

The second type is the rotating priority. In this type, an accepted channels is then given with the lowest priority.

On the rotating priority in the single chip DMA system, the highest priority of any one channel comes after no more than three higher priority services have occurred. This rotating priority prevent a specific channel from occupying the system all the time.(See the following next page diagram.)



The priority judging circuit selects a channel with the highest priority requesting the DMA service for every active edge of HLDA

Once the channel starts the service, that operation will not be suspended even when the service is demanded by another channel with higher priority. A channel with higher priority can get the control right only after a channel with lower priority relinquished HRQ.

Whenever the control is transferred from a channel to another channel, MPU gets the system bus control right. This assures the leading edge of HLDA which is used for selecting a channel with the highest priority.

#### 5.8 COMPRESSED TRANSFER TIMING:

In order to accomplish greater throughout allowed by system characteristics, the TMP8237A is capable of compressing the transfer time to 2 clock cycles. As can be seen from Timing Diagram 3, State S3 is used to extend readout pulse access time. When State S3 is removed, readout pulse width becomes equal to write pulse width. Then, the transfer will consist of State S2 for changing address and State S4 for executing read/write. State S1 is produced when  $A_8$  to  $A_{15}$  are updated (refer to Address Generation). Compressed transfer timing is shown in Timing Diagram 5.

During Memory-to Memory transfer, compressed transfer is not available.

#### 5.9 ADDRESS GENERATION:

To reduce number of pins, the TMP8237A has the multiplexed address/data bus. State S1 is used to output high order address byte to the external latch. The trailing edge of ADSTB is used to load the address byte from the data line on the external latch circuit.

AEN is used to enable latch outputs from 3 states. Low order address byte is directly output by the TMP8237A.

 $A_0$  to  $A_7$  are connected to address bus. Timing Diagram 3 show the relationship among CLK, AEN, ADSTB, DB<sub>0</sub> to DB<sub>7</sub> and A<sub>0</sub> to A<sub>7</sub>.

Addresses produced during the block and demand transfers are sequential. For many transfer the same address data will be held in the external address latch. This address data changes only when carry or borrow from  $A_7$  to  $A_8$  is produced in the normal sequence. To raise system through put, on the TMP8237A, S1 state is executed only for updating  $A_8$  to  $A_{15}$  requiring the external latch.

## 6. DESCRIPTION OF REGISTERS

| Register Name                 | Size   | Number |
|-------------------------------|--------|--------|
| Base address register         | 16-bit | 4      |
| Base word count register      | 16-bit | 4      |
| Count address register        | 16-bit | 4      |
| Current word count register   | 16-bit | 4      |
| Temporary address register    | 16-bit | 1      |
| Temporary word count register | 16-bit | 1      |
| Status register               | 8-bit  | 1      |
| Command register              | 8-bit  | 1      |
| Temporary register            | 8-bit  | 1      |
| Mode register                 | 6-bit  | 4      |
| Mask register                 | 4-bit  | 1      |
| Request register              | 4-bit  | 1      |
|                               |        | 050489 |

Figure 6.1 Internal Registers

## 6.1 CURRENT ADDRESS REGISTER:

Each channel has a 16-bit current address register. This register holds address that are used during the DMA trnasfer. After each transfer, this register is automatically incremented or decremented, and intermediate address values are stored in the current address register during the transfer. Write or read of this register is made by MPU. An original value is initialized again by the auto initialization.

The auto initialization is taken place only after  $\overline{\text{EOP}}$ .

## 6.2 CURRENT WORD COUNT REGISTER:

Each channel has a 16-bit current word count register. For this register, the number of words to be transferred that is one less than that to be transferred must be programmed. The word counter is decremented after each transfer. Intermediate values of word count are stored in this register during the transfer. When the register value goes from 0000H to FFFFH, TC (Terminal Count) is produced.

When this register is in the program condition, load or read is made by MPU. Following the end of DMA service, this register is initialized to original values again by the auto initialization.

The auto initialization is taken place only when  $\overline{\text{EOP}}$  is produced.

Note that the content of the word count register becomes FFFFH following internally produced EOP.

### 6.3 BASE ADDRESS REGISTER, BASE WORD COUNT REGISTER:

Each channel has a pair of registers; the base address register and base word count register. These 16-bit registers store original values of related current registers. These registers are used to store original values of current registers at time of the auto initialization. Write to the base register is made at the same time of write into equivalent current registers during the programming by MPU.

Therefore, write into the current registers which store intermediate values are made over these intermediate values. The base register cannot be read out by MPU.

#### 6.4 COMMAND REGISTER:

This 8-bit register controls the operation of TMP8237A. This command register is programmed (clear or reset) by MPU when it is in the program condition. The figure presented below show the functions of command bits. For address codes, refer to Figure 6.2.



### 6.5 MODE REGISTER:

All channels have a 6-bit mode register, respectively. This mode register is written by MPU when it is in the program condition, and Bit 0 and 1 select the channel to be programmed is to be written.



### 6.6 REQUEST REGISTER:

The TMP8237A is capable of responding to DMA service request by software similar to DREQ. Each channel has a single bit request register which cannot be masked. Further, priority is given by the priority encode circuit.

Bit of each register is set or cleared by software and further, cleared by generation of TC or external  $\overline{\text{EOP}}$ . All registers are cleared by reset. In order to set or reset bit, a proper form of data word is loaded by software.

Address codes are shown in Figure 6.2. DMA service request by software is accepted only when the channels are in the block mode. In the Memory-to-Memory transfer, DMA service request to only channel 0 by this software command becomes valid.



### 6.7 MASK REGISTER:

For each channel, mask bit are allocated to the mask register to disable DREQ input. If the auto initialization has not been programmed for the channels, the channel corresponding to a mask bit is set when  $\overline{\text{EOP}}$  is produced. Each bit of the 4-bit mask register is also set or cleared by the software command. All bits are also set by reset. This will disable all DMA requests until the clear mask register command is enabled. Command addressing is shown in Figure 6.2.



All four bits of the mask register can be written also by a single command.



## 6.8 STATUS REGISTER

This register is read out by MPU through the TMP8237A. Status information of the TMP8237A at time of readout is included.

Information as to which channel reaches the terminal count (TC) and which channel is pending the DMA request are included in this information. Bits 0 to 3 are set every time when a channel reaches TC including the auto initialization.

These bits are cleared by reset or when each status is read out.

Bits 4 to 7 are always set when corresponding channels are requesting the DMA service



050489

#### 6.9 TEMPORARY REGISTER:

This register is used for holding data during the Memory-to-Memory transfer. A last word transferred following the end of transfer is read out by MPU that is in the program condition. Unless cleared by reset, this register contains the last word transferred during the preceding Memory-to-Memory transfer.

## 6.10 SOFTWARE COMMANDS:

These commands are special software commands which are executed in the program condition and do not depend upon the specified bit pattern on the data bus. These commands are available in following third commands:

## 6.10.1 Clear First/Last flip-flop

This command is executed prior to write or read of address information or word count information of the TMP8237A. Furthermore, this command is used when low order or high order 8 bits of register are accessed.

## 6.10.2 Master Clear

This software command has the same effect as the hardware reset. The command, status, request, temporary, and internal First/Last flip-flop registers are all cleared by this command, and the mask register is set.

The TMP8237A enters into the idle cycle.

6.10.3 Clear Mask Register

This command clears all mask bits of four channels, enabling acceptance of the DMA service requests.

|                |                | Sig            | nal            |     |     | Operation                       |
|----------------|----------------|----------------|----------------|-----|-----|---------------------------------|
| A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | IOR | ĪOW | Operation                       |
| 1              | 0              | 0              | 0              | 0   | 1   | Read of status register         |
| 1              | 0              | 0              | 0              | 1   | 0   | Write to command register       |
| 1              | 0              | 0              | 1              | 0   | 1   | _                               |
| 1              | 0              | 0              | 1              | 1   | 0   | Write to request register       |
| 1              | 0              | 1              | 0              | 0   | 1   |                                 |
| 1              | 0              | 1              | 0              | 1   | 0   | Bit set, reset of mask register |
| 1              | 0              | 1              | 1              | 0   | 1   | . –                             |
| 1              | 0              | 1              | 1              | 1   | 0   | Write to mode register          |
| 1              | 1              | 0              | 0              | 0   | 1   | -                               |
| 1              | 1              | 0              | 0              | 1   | 0   | Clear First/Last flip-flop      |
| 1              | 1              | 0              | 1              | 0   | 1   | Read of temporary register      |
| 1              | 1              | 0              | 1              | 1   | 0   | Master clear                    |
| 1              | 1              | 1              | 0              | 0   | 1   | _                               |
| 1              | 1              | 1              | 0              | 1   | 0   | Clear mask register             |
| 1              | 1              | 1              | 1              | 0   | 1   | -                               |
| 1              | 1              | 1              | 1              | 1   | 0   | All bit write of mask register  |

Address codes of the software commands are shown in Figure 6.2.

Note: The oblique lined codes denote illegal codes.

Figure 6.2 Register and Function Addressing

050489

| Chan- | Pagistar                   | Operation |                |     | 9      | Signa          | Inter-<br>nal  | Data Bus       |                |            |                                                                          |
|-------|----------------------------|-----------|----------------|-----|--------|----------------|----------------|----------------|----------------|------------|--------------------------------------------------------------------------|
| nel   | Register                   | Operation | <del>C</del> S | IOR | IOW    | A <sub>3</sub> | A <sub>2</sub> | A <sub>1</sub> | A <sub>0</sub> | F/L<br>F/F | DB <sub>0</sub> ∼DB <sub>7</sub>                                         |
|       | Base & Current<br>Address  | Write     | 0<br>0         | 1   | 0<br>0 | 0<br>0         | 0<br>0         | 0<br>0         | 0<br>0         | 0<br>1     | $\begin{array}{rcl} A_0 & \sim & A_7 \\ A_8 & \sim & A_{15} \end{array}$ |
|       | Current Address            | Read      | 0              | 0   | 1      | 0              | 0              | 0              | 0              | 0          | $A_0 \sim A_7$                                                           |
| 0     | Base & Current             | Write     | 0              | 1   | 0      | 0              | 0              | 0              | 1              | 0          | $M_8 \sim M_{15}$<br>$W_0 \sim W_7$                                      |
|       | Address                    |           | 0              | 1   | 0      | 0              | 0              | 0              | 1              | 1          | $W_8 \sim W_{15}$                                                        |
|       | Current Address            | Read      | 0              | 0   | 1      | 0              | 0              | 0              | 1              | 0          | $W_0 \sim W_7$                                                           |
|       | Pace & Current             | ) M/rito  | 0              | 1   | 0      | 0              | 0              |                |                | ,          | 0 0-                                                                     |
|       | Address                    | vvrite    | 0              | 1   | 0      | 0              | 0              | 1              | 0              | 1          | $A_0 \sim A_7$<br>$A_8 \sim A_{15}$                                      |
|       | Current Address            | Read      | 0              | 0   | 1      | 0              | 0              | 1              | 0              | 0          | $A_0 \sim A_7$                                                           |
| 1     |                            |           | 0              | 0   | 1      | 0              | 0              | 1              | 0              | 1          | $A_8 \sim A_{15}$                                                        |
|       | Base & Current             | Write     | 0              | 1   | 0      | 0              | 0              | 1              | 1              | 0          | $W_0 \sim W_7$                                                           |
| [     | Address                    | Pood      | 0              | 1   | 0      | 0              | 0              | 1              | 1              | 1          | $W_8 \sim W_{15}$                                                        |
|       | Current Address            | Redu      | 0              | 0   | 1      | 0              | 0              | 1              | 1              | 1          | $W_0 \sim W_7$<br>$W_8 \sim W_{15}$                                      |
|       | Base & Current             | Write     | 0              | 1   | 0      | 0              | 1              | 0              | 0              | 0          | A <sub>0</sub> ~ A <sub>7</sub>                                          |
|       | Address                    |           | 0              | 1   | 0      | 0              | 1              | 0              | 0              | 1          | $A_8 \sim A_{15}$                                                        |
|       | Current Address            | Read      | 0              | 0   | 1      | 0              | 1              | 0              | 0              | 0          | $A_0 \sim A_7$                                                           |
| 2     |                            |           | 0              | 0   | 1      | 0              | 1              | 0              | 0              | 1          | $A_8 \sim A_{15}$                                                        |
|       | Base & Current             | Write     | 0              |     | 0      | 0              | 1              | 0              | 1              | 0          | $W_0 \sim W_7$                                                           |
|       | Address<br>Current Address | Read      | 0              |     | 1      | 0              | 1              | 0              | 1              | 0          | $W_8 \sim W_{15}$                                                        |
|       | current Address            | neud      | 0              | 0   | 1      | 0              | 1              | 0              | 1              | 1          | $W_8 \sim W_{15}$                                                        |
|       | Base & Current             | Write     | 0              | 1   | 0      | 0              | 1              | 1              | 0              | 0          | A <sub>0</sub> ~ A <sub>7</sub>                                          |
|       | Address                    |           | 0              | 1   | 0      | 0              | 1              | 1              | 0              | 1          | $A_8 \sim A_{15}$                                                        |
| 1     | Current Address            | Read      | 0              | 0   | 1      | 0              | 1              | 1              | 0              | 0          | $A_0 \sim A_7$                                                           |
| 3     |                            |           | 0              | 0   | 1      | 0              | 1              | 1              | 0              | 1          | $A_8 \sim A_{15}$                                                        |
|       | Base & Current             | vvrite    | 0              |     | 0      | 0              | 1              |                |                | 1          | $vv_0 \sim vv_7$                                                         |
|       | Current Address            | Read      | 0              | 0   | 1      | 0              | 1              | 1              | 1              | 0          | $W_0 \sim W_7$                                                           |
|       |                            |           | 0              | 0   | 1      | 0              | 1              | 1              | 1              | 1          | $W_8 \sim W_{15}$                                                        |

Figure 6.3 Word Count, Address Registers

050489

## 7. PROGRAMMING

If HLDA of MPU is inactive it is possible to program the TMP8237A by MPU even when HRQ is active.

However, it is necessary for MPU to take care that programming of the TMP8237A and answer of HLDA are taken place simultaneously.

It requires care when the DMA service is requested to an unmasked channel during the programming of the TMP8237A.

It is considered that an embarrassing trouble may be caused in this case.

For instance, if MPU is going to rewrite the address register of channel 2 and in addition, the TMP8237A is enabled and channel 2 is not masked when channel 2 received a DMA request. The DMA service will be started after one byte of the address register is written. Such a problem as exampled above can be taken place.

To avoid such problems as this, it is better to disable the controller or mask unmasked channels before reprogramming any register.

It is better to enable the controller or clear the masking when the programming is completed.

#### Example of Program Set (CH2)

| DI  |              | : | Interrupt disable                    |
|-----|--------------|---|--------------------------------------|
| OUT | MCLR         | : | Master clear                         |
| MVI | A, XXXXXXXB  |   |                                      |
| OUT | CMND         | : | Command register set-up              |
| MVI | A, XXXXXX10B |   |                                      |
| OUT | MODE         | : | Mode register set-up                 |
| MVI | А, 37Н       |   |                                      |
| OUT | ADR2         | : | CH2 Address Reg. (low order)         |
| MVI | A, 82H       |   |                                      |
| OUT | ADR2         | : | CH2 Address Reg. (high order)        |
| MVI | A, 17H       |   |                                      |
| OUT | WCNT2        | : | CH2 Word count register (low order)  |
| MVI | А, 95Н       |   |                                      |
| OUT | WCNT2        | : | CH2 Word count register (high order) |
| MVI | A, 00000010B |   |                                      |
| OUT | MSKB2        | : | CH2 Mask clear (single bit)          |
| EI  |              | : | Interrupt enable                     |

# 8. ELECTRIC CHARACTERISTICS

## 8.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | PARAMETER             | TEST CONDITIONS         | EST CONDITIONS RATING |    |  |
|------------------|-----------------------|-------------------------|-----------------------|----|--|
| V <sub>CC</sub>  | Supply Voltage        |                         | - 0.5~ + 7.0          | V  |  |
| VIN              | Input Voltage         | With Respect<br>to GND. | - 0.5~ + 7.0          | V  |  |
| Vout             | Output Voltage        |                         | - 0.5~ + 7.0          | V  |  |
| PD               | Power Dissipation     | -                       | 1.5                   | w  |  |
| T <sub>sol</sub> | Solder Temperature    | -                       | 260 (10 sec)          | °C |  |
| T <sub>stg</sub> | Strage Temperature    | _                       | - 65~ + 150           | °C |  |
| T <sub>opr</sub> | Operating Temperature | _                       | 0~+70                 | °C |  |
| 050489           |                       |                         |                       |    |  |

### 8.2 DC CHARACTERISTICS

Ta = 0  $\degree$  to 70  $\degree$  , V<sub>CC</sub> = 5V ± 5% , V<sub>SS</sub> (GND) = 0V

| SYMBOL           | PARAMETER                 | TEST CONDITIONS                          | MIN.  | TYP. | MAX.                  | UNIT |
|------------------|---------------------------|------------------------------------------|-------|------|-----------------------|------|
| VIL              | Input Low Voltage         |                                          | - 0.5 | _    | 0.8                   | V    |
| VIH              | Input High Voltage        |                                          | 2.2   | —    | V <sub>CC</sub> + 0.5 | V    |
| V <sub>OL</sub>  | Output Low Voltage        | I <sub>OL</sub> = 3.2mA                  | —     | —    | 0.45                  | V    |
| V <sub>OH1</sub> | Output High Voltage       | I <sub>OH1</sub> = - 200µА               | 2.4   | —    | -                     | V    |
| V <sub>OH2</sub> | Output High Voltage       | I <sub>OH2</sub> = - 100μA<br>(HRQ ONLY) | 3.3   | —    | _                     | V    |
| l <sub>IL</sub>  | Input Leakage Current     | $0V \leq V_{IN} \leq V_{CC}$             | _     | -    | ± 10                  | μA   |
| IOFL             | Output Leakage<br>Current | $0.45V \le V_{OUT} \le V_{CC}$           | _     | _    | ± 10                  | μА   |
| I <sub>CC</sub>  | Supply Current            |                                          | —     | _    | 150                   | mA   |

050489

## 8.3 AC CHARACTERISTICS

8.3.1 Active Cycle (1/3) (Notes : 2 and 9)

Ta = 0°C to 70°C,  $V_{CC} = 5V \pm 5\%$ ,  $V_{SS} = 0V$ 

| SYMBOL            | PARAMETER                               |   | MAX. | Unit |
|-------------------|-----------------------------------------|---|------|------|
| T <sub>AEL</sub>  | AEN HIGH from CLK LOW (S1) Delay Time   | - | 200  | ns   |
| T <sub>AET</sub>  | AEN LOW from CLK HIGH (SI) Delay Time   |   | 130  | ns   |
| T <sub>AFAB</sub> | ADR Active to FLoat Delay from CLK HIGH | _ | 90   | ns   |
| TAFC              | READ or WRITE Float Delay from CLK HIGH | - | 120  | ns   |

050489
# Active Cycle (2/3)

| SYMBOL            | PARAMETER                                            | MIN.      | MAX. | UNIT |
|-------------------|------------------------------------------------------|-----------|------|------|
| T <sub>AFDB</sub> | DB Active to Float Delay from CLK HIGH               | -         | 170  | ns   |
| T <sub>AHR</sub>  | ADR from READ HIGH Hold Time                         | TCY - 100 | -    | ns   |
| T <sub>AHS</sub>  | DB from ADSTB LOW Hold Time                          | 30        | -    | ns   |
| T <sub>AHW</sub>  | ADR from WRITE HIGH Hold Time                        | TCY – 50  | -    | ns   |
|                   | DACK Valid from CLK LOW Delay Time                   | -         | 170  | ns   |
| ΤΑΚ               | EOP HIGH from CLK HIGH Delay Time                    | -         | 170  | ns   |
|                   | EOP LOW to CLK HIGH Delay Time                       | -         | 170  | ns   |
| T <sub>ASM</sub>  | ADR Stable from CLK HIGH                             | _         | 170  | ns   |
| T <sub>ASS</sub>  | DB to ADSTB LOW Setup Time                           | 100       | -    | ns   |
| Т <sub>СН</sub>   | Clock HIGH Level Width                               | 80        | -    | ns   |
| T <sub>CL</sub>   | Clock LOW Level Width                                | 68        | -    | ns   |
| T <sub>CY</sub>   | Clock Cycle Time                                     | 200       | -    | ns   |
| T <sub>DCL</sub>  | CLK HIGH to READ or WRITE LOW Delay Time<br>(Note 3) |           | 190  | ns   |
| T <sub>DCTR</sub> | READ HIGH from CLK HIGH (S4) Delay Time<br>(Note 3)  | _         | 190  | ns   |
| TDCTW             | WRITE HIGH from CLK HIGH (S4) Delay (Note 3)         | -         | 130  | ns   |
| T <sub>DQ1</sub>  | HPO Valid from CLK HICH Delay Time (Note 4)          | -         | 120  | ns   |
| T <sub>DQ2</sub>  |                                                      |           | 120  | ns   |
| T <sub>EPS</sub>  | EOP Low from CLK LOW Setup Time                      | 40        | -    | ns   |
| T <sub>EPW</sub>  | EOP pulse width                                      | 220       | -    | ns   |
| T <sub>FAAB</sub> | DB Float to Active Delay from CLK HIGH               | -         | 170  | ns   |
| T <sub>FAC</sub>  | READ or WRITE Active from CLK HIGH                   | -         | 150  | ns   |
| T <sub>FADB</sub> | DB Float to Active Delay from CLK HIGH               | -         | 200  | ns   |
| т <sub>нs</sub>   | HLDA Valid to CLK HIGH Setup Time                    | 75        | -    | ns   |
| TIDH              | Input Data from MEMR HIGH Hold Time                  | 0         | -    | ns   |
| T <sub>IDS</sub>  | Input Data to MEMR HIGH Setup Time                   | 170       | -    | ns   |
| TODH              | Output Data to MEMR HIGH Hold Time                   | 10        | -    | ns   |
| T <sub>ODV</sub>  | Output Data Valid to MEMW HIGH                       | 125       | -    | ns   |
| T <sub>QS</sub>   | DREQ to CLK LOW (SI, S4) Setup Time                  | 0         | -    | ns   |
| T <sub>RH</sub>   | CLK to READY LOW Hold Time                           | 20        |      | ns   |

# Active Cycle (3/3)

| SYMBOL           | PARAMETER                           | MIN. | MAX. | UNIT |
|------------------|-------------------------------------|------|------|------|
| T <sub>RS</sub>  | READY to CLK LOW Setup Time         | 60   | -    | ns   |
| T <sub>STL</sub> | ADSTB HIGH from CLK HIGH Delay Time |      | 130  | ns   |
| T <sub>STT</sub> | ADSTB LOW from CLK HIGH Delay Time  | —    | 90   | ns   |

050489

# 8.3.2 Program Condition (Idle Cycle) (Notes : 2, 8 and 9)

Ta = 0°C to 70°C,  $V_{CC}$  = 5V ± 5%,  $V_{SS}$  = 0V

| SYMBOL            | PARAMETER                                 | MIN. | MAX. | UNIT |
|-------------------|-------------------------------------------|------|------|------|
| T <sub>AR</sub>   | ADR Valid or CS LOW to READ LOW           | 50   | _    | ns   |
| TAW               | ADR Valid or WRITE HIGH Setup Time        | 130  | -    | ns   |
| T <sub>CW</sub>   | CS LOW to WRITE HIGH Setup Time           | 130  | -    | ns   |
| T <sub>DW</sub>   | Data Valid to WRITE HIGH Setup Time       | 130  | -    | ns   |
| T <sub>RA</sub>   | ADR or CS Hold from READ HIGH             | 0    | -    | ns   |
| T <sub>RDE</sub>  | Data Access from READ LOW                 |      | 140  | ns   |
| T <sub>RDF</sub>  | Data Bus Float Delay from READ HIGH       | 0    | 70   | ns   |
| T <sub>rstd</sub> | Power Supply HIGH to RESET LOW Setup Time | 500  | _    | ns   |
| T <sub>RSTS</sub> | RESET to First IOWR                       | 2    | -    | тсү  |
| T <sub>RSTW</sub> | RESET pulse width                         | 300  | -    | ns   |
| T <sub>RW</sub>   | READ pulse width                          | 200  | -    | ns   |
| TWA               | ADR from WRITE HIGH Hold Time             | 20   | -    | ns   |
| Twc               | CS HIGH from WRITE HIGH Hold Time         | 20   | -    | ns   |
| T <sub>WD</sub>   | Data from WRITE HIGH Hold Time            | 30   |      | ns   |
| Twws              | WRITE pulse width                         | 160  | -    | ns   |

050489

#### 8.4 CAPACITY

# $Ta = 25^{\circ}C, V_{CC} = GND = 0V$

| SYMBOL           | PARAMETER          | TEST CONDITION                      | MIN. | TYP. | MAX. | UNIT |
|------------------|--------------------|-------------------------------------|------|------|------|------|
| Co               | Output Capacitance |                                     | -    | _    | 8    |      |
| Cl               | Input Capacitance  | f <sub>C</sub> = 1.0MHz, Input = 0V | —    | -    | 15   | рF   |
| C <sub>I/O</sub> | I/O Capacitance    |                                     |      | —    | 20   |      |

Note 1: Typ. value is that when rated voltage is applied at  $Ta = 25^{\circ}C$ .

- Note 2: Test conditions; a) Unless otherwise specified, timing defining signal voltages are; Input High level=2.4V, Low level=0.45V Output High level=2.0V, Low level=0.8V
  - b) Unless otherwise specified, 1×TTL gate and 150pF load are provided to output.
- Note 3: Normal write pulse width is TCY 100 ns. Extension write pulse width is 2TCY 100 ns. Read pulse width is 2TCY-50 ns, and compressed read pulse width is TCY 50 ns.
- Note 4: TDQ is measured at two different high levels. TDQ1=2.0V, TDQ2=3.3V
- Note 5: It is necessary to keep DREQ active until DACK is received.
- Note 6: Both low active and high active level ae available for DREQ and DACK.
- Note 7: Output load of the data bus are provided with 1×TTL gate and 15 pF as the minimum value, and 1×TTL gate and 150 pF as the maximum value.
- Note 8: Sucessive read or/and write operations by the MPU to program must be timed to allow at least 600ns for the TMP8237AP and at least 400ns for the TMP8237AP-5 as recovery time between active read or write pulses.
- Note 9: Signal <u>READ</u> and <u>WRITE</u> are <u>IOR</u> and <u>MEMW</u> for the DMA operations from peripheral devices to the memory. In the DMA operations from the memory to peripheral devices, they are <u>MEMR</u> and <u>IOW</u>.
- Note10: When N state wait is added at time of write to memory in the latter half of memory-to-memory transfer, this parameter increases by N (TCY) at a time.

# 9. TIMING DIAGRAM



050489





Timing Diagram 2 Program Condition Read Cycle



Timing Diagram 3 Active Cycle





Timing Diagram 4 Memory-to-Memory Transfer









# 10. EXTERNAL DIMENSION VIEW (PLASTIC PACKAGE)

DIP40-P-600



270289

Note : Each pitch is 2.54mm, and all the leads are located within  $\pm$  0.25mm from their theoretical positions with respect to No.1 and No.40 leads.

# 11. EXAMPLE OF APPLICATION CIRCUIT

The connecting method of the TMP8237A and MPU is shown in Figure 11.1.

The multimode DMA controller outputs a hold request whenever valid DMA request is produced from peripheral device. When MPU answers by the hold acknowledge signal, the TMP8237A receives the contorl right of the address bus, data bus, and control bus. In the first transfer, address (the least significant 8 bits of the address bits and the most significant 8 bits on the data bus) is output.

The content of the data bus is latched by the 8-bit latch (TC74HC373P) to make the address bus complete. After execution of the first transfer, that latched data is updated only when carry or borrow is produced on the least significant address byte.

ADDRESS BUS A0~A15 A8~A15 ŌĒ TC74HC373P I F 8BIT LATCH AEN A0~A3 A4~A7 CS ADSTB A0~A15 DB0~DB7 BUSEN TMP8237A DR EQ DACK<sub>0-3</sub> HLDA HLDA MEMW RESE MEM HOLD HRO CLK <u>N</u> OR 4 CLOCK MPU RESET MEMR MEMW CONTROL IOR BUS IOW  $D_0 \sim D_7$ SYSTEM DATA BUS 050489

When one TMP8237A is used, four DMA channels are provided.

Figure 11.1 Basic System Connection Diagram

Figure 11.2 shows the expansion method for number of DMA channels. It is possible to realize net 7 DMA channels by connecting the second TMP8237A to one of the DMA channels of the first TMP8237A.

Two DMA chips commonly use the same 8-bit latch. Thus, any channel is used for expansion.



# PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE

# TMP82C79P-2/TMP82C79M-2

# 1. GENERAL DESCRIPTION

The TMP82C79P-2/M-2 (hereinafter referred to as TMP82C79) is a programmable keyboard/display interface. The keyboard portion can provide a scanned interface up to 64-contact key matrix. Also, the keyboard portion can interface to an array of sensors or a strobed interface keyboard. Key depressions can be 2-key lockout or N-key rollover. The display portion has  $16 \times 8$  bits display RAM which can be treated as dual  $16 \times 4$  bits. Both right entry and left entry display formats are possible.

# 2. FEATURES

- Simultaneous Keyboard Display operation.
- Scanned Keyboard mode.
- Scanned Sensor matrix mode.
- Strobed Input Entry mode.
- Built-in 8-Character FIFO or 64 bit Sensor RAM.
- Programmable 2-key Lockout or N-key Rollover with contact debounce.
- Built-in 16×8bit Display RAM
- Programmable scan timing.
- Extend operating temperature range -40 °C to +85 °C.





# 5. PIN NAMES AND PIN DESCRIPTION

• VSS (Power Supply)

Gound

• VCC (Power Supply)

+5V during operation

• DB<sub>0</sub>-DB<sub>7</sub> (Input/Output)

Bidirectional data bus. All data and commands are transferred via this data bus.

• CLK (Input)

System Clock used to generate the TMP82C79 internal timing.

• RESET (Input)

A high level signal on this pin resets the TMP82C79. After being reset the TMP82C79 is placed in the following state.

 $(1)16 \times 8$  bit character display, left entry.

(2)Encode scan keyboard, 2 key lockout, clock pre-scale value is set to 31.

•  $\overline{\mathrm{CS}}$  (Input)

A low level input on this pin enables  $\overline{RD}$  and  $\overline{WR}$  communication between the MPU and the TMP82C79.

• A<sub>0</sub> (Input)

This input acts in conjunction with the  $\overline{CS}$ ,  $\overline{WR}$  and  $\overline{RD}$  pins. A high level on this pin indicates the signals on data bus are interpreted as command or status. A low level indicates they are data in the RAMs.

• WR (Input)

A low level input on this pin when  $\overline{\rm CS}$  is low enables the TMP82C79 to accept command or data from the MPU.

•  $\overline{\text{RD}}$  (Input)

A low level input on this pin when  $\overline{\text{CS}}$  is low enables the TMP82C79 to output data or status onto the data bus.

• IRQ (Output)

Interrupt request output. In keyboard mode, the interrupt line is high when the FIFO/Sensor RAM has effective data. The interrupt line goes low when each FIFO/Sensor RAM is read and returns high if the RAM still has effective data. In sensor matrix mode, the interrupt line goes high whenever any change in the sensor matrix is detected.

• SL<sub>0</sub>-SL<sub>3</sub> (Output)

Scan lines which are used to scan the key switch or sensor matrix and the display digits. These lines can be either encoded (1 of 16) or decoded (1 of 4).

• RL<sub>0</sub>-RL<sub>7</sub> (Input)

Return lines which are connected to the scan lines through the key or sensor switches. Each line has an internal pullup to keep it high until a switch closure pulls it low. They also serve as an 8-bit input in Strobed Input mode.

• SHIFT (Input)

This input status is stored in the FIFO RAM in addition to the information of the key position on key closure in Scanned key board modes. It has an internal pullup to keep it high until a switch closure pulls it low.

• CNTL/STB (Input)

For Keyboard modes this line is used as a control input and stored like status on a key closure. This can be also programmed as the strobe line that enters the data into FIFO in Strobed Input mode (Rising Edge). It has an internal pullup to keep it high until a switch closure pulls it low.

 $OUTA_0-OUTA_3$  (Output)

## $OUTB_0-OUTB_3$ (Output)

These two ports are the outputs for the  $16 \times 4$  display refresh registers. The data from these outputs is updated synchronized with the scan lines (SL<sub>0</sub>-SL<sub>3</sub>) for multiplexed digit displays. The two 4 bit ports may be blanked independently. These two ports may also be treated as one 8-bit port.

• BD (Output)

This output is used to blank the display during digit switching or by a display blanking command.

#### 6. FUNCTIONAL DESCRIPTION

#### 6.1 I/O CONTROL AND DATA BUS BUFFER

The I/O control section uses the  $\overline{CS}$ ,  $A_0$ ,  $\overline{RD}$  and  $\overline{WR}$  lines and controls the flow of data to and from the various internal registers and buffers in the TMP82C79.  $\overline{CS}$  input enables the all data flow to and from the TMP82C79. The character of the information given by the MPU, is identified by  $A_0$ .

 $\overline{\text{RD}}$  and  $\overline{\text{WR}}$  decide the direction of data flow through the data bus buffer. The data bus buffer is bidirectional buffer which is used for connecting the internal bus and a system bus. When  $\overline{\text{CS}}$  is high, the buffer is in a high impedance state.

#### 6.2 CONTROL REGISTER, TIMING REGISTER AND TIMING CONTROL CIRCUIT

Keyboard and display modes and the other operating conditions are programmed by the MPU. These modes are latched at the rising edge of  $\overline{WR}$  when  $A_0$  is high. The timing control contains the basic counter chains. The first counter is the 1/N prescaler that can be programmed to yield an basic internal frequency. In case of 100kHz basic internal frequency, it gives a 5.1 ms keyboard scan time and a 10.3 ms debounce time. The other counters divide down the basic internal frequency to provide the proper key scan, row scan, keyboard matrix scan and display scan timings.

#### 6.3 SCAN COUNTER

Two modes are available for the scan counter. In the encode mode, the counter provides a binary count that must be externally decoded to provide the scan lines for the key board and display. In the decode mode, the scan counter decodes the least significant 2 bits internally and provides a decoded 1 of 4 scan. Note that the only first 4 characters in the Display RAM are outputted from  $OUTA_{0-3}$  and  $OUTB_{0-3}$  in the decode mode.

#### 6.4 RETURN BUFFER AND KEYBOARD DEVOUNCE CONTROL CIRCUIT

The 8 return lines are latched onto the return line buffer. In the Keyboard mode, these lines are scanned to look for key closures in a row. If the debounce circuit detects a closed switch, it waits about \*10 ms, and checks if the switch remains closed. If it does so, the address of the switch and the status of SHIFT and CNTL lines is transferred to the FIFO.

In the scanned Sensor Matrix Modes, the contents of the return lines are directly transferred to the corresponding row of the sensor RAM (FIFO) each scan time.

In the Strobed Input Mode, the contents of the return lines are transferred to the FIFO on the rising edge of the CNTL/STB line pulse.

#### 6.5 FIFO/SENSOR RAM AND FIFO/SENSER RAM STATUS

The FIFO/Sensor RAM is a dual function RAM. In the keyboard mode or In the Strobe Input mode, this RAM serves as a FIFO. The FIFO status shows whether the FIFO is empty or full and keeps the number of characters in the FIFO. In addition, there is a flag to show an error in the case where too many reads or writes is recognized. The FIFO status can be read at  $\overline{CS} = \overline{RD} = 0$ ,  $A_0 = 1$ . The FIFO status logic provides an IRQ signal when the FIFO is not empty. In the scanned sensor matrix mode, the RAM serves as a sensor RAM. IRQ becomes high when a change in the sensor is detected.

#### 6.6 DISPLAY ADDRESS REGISTERS AND DISPLAY RAM

The display address registers hold the address of the word currently being written or read by the MPU and the two 4 bit nibbles being displayed. The Display RAM stores data for display outputs. The read/write addresses are programmed by the MPU command. They also can be programmed to autoincrement after read or write. The Display RAM can be directry read out by the MPU after mode and address is set. The A and B nibbles of the Display RAM are outputted to the Display Output A and B synchronously with scan signals ( $SL_0$ - $SL_3$ ). The A and B nibbles can be entered independently or as one word by the MPU command.

\* In case of 100kHz basic internal frequency

#### 7. COMMAND DESCRIPTION

#### 7.1 **KEYBOARD/DISPLAY MODE SET**



#### 7.2 PROGRAM CLOCK

| DB7 | DB <sub>6</sub> | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----------------|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 0   | 0               | 1               | Р   | Р   | Р               | Р               | Р               |

The TMP82C79 generates all timing and multiplexing signals by means of the internal prescaler. The prescaler generates internal reference clocks by dividing an external supply clock by a programmable value PPPPP. Any number from 2 to 31 can be set as a prescaler value. When this value is set to 0 or 1, it is interpreted to be 2. If the internal reference clock is set to 100kHz, it is possible to obtain 5.1ms keyboard scan time and 10.3ms debounce time. The value PPPPP is set to 31 after reset, but cannot be changed by the Clear command.

#### 7.3 READ FIFO/SENSOR RAM

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> | _              |        |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|----------------|--------|
| 0   | 1   | 0               | AI  | . × | А               | A               | А               | x = don't care | 050489 |

If this command is written, the subsequent data reads are set up for the FIFO/Sensor RAM. Auto-increment flag (AI) and the RAM address bits AAA are valid only in Senser Matrix Mode. The address bits AAA select one of the 8 rows of the Sensor RAM. If AI=1, the RAM address is incremented after each successive read. The Auto-increment flag does not affect the auto-increment of the Display RAM.

#### 7.4 READ DISPLAY RAM

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 0   | 1   | 1               | AI  | А   | А               | А               | А               |

If this command is written, the subsequent data reads are set up for the Display RAM. The address bits AAAA select one of the 16 rows of the Display RAM. If AI=1, the address is incremented after each read or write to the Display RAM. Since the same counter is used for both reading and writing, this command sets the next read or wirte address and the sense of the Auto-increment for both operation.

#### 7.5 WRITE DISPLAY RAM

| DB7 | DB <sub>6</sub> | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----------------|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 1   | 0               | 0               | AI  | A   | А               | А               | Α               |

If this command is written, the subsequent data writes are set up for the Display RAM. Note that writing this command does not switch the source of the subsequent data reads. The address register of the Display RAM is same for read/write operations. The addressing and Auto-increment function are identical to those for the Read Display RAM.

#### 7.6 DISPLAY WRITE INHIBIT/BLANKING

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB0 |                |        |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----|----------------|--------|
| 1   | 0   | 1               | ×   | IWA | IWB             | BLA             | BLB | x = don't care | 050489 |

The IWA or IWB bit can be used to mask A nibble or B nibble for entering the Display data independently. The BLA of BLB flag is available for the nibble A or B to blank the display. In the case where the Display Outputs are used as separate 4-bit display ports, the IWA or IWB bit is useful so as not to affect the other display port when the MPU writes a word to the display RAM. The BLA or BLB bit is used for blanking the display independently without giving any affect to the other 4-bit display port. The blank code is determined by the last Clear command that has been programmed after reset. If the Display Output is used as an 8-bit port, it is necessary to set both BLA and BLB bits for blanking the display. Then  $\overline{BD}$  signal becomes low.

| DB7            | DB6            | DB <sub>5</sub> | DB4            | $DB_3$ | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |  |
|----------------|----------------|-----------------|----------------|--------|-----------------|-----------------|-----------------|--|
| ł              | <b>↑</b>       | ł               | ł              | 1      | 1               | Ť               | ↑               |  |
| ¥              | ¥              | ¥               | ¥              | ¥      | ¥               | ¥               | ¥               |  |
| A <sub>3</sub> | A <sub>2</sub> | Α1              | A <sub>0</sub> | B3     | B <sub>2</sub>  | B 1             | Bo              |  |

Correspondence between Display Output and Data Bus

050489

#### 7.7 CLEAR

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----|-----------------|-----|-----------------|-----------------|-----------------|-----------------|
| 1   | 1   | 0               | CD  | CD              | CD              | CF              | CA              |

The CD bits are used to clear all rows of the Display RAM to the following code shown below.

| (DB4) | (DB <sub>3</sub> ) | (DB <sub>2</sub> ) |         |                                                 |        |
|-------|--------------------|--------------------|---------|-------------------------------------------------|--------|
| CD    | CD                 | CD                 |         |                                                 |        |
| 1     | 0                  | ×                  | • • • • | All Zeros (X = Don't Care)                      |        |
| 1     | 1                  | 0                  | ••••    | All Hex 20H (0010 0000)                         |        |
| 1     | 1                  | 1                  | • • • • | All Ones                                        |        |
| 0     | ×                  | ×                  | • • • • | not clear display if CA = 0                     |        |
| t     |                    |                    |         | Enable clear display when CD = 1 (or by CA = 1) | 050489 |

While the Display RAM is being cleared, it may not write to the Display RAM. The MSB bit of the FIFO status word is set during this time. If the CF bit is set to "1", the FIFO status is cleared and the interrupt request output (IRQ) is reset. Also, the Senser RAM pointer is set to the row 0.

The CA bit has the combined effect of the CD bit and CF bit. It enables clear display code to the Display RAM and also clears the FIFO status. Furthermore, it resynchronizes the internal timing chains.

#### 7.8 END INTERRUPT/ERROR MODE SET

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> | <b>-</b>       |        |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|----------------|--------|
| 1   | 1   | 1               | E   | ×   | ×               | ×               | ×               | x = don t care | 050489 |

In the Sensor Matrix mode, this command loweres the IRQ line and enables writing to the sensor RAM. This means that a write to the Sensor RAM is inhibited when IRQ line is high. If the E bit is set to "1", the S/E bit of the FIFO status becomes "1" when any one of the sensor switches is closed. If E=0, the S/E bit is always "0". In the N-Key Rollover mode, if the E bit is programmed to "1", the Special Error mode will be resulted.

#### 7.9 FIFO STATUS

| DU S/E 0 U F N N N<br>Number of characters in Fl<br>FIFO Full<br>Error-Underrun          | DB7 DB6 | B <sub>6</sub> DB <sub>5</sub> DB <sub>4</sub> | DB <sub>3</sub> DB <sub>2</sub>       | DB <sub>1</sub> | DB <sub>0</sub> | V: dop't caro                                                                                                                                             |
|------------------------------------------------------------------------------------------|---------|------------------------------------------------|---------------------------------------|-----------------|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| Number of characters in Fl<br>FIFO Full<br>Error-Underrun                                | DU S/E  | /E 0 U                                         | F N                                   | N               | N               | X. don t care                                                                                                                                             |
| Error-Overrun<br>Sensor Closure/Error Flag f<br>Multiple Closures<br>Display upayailable |         |                                                | · · · · · · · · · · · · · · · · · · · |                 |                 | Number of characters in FIFO<br>FIFO Full<br>Error-Underrun<br>Error-Overrun<br>Sensor Closure/Error Flag for<br>Multiple Closures<br>Display upavailable |

- Du : Indicates that the Display RAM was unavailable because a Clear Display or Clear All command has not completed its clearing operation.
- S/E : In a Sensor Matrix mode, if the E bit of End Interrupt/error mode set is programmed to "0", this S/E bit is set to indicate that at least one sensor closure indication is contained in the Sensor RAM.
  In Special Error Mode, this S/E bit is showing the error flag and serves as an indication to whether a simultaneous multiple closure error has occurred.
- O : indicates that the entry of another character into a full FIFO was attempted.
- U : indicates that the MPU tried to read an empty FIFO.
- F : indicates that the FIFO is full of the eight characters.
- NNN : indicates number of characters in the FIFO when in the Keyboard Mode or in the Strobe Input Mode.

| <u>CS</u> | A <sub>0</sub> | RD         | WR | Functions            |  |
|-----------|----------------|------------|----|----------------------|--|
| 0         | 0              | 0          | 1  | Read Data            |  |
| 0         | 0              | <u>,</u> 1 | 0  | Write Data           |  |
| 0         | 1              | 0          | 1  | Read Status word     |  |
| 0         | 1              | 1          | 0  | Write Command word   |  |
| 1         | ×              | ×          | ×  | High-impedance state |  |

#### Table 7.1 ADDRESSING

# 8. INTERFACE WITH KEYBOARD

#### 8.1 SCANNED KEYBOARD, 2-KEY LOCKOUT

In this mode, if one key only is kept depressed during one debounce cycle (2 times of the key scan cycle), the key is recognized. When a key is depressed, the debounce logic is set and the other depressed keys are checked during the next two scan cycle. If none are encountered, it is a single key depression and the key position is entered into the FIFO along with the status of CNTL and SHIFT lines. If another depressed key are encountered, operates as follows.



Figure 8.2 Example of a Case Where all Depressed Keys are Ignored

As shown in Figure 8.1 if all the other keys are released before the first depressed key, the first depressed key is recognized. As shown in Figure 8.2 if the first depressed key is released within one debounce cycle after the other keys was released, then all keys are ignored.

#### 8.2 SCANNED KEYBOARD, N-KEY ROLLOVER

In this mode, each key depression is independently treated from all others. In the 2key lockout mode, if a key is depressed, the debounce logic is set. If the other keys are depressed within one debounce cycle after it, the debounce logic is set again. The first depressed key is ignored. In the N-key Rollover mode, if a key is depressed waits one debounce cycle and then checks of the key is still down. If it is, the key is entered into the FIFO even of other keys are depressed.



Figure 8.3 Example of 3 Keys Being Pushed Simultaneously

In the example as shown in Figure 8.3 the debounce circuit starts by Key 1, and checks if the key is still down after one debounce cycle. If it is, Key 1 is recognized and Key 2 is ignored not to be depressed for one debounce cycle.

#### 8.3 SPECIAL ERROR MODE (N-KEY ROLLOVER)

This mode is set if the E bit of the End interrupt/error mode set command is programmed to "1". In the normal N-Key Rollover Mode, the key information is entered to the FIFO according to the key scan timing even if a simultaneous multiple depression occures during one debounce cycle. In the Special Error Mode, if a simultaneous multiple depression occurs during one debounce cycle, sets the error falg (the S/E bit of the FIFO status word) to "1". This flag prevents any further writing into the FIFO and will set interrupt request (IRQ). The S/E bit is cleared if the normal Clear command is written with CF = 1.

#### 8.4 SENSOR MATRIX MODE

In Sensor Matrix Mode, the debounce circuit does not operate. The status of the sensor switch is inputted directly to the Sensor RAM. The MPU can only know a validated closure in the keyboard mode, however this mode has such advantage that the CPU knows how long the sensor was closed and when it was released. If there is any change in the sensor value at the end of the sensor matrix scan, the IRQ line goes high. The IRQ line is cleared by the first data read if the Auto-increment flag is "0" or by the End Interrupt/error mode set command if AI = 1.

#### 8.5 STROBE INPUT MODE

In Strobe Input Mode, the debounce circuit does not operate. The data is inputted into the FIFO from the return lines at the rising edge of CNTL/STB Signal. When the data is entered into the FIFO, the IRQ line goes high. The functions of the FIFO and the FIFO status in this mode are same as those in the keyboard mode.

## 9. DATA FORMAT

#### 9.1 KEYBOARD MODE

| DB7  | DB <sub>6</sub> | DB <sub>5</sub> | DB4  | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|------|-----------------|-----------------|------|-----------------|-----------------|-----------------|-----------------|
| CNTL | SHIFT           |                 | SCAN | ,               | 1               | RETURN          | 1               |

In this mode, the Data Format of the character entered into the FIFO is as follows. The MSB is the status of CNTL/STB line and the next MSB shows the status of SHIFT line. The next three bits are from the scan counter and indicate the row the key was found in. The last three bits are from the column counter and indicate to which return line the key was connected.

#### 9.2 SENSOR MATRIX MODE

| DB7 | DB6             | DB <sub>5</sub> | DB4 | DB3             | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |       |
|-----|-----------------|-----------------|-----|-----------------|-----------------|-----------------|-----------------|-------|
| RL7 | RL <sub>6</sub> | RL <sub>5</sub> | RL4 | RL <sub>3</sub> | RL <sub>2</sub> | RL <sub>1</sub> | RL <sub>0</sub> | 05048 |

In this mode, the data on return lines is inputted in the row of the Sensor RAM in order according to the scan. The data is entered even if there is no change in the status of the sensor matrix switches. Each switch position maps to a Sensor RAM position. CNTL and SHIFT signals are ignored.

#### 9.3 STROBE INPUT MODE

| DB7             | DB6             | DB <sub>5</sub> | DB4 | DB3             | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----------------|-----------------|-----------------|-----|-----------------|-----------------|-----------------|-----------------|
| RL <sub>7</sub> | RL <sub>6</sub> | RL <sub>5</sub> | RL4 | RL <sub>3</sub> | RL <sub>2</sub> | RL <sub>1</sub> | RL <sub>0</sub> |

In this mode, the data on return lines is entered into FIFO at the rising edge of CNTL/STB signal.

# 10. INTERFACE WITH DISPLAY

## 10.1 LEFT ENTRY

In Left Entry mode, address 0 of the Display RAM is the left-most side of the display and address 15 (address 7 in the case of 8-character display) is the right-most side. when characters are inputted onto the display RAM with the auto increment mode from address 0 of the display RAM, Characters are filled from the left-most position of the display. The 17th (or 9th) character is placed in the left-most position again. Address of the display RAM corresponds directly to each display positon of the display, and so its position does not change every entry.



#### 10.2 RIGHT ENTRY

In Right Entry, the first entry is from the right-most position. Address of the Display RAM does not correspond to the display position.



# 11. ELECTRIC CHARACTERISTICS

#### 11.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                                            | RATING             | UNIT   |
|------------------|-------------------------------------------------|--------------------|--------|
| V <sub>CC</sub>  | VCC Supply Voltage (with respect to VSS (GND) ) | -0.5 to +7.0       | V      |
| V <sub>1N</sub>  | Input Voltage (with respect to VSS (GND) )      | – 0.5 to VCC + 0.5 | V      |
| Vout             | Output Voltage (with respect to VSS (GND) )     | – 0.5 to VCC + 0.5 | V      |
| PD               | Power Dissipation                               | 250                | mW     |
| T <sub>sol</sub> | Soldering Temperature (soldering time 10 sec)   | 260                | °C     |
| T <sub>stg</sub> | Storage Temperature                             | – 65 to + 150      | °C     |
| T <sub>opr</sub> | Operating Temperature                           | – 40 to + 85       | °C     |
| B                |                                                 |                    | 050489 |

11.2 D.C. ELECTRICAL CHARACTERISTICS

| (, , , , , , , , , , , , , , , , , , , |                                                                         |                                            |           |      |                       |      |
|----------------------------------------|-------------------------------------------------------------------------|--------------------------------------------|-----------|------|-----------------------|------|
| SYMBOL                                 | PARAMETER                                                               | CONDITION                                  | MIN.      | TYP. | MAX.                  | UNIT |
| V <sub>IL1</sub>                       | Input Low Voltage<br>(RL <sub>0</sub> -RL <sub>7</sub> )                |                                            | - 0.5     |      | 1.4                   | V    |
| V <sub>IL2</sub>                       | Input Low Voltage<br>(Others)                                           |                                            | - 0.5     |      | 0.8                   | v    |
| V <sub>IH1</sub>                       | Input High Voltage<br>(RL <sub>0</sub> -RL <sub>7</sub> )               |                                            | 2.2       | —    | V <sub>CC</sub> + 0.5 | v    |
| V <sub>IH2</sub>                       | Input High Voltage<br>(Others)                                          |                                            | 2.2       | -    | V <sub>CC</sub> + 0.5 | V    |
| V <sub>OL</sub>                        | Output Low Voltage                                                      | IOL = 2.2mA                                |           | —    | 0.45                  | V    |
| V <sub>OH1</sub>                       | Output High Voltage                                                     | IOH = -400µA                               | 2.4       |      | —                     | V    |
| V <sub>OH2</sub>                       | Output High Voltage                                                     | IOH = -100μA                               | Vcc – 0.8 | -    | _                     | V    |
|                                        |                                                                         | VIN = VCC                                  | -         | _    | + 10                  |      |
| l <sub>IL1</sub>                       | Input 1LEAK Current<br>(SHIFT, CNTL, RL <sub>0</sub> -RL <sub>7</sub> ) | VIN = 2.4V                                 | - 10      | - 30 | —                     | μA   |
|                                        |                                                                         | VIN = 0V                                   | _         |      | - 100                 |      |
| I <sub>IL2</sub>                       | Input Leak Current<br>(Others)                                          | 0V≦VIN≦VCC                                 |           | _    | ± 10                  | μА   |
| IOFL                                   | Output Leak Current                                                     | $0.45V \le VOUT \le VCC$                   |           | —    | ± 10                  | μA   |
| lcc                                    | Operating Supply<br>Current                                             | VIH = VCC-0.2V<br>VIL = 0.2V,<br>fc = 5MHz |           | _    | 5                     | mA   |

## $(Ta = -40 \text{ to } + 85 \text{ °C}, V_{CC} = 5V \pm 10\%, V_{SS} \text{ (GND)} = 0V)$

#### 11.3 INPUT CAPACITY

| SYMBOL          | PARAMETER      | CONDITION                 | MIN. | TYP. | MAX. | UNIT |
|-----------------|----------------|---------------------------|------|------|------|------|
| C <sub>IN</sub> | Input Capcity  | fc = 1MHz Unmeasured Pins | -    | 5    | 10   | рF   |
| COUT            | Output Capcity | returned to VSS.          | -    | 10   | 20   | рF   |

050489

#### 11.4 A.C. ELECTRICAL CHARACTERISTICS

| $1a = -40 t0 + 85 C, VCC = 5.0V \pm 10\%, VSS (GND) =$ | = 0 V |
|--------------------------------------------------------|-------|
|--------------------------------------------------------|-------|

| SYMBOL           | PARAMETER                     | MIN. | TYP. | MAX.  | UNIT |
|------------------|-------------------------------|------|------|-------|------|
| t <sub>AR</sub>  | Address Set up Time (RD)      | 10   | -    | -     | ns   |
| t <sub>RA</sub>  | Address Hold Time (RD)        | 10   |      |       | ns   |
| t <sub>RR</sub>  | RD Pulse Width                | 160  |      | -     | ns   |
| *t <sub>RD</sub> | Valid Data (RD)               | -    | _    | 120   | ns   |
| *t <sub>AD</sub> | Address to Valid Data         | -    |      | . 185 | ns   |
| t <sub>DF</sub>  | Data Floating (RD)            | 10   | -    | 85    | ns   |
| t <sub>RCY</sub> | Read cycle Time               | 200  | -    |       | ns   |
| t <sub>AW</sub>  | Address Set up Time (WR)      | 0    | _    | -     | ns   |
| t <sub>WA</sub>  | Address Hold Time (WR)        | 0    |      | -     | ns   |
| t <sub>WW</sub>  | WR Pulse Width                | 160  | —    | -     | ns   |
| t <sub>DW</sub>  | Data Set up Time (WR)         | 120  | -    | -     | ns   |
| t <sub>WD</sub>  | Data Hold Time (WR)           | 30   | -    | -     | ns   |
| twcy             | Write Cycle Time              | 200  | -    | -     | ns   |
| t <sub>OWH</sub> | CLK Pulse Width of High Level | 80   | -    | -     | ns   |
| t <sub>OWL</sub> | CLK Pulse Width of Low Level  | 50   | -    | -     | ns   |
| t <sub>CY</sub>  | Clock Period                  | 200  | -    |       | ns   |

\*TEST CONDITION CL = 150pF

11.4.1 AC TEST CONDITION



050489

# 11.4.2 AC TEST INPUT WAVEFORM



# 12. TIMING DIAGRAM



Figure 12.1 READ TIMING











# 13. EXAMPLE OF APPLICATION CIRCUIT



Figure 13.1 EXAMPLE OF APPLICATION CIRCUIT

# 14. EXTERNAL DIMENSION

## 14.1 40PIN DIP EXTERNAL DIMENSION

DIP40-P-600



050489

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoritical positions with respect to No.1 and No.40 leads.

## 14.2 40PIN SOP EXTERNAL DIMENSION

#### SSOP40-P-450

Unit : mm



050489

Note : Package Width and Length do not include Mold Protrusions. Allowable Mold Protrusion is 0.15mm.

# PROGRAMMABLE KEYBOARD/DISPLAY INTERFACE

# TMP8279P-5

# 1. GENERAL DESCRIPTION

The TMP8279P-5 (hereinafter referred to as TMP8279) is a programmable keyboard/display interface designed for use as the TLCS-85A microcomputer peripheral. The keyboard portion can provide a scanned interface to a 64-contact key matrix. Also, the keyboard portion can interface to an array of sensors or a strobed interface keyboard. Key depressions can be 2-key lockout or N-key rollover. The display portion has  $16 \times 8$  bits display RAM which can be treated as dual  $16 \times 4$  bits. Both right entry and left entry display formats are possible.

# 2. FEATURES

- Simulataneous Keyboard/Display operation is possible
- Scanned Keyboard mode.
- Scanned Sensor Matrix mode.
- Strobed Input Entry mode.
- Buil in 8-character FIFO or 64 bit Sensor RAM
- Programmable 2 Key Lockout or N-key Rollover with contact Debounce.
- Built in  $16 \times 8$  bit display RAM.
- Programmable scan timing
- Compatible with INTEL 8279-5.



# 5. PIN NAME AND PIN DESCRIPTION

- VSS (Power Supply) Ground
- VCC (Power Supply)

+5V during operaiton

• DB<sub>0</sub>~DB<sub>7</sub> (Input/Output)

Bidirecitonal Data Bus. All data and commands are transfered via this data bus.

• CLK (Input)

System clock used to generate the TMP8279 internal timing.

• RESET (Input)

A high level signal on this pin resets the TMP8279. After being reset the TMP8279 is placed in the following state.

- (1)  $16 \times 8$  bit character display, left entry.
- (2) Encode scan keyboard, 2 key lockout, clock pre-scale value is set to 31.
- $\overline{\mathrm{CS}}$  (Input)

A low level input on this pin enables  $\overline{RD}$  and  $\overline{WR}$  communication between the MPU and the TMP8279.

• A<sub>0</sub> (Input)

This inputs acts in conjunction with the  $\overline{CS}$ ,  $\overline{WR}$  and  $\overline{RD}$  pins. A high level input on this pin indicates the signals on data bus are interpreted as command or status. A low level input indicates they are data in the RAMs.

• WR (Input)

A low level input on this pin when  $\overline{CS}$  is low enables the TMP8279 to accept command or data from the MPU.

• RD (Input)

A low level input on this pin when  $\overline{\text{CS}}$  is low enables the TMP8279 to output data or status onto the bus.

IRQ (Output)

Interrupt request output. In a keyboard mode, the interrupt line is high when the FIFO/Sensor RAM has effective data. The interrupt line goes low when each FIFO/Sensor RAM read and returns high if the RAM still has effective data. In sensor matrix mode, the interrupt line goes high whenever any change in the sensor matrix is detected.

•  $SL_0 \sim SL_3$  (Output)

Scan lines which are used to scan the key switch or the sensor matrix and the display digits. These lines can be either encoded (1 of 16) of decode (1 of 4).

•  $RL_0 \sim RL_7$  (Input)

Return lines which are connected to the scan lines through the keys or sensor switches. Each line has an internal pullup to keep it high until a switch closure pulls it low. They also serve as an 8-bit input in Strobed Input mode.

• SHIFT (Input)

This input status is stored in the FIFO RAM in addition to information of the key position on key closure in Scannned key board modes. It has an internal pullup to keep it high until a switch closure pulls it low.

• CNTL/STB (Input)

For Keyboard modes this line is used as a control input and stored like status on a key closure. This can be programmed as the strobe line that enters the data into FIFO in Strobed Input mode (Rising Edge). It has an internal pullup to keep it high until a switch closure pulls it low.

- OUTA<sub>0</sub>~OUTA<sub>3</sub> (Output)
- OUTB<sub>0</sub>~OUTB<sub>3</sub> (Output)

These two ports are the outputs for the  $16 \times 4$  display refresh registers. The data from these outputs is updated synchronized with the scan lines (SL<sub>0</sub>~SL<sub>3</sub>) for multiplexed digit displays. The two 4 bit ports may be blanked independently. These two ports may also be treated as one 8-bit port.

• <u>BD</u> (Output)

This output is used to blank the display during digit switching or by a display blanking command.
# 6. FUNCTIONAL DESCRIPTION

### 6.1 I/O CONTROL AND DATA BUS BUFFER

The I/O control section uses the  $\overline{CS}$ ,  $A_0$ ,  $\overline{RD}$  and  $\overline{WR}$  lines and controls the flow of data to and from the various internal registers and buffers in the TMP8279.  $\overline{CS}$  input enables the all data flow to and from the TMP8279. The character of the information given by the MPU, is identified by  $A_0$ .  $\overline{RD}$  and  $\overline{WR}$  decide the direction of data flow through the data bus buffer. The data bus buffer is bidirectional buffer which is used for connecting the internal bus and a system bus. When  $\overline{CS}$  is high, the buffer is in a high impedance state.

## 6.2 CONTORL REGISTER, TIMING REGISTER AND TIMING CONTROL CIRCUIT

The keyboard and display modes or the other operating conditions are programmed by the MPU. These modes are latched at the rising edge of  $\overline{WR}$  when  $A_0$  is high. The timing control contains the basic counter chains. The first counter is the 1/N prescaler that can be programmed to yield an basic internal frequency which gives a 5.1ms keyboard scan time and a 10.3ms debounce time. The other counters divide down the basic internal frequency to provide the proper keyboard matrix scan and display scan timings.

### 6.3 SCAN COUNTER

Two modes are available for the scan counter. In the encode mode, the counter provides a binary count that must be externally decoded to provide the scan lines for the key board and display. In the decode mode, the scan counter decodes the least significant 2 bits internally and provides a decoded 1 of 4 scan. Note that the only first 4 characters in the Display RAM are outputted from  $OUTA_{0-3}$  and  $OUTB_{0-3}$  in the decode mode.

### 6.4 RETURN BUFFER AND KEYBOARD DEVOUNCE CONTROL CIRCUITS

The 8 return lines are latched onto the return line buffer. In the Keyboard mode, these lines are scanned to look for key closures in a row. If the debounce circuit detects a closed switch, it waits about 10ms\*, and checks if the switch remains closed. If it does so, the address of the switch and the status of SHIFT and CNTL lines is transferred to the FIFO.

#### 6.5 FIFO/SENSOR RAM AND FIFO/SENSOR RAM STATUS

The FIFO/Sensor RAM is a dual funciton RAM. In the keyboard mode or in the Strobe Input mode, this RAM serves as a FIFO. The FIFO status shows whether the FIFO is empty or full and keeps the number of characters in the FIFO. In addition, there is a flag to show an error in the case where too many reads or writes is recognized. The FIFO status can be read at  $\overline{CS} = \overline{RD} = 0$ ,  $A_0 = 1$ . The FIFO status logic provides an IRQ signal when the FIFO is not empty. In the scanned sensor matrix mode, the RAM serves as a Sensor RAM. IRQ becomes high when a change in the sensor is detected.

### 6.6 DISPLAY ADDRESS REGISTERS AND DISPLAY RAM

The display address registers hold the address of the word currently being written or read by the MPU and the two 4 bit nibbles being displayed. The Display RAM stores data for display outputs. The read/write addresses are programmed by the MPU command. They also can be programmed to auto-increment after read or wirte. The Display RAM can be directy read out by the MPU after mode and address is set. The A and B nibbles of the Display RAM are outputted to the Display Outputs A and B syncronously with scan signals ( $SL_0 \sim SL_3$ ). The A and B nibbles can be entered independently or as one word by the MPU command.

\* In case of 100KHz basic internal frequency.

# 7. COMMAND DESCRIPTION

### 7.1 KEYBOARD/DISPLAY MODE SET



050489

#### 7.2 PROGRAM CLOCK

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 0   | 0   | 1               | Р   | Р   | Р               | Р               | Р               |

The TMP8279 generates all timing and multiplexing signals by means of the internal prescaler. The prescaler generates internal reference clocks by dividing an external supply clock by a programmable value PPPPP. Any number from 2 to 31 can be set as a prescaler value. When this value is set to 0 or 1, it is interpreted to be 2. If the internal reference clock is set to 100kHz, it is possible to obtain 5.1ms keyboard scan time and 10.3ms debounce time. The value PPPPP is set to 31 after reset, but cannot be changed by the Clear command.

#### 7.3 READ FIFO/SENSOR RAM

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |                |        |
|-----|-----|-----------------|-----|-----------------|-----------------|-----------------|-----------------|----------------|--------|
| 0   | 1   | 0               | Al  | Х               | А               | А               | А               | X = don't care | 050489 |

If this command is writen, the subsequent data reads are set up for the FIFO/Sensor RAM. Auto-increment flag (AI) and the RAM address bits AAA are valid only in Sensor Matrix Mode. The address bits AAA select one of the 8 rows of the Sensor RAM. If AI=1, the RAM address is incremented after each successive read. The Auto-incremented flag does not affect the auto-increment of the Display RAM.

#### 7.4 READ DISPLAY RAM

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----|-----------------|-----|-----------------|-----------------|-----------------|-----------------|
| 0   | 1   | 1               | AI  | А               | А               | А               | А               |

If this command is written, the subsequent data reads are set up for the Display RAM. The address bits AAAA select one of the 16 rows of the Display RAM. If AI=1, the address is incremented after each read or write to the Display RAM. This command sets the next read or write address and the sense of the Auto-increment.

### 7.5 WRITE DISPLAY RAM

| DB7 | DB <sub>6</sub> | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----------------|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 1   | 0               | 0               | AI  | А   | A               | A               | A               |

If this command is written, the subsequent data writes are set up for the Display RAM. Note that writing this command does not switch the source of the subsequent data reads. The address register of the Display RAM is same for read/write operations. The addressing and Auto-increment function are identical to those for the Read Display RAM.

#### 7.6 DISPLAY WRITE INHIBIT/BLANKING

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |                |        |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|----------------|--------|
| 1   | 0   | 1               | Х   | IWA | IWB             | BLA             | BLB             | X = don't care | 050489 |

The IWA or IWB bit can be used to mask A nibble or B nibble for entering the Display data independently. The BLA or BLB flag is available for the nibble A or B to blank the display. In the case where the Display Outputs are used as separate 4-bit display ports, the IWA or IWB bit is useful so as not to affect the other display port when the MPU writes a word to the display RAM. The BLA or BLB bit is used for blanking the display independently without giving any affect to the other 4-bit display port. The blank code is determined by the last Clear command that has been programmed after reset. If the Display Output is used as an 8-bit port, it is necessary to set both BLA and BLB bits for blanking the display. The BD signal becomes low.

| DB7 | DB <sub>6</sub> | DB <sub>5</sub> | $DB_4$         | DB <sub>3</sub> | DB <sub>2</sub> | DB <sub>1</sub> | DB0            |
|-----|-----------------|-----------------|----------------|-----------------|-----------------|-----------------|----------------|
| \$  | \$              | \$              | \$             | \$              | \$              | \$              | \$             |
| A3  | A <sub>2</sub>  | A <sub>1</sub>  | A <sub>0</sub> | B3              | B <sub>2</sub>  | B <sub>1</sub>  | B <sub>0</sub> |

Correspondence between Display Output and Data Bus

#### 7.7 CLEAR

| DB7 | DB6 | DB <sub>5</sub> | DB4 | DB3 | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----|-----------------|-----|-----|-----------------|-----------------|-----------------|
| 1   | 1   | 0               | CD  | CD  | CD              | CF              | CA              |

The  $C_D$  bits are used to clear all rows of the Dislay RAM to the following code shown below.

| (DB4)   | (DB <sub>3</sub> ) | (DB <sub>2</sub> ) |                                                        |        |
|---------|--------------------|--------------------|--------------------------------------------------------|--------|
| $C_{D}$ | $C_{D}$            | $C_{D}$            |                                                        |        |
| 1       | 0                  | ×                  | ···· All Zeros (X = Don't Care)                        |        |
| 1       | 1                  | 0                  | ···· All Hex 20H (0010 0000)                           |        |
| 1       | 1                  | 1                  | ···· All Ones                                          |        |
| 0       | х                  | ×                  | $\cdots$ not clear display if $C_A = 0$                |        |
| t       |                    |                    | Enable clear display when $C_D = 1$ (or by $C_A = 1$ ) | 050489 |

While the Display RAM is being cleared, it may not write to the Display RAM. The MSB bit of the FIFO status word is set during this time. If the  $C_F$  bit is set to "1", the FIFO status is cleared and the interrupt request output (IRQ) is reset. Also, the Sensor RAM pointer is set to the row 0.

The  $C_A$  bit has the combined effect of the  $C_D$  bit and  $C_F$  bit. It enables clear display code to the Display RAM and also clears the FIFO status. Furthermore, it resynchronizeds the inernal timing chains.

#### 7.8 END INTERRUPT/ERROR MODE SET

| DB7 | DB <sub>6</sub> | DB <sub>5</sub> | DB4 | $DB_3$ | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |               |        |
|-----|-----------------|-----------------|-----|--------|-----------------|-----------------|-----------------|---------------|--------|
| 1   | 1               | 1               | E   | ×      | ×               | ×               | ×               | X: don't care | 050489 |

In the Sensor Matrix mode, this command loweres the IRQ line and enables writing to the Sensor RAM. This means that a write to the Sensor RAM is inhibited when IRQ line is high. If the E bit is set to "1", the S/E bit of the FIFO status becomes "1" when any one of the sensor switches is closed. If E = 0, the S/E bit is always "0". In the N-Key Rollover, if the E bit is programmed to "1", the Special Error mode will be resulted.

#### 7.9 FIFO STATUS



- Du : indicates that the Display RAM is unavailable because a Clear Display or Clear All command has not completed its clearing operation.
- S/E : in a Sensor Matrix mode, if the E bit of End Interrupt/Error Mode Set is programmed to "1", this S/E bit is set to indicate that at least one sensor closure indication is contained in the Sensor RAM.
  In Special Error Mode, this S/E bit is showing the error flag and serves as an indication to whether a simulataneous multiple closure error has occured.
- O : indicates that the entry of another character into a full FIFO was attempted.
- U : indicates that the MPU tried to read an empty FIFO.
- F : indicates that the FIFO is full of the eight characters.
- NNN : indicate number of characters in the FIFO when in the Keyboard Mode or in the Strobe Input Mode.

| <u>cs</u> | A <sub>0</sub> | RD | WR | Functions            |
|-----------|----------------|----|----|----------------------|
| 0         | 0              | 0  | 1  | Read Data            |
| 0         | 0              | 1  | 0  | Write Data           |
| 0         | 1              | 0  | 1  | Read Status word     |
| 0         | 1              | 1  | 0  | Write Command word   |
| 1         | ×              | ×  | ×  | High-impedance state |

#### Table 7.1 Addressing

# 8. INTERFACE WITH KEYBOARD

## 8.1 SCANNED KEYBOARD, 2-KEY LOCKOUT

In this mode, if one key only is kept depressed during one debounce cycle (2 times of the key scan cycle), the key is recognized. When a key is depressed, the debounce logic is set and the other depressed keys are checked during the next two scan cycle. If none are encountered, it is a single key depressing and the key position is entered into the FIFO along with the status of CNTL and SHIFT lines. If another depressed key are encountered, operates as follows.





As shown in Figure 8.1, if all the other keys are released before the first depressed key, the first depressed key is recognized. As shown in Figure 8.2, if the first depressed key is released within one debounce cycle after the other keys was released, than all keys are ignored.

## 8.2 SCANNED KEYBOARD, N-KEY ROLLOVER

In this mode, each key depression is independently treated from all others. In the 2-Key lockout mode, if a key is depressed, the debounce logic is set. If the other keys are depressed within one debounce cycle after it, the debounce logic is set again. The first depressed key is ignored. In the N-key Rollover mode, if a key is depressed waits one debounce cycle and then checks if the key is still down. If it is, the key is entered into the FIFO even if other keys are depressed.



Figure 8.3 Example of 3 keys being pushed simultaneously

In the example as shown in Figure 8.3, the debounce circuit starts by Key 1, and checks if the key is still down after one debounce cycle. If it is, Key 1 is recognized and Key 2 is ignored not to be depressed for one debounce cycle.

#### 8.3 SPECIAL ERROR MODE (N-KEY ROLLOVER)

This mode is set if the E bit of the End Interrupt/error Mode Set command is programmed to "1". In the normal N-Key Rollover Mode, the key information is entered to the FIFO according to the key scan timing even if a simulataneous multiple depression occures during one debounce cycle. In the Special Error Mode, if a simulataneous multiple depression occurs during one debounce cycle, sets the error flag (the S/E bit of the FIFO status word) to "1". This flag prevents any further writing into the FIFO and will set interrupt request (IRQ). The S/E bit is cleared if the normal Clear command is written with  $C_F = 1$ .

## 8.4 SENSOR MATRIX MODE

In Sensor Matrix Mode, the debounce circuit does not operate. The status of the sensor switch is inputted directly to the Sensor RAM. The MPU can know a validated closure in the keyboard, however this mode has such advantage that the MPU knows how long the sensor was closed and when it was released.

If there is any change in the sensor value at the end of the sensor matrix scan, the IRQ line goes high. The IRQ line is cleared by the first data read if the Auto-increment flag is "0" or by the End Interrupt/Error Mode Set command if AI = 1.

### 8.5 STROBE INPUT MODE

In Strobe Input Mode, the debounce circuit does not operate. The data is inputted into the FIFO from the return lines at the rising edge of CNTL/STB Signal. When the data is entered into the FIFO, the IRQ line goes high.

The functions of the FIFO and the FIFO status in this mode are same as those in the keyboard mode.

# 9. DATA FORMAT

## 9.1 KEYBOARD MODE

| DB7  | DB6   | DB <sub>5</sub> | DB4  | DB <sub>3</sub> | $DB_2$ | DB <sub>1</sub> | DB <sub>0</sub> |
|------|-------|-----------------|------|-----------------|--------|-----------------|-----------------|
| CNTL | SHIFT |                 | SCAN |                 | F      | RETURN          | 1               |

In this mode, the Data Format of the character entered into the FIFO is as follows. The MSB is the status of CNTL/STB line and the next MSB shows the status of SHIFT line. The next three bits are from the scan counter and indicate the row the key was found in. The last three bits are from the column counter and indicate to which return line the key was connected.

## 9.2 SENSOR MATRIX MODE

| DB7 | DB6             | DB <sub>5</sub> | DB4 | DB3             | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----------------|-----------------|-----|-----------------|-----------------|-----------------|-----------------|
| RL7 | RL <sub>6</sub> | RL <sub>5</sub> | RL4 | RL <sub>3</sub> | RL <sub>2</sub> | RL <sub>1</sub> | RL <sub>0</sub> |

In this mode, the data on return lines is inputted in the row of the Sensor RAM in order according to the scan. The data is entered even if there is no change in the status of the sensor matrix switches. Each switch position maps to a Sensor RAM position. CNTL and SHIFT signals are ignored.

## 9.3 STROBE INPUT MODE

| DB7 | DB6             | DB <sub>5</sub> | DB4 | DB3             | DB <sub>2</sub> | DB <sub>1</sub> | DB <sub>0</sub> |
|-----|-----------------|-----------------|-----|-----------------|-----------------|-----------------|-----------------|
| RL7 | RL <sub>6</sub> | RL <sub>5</sub> | RL4 | RL <sub>3</sub> | RL <sub>2</sub> | RL1             | RL <sub>0</sub> |

## 10. INTERFACE WITH DISPLAY

## 10.1 LEFT ENTRY

In Left Entry mode, address 0 of the Display RAM is the left-most side of the display and address 15 (address 7 in the case of 8-character display) is the right-most side. When characters are inputted onto the Display RAM with the auto-increment mode from address 0 of the display RAM, Characters are filled from the left-most position of the display. The 17th (or 9th) character is placed in the left-most position again. Address of the display RAM corresponds directly to each display position of the display, and so its position does not change every entry.



## 10.2 RIGHT ENTRY

In Right Entry, the first entry if from the right-most position. Address of the Display RAM does not correspond to the display position.

|            |    |   |   |               |    | ← [ | Display | RAM Addres  | s →          |               |                  |              |                 |            |   |        |
|------------|----|---|---|---------------|----|-----|---------|-------------|--------------|---------------|------------------|--------------|-----------------|------------|---|--------|
|            | 1  | 2 |   |               | 14 | 15  | 0       |             | 0            | 1             | 2                | 3            | 4               | 5          | 6 | 7      |
| 1st entry  |    |   |   | ····· <u></u> |    |     | 1       | 1st entry   |              |               |                  |              |                 |            |   | 1      |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            | _2 | 3 |   |               | 15 | 0   | 1       |             | 2            | 3             | 4                | 5            | 6               | 7          | 0 | 1      |
| 2nd entry  |    |   | L |               |    | 1   | 2       | 2nd entry   | 1            | 2             |                  |              |                 |            | 1 | 2      |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            | 3  | 4 |   |               | 0  |     | 2       | Command     | 2            | 3             | 4                | 5            | 6               | 7          | 0 | 1      |
| 3rd entry  |    |   | L | <del></del>   | 1  | 2   | 3       | write       | L            |               |                  |              |                 |            | 1 | 2      |
|            |    |   |   |               |    |     |         | (10010101)  | Righ<br>with | t Ent<br>Auto | ry fra<br>5-incr | m Ac<br>emer | ldres:<br>nt mc | s 5<br>ode |   |        |
|            | 0  | 1 |   |               | 13 | 14  | 15      |             | 3            | 4             | 5                | 6            | 7               | 0          | 1 | 2      |
| 16th entry | 1  | 2 | T |               | 14 | 15  | 16      | 3rd entry   |              |               | 3                |              |                 | 1          | 2 |        |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            | 1  | 2 |   |               | 14 | 15  | 0       |             | 4            | 5             | 6                | 7            | 0               | 1          | 2 | 3      |
| 17th entry | 2  | 3 |   |               | 15 | 16  | 17      | 4th entry   |              | 3             | 4                |              | 1               | 2          |   |        |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            | 2  | 3 |   |               | 15 | 0   | 1       |             | 5            | 6             | 7                | 0            | 1               | 2          | 3 | 4      |
| 18th entry | 3  | 4 |   |               | 16 | 17  | 18      | 5th entry   | 3            | 4             | 5                | 1            | 2               |            |   |        |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            |    |   |   |               |    |     |         |             | 6            | 7             | 0                | 1            | 2               | 3          | 4 | 5      |
|            |    |   |   |               |    |     |         | 6th entry   | 4            | 5             | 6                | 2            |                 |            |   | 3      |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            |    |   |   |               |    |     |         |             | 2            | 3             | 4                | 5            | 6               | 7          | 0 | 1      |
|            |    |   |   |               |    |     |         | 10th entry  | 8            | 9             | 10               | 3            | 4               | 5          | 6 | 7      |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   |        |
|            |    |   |   |               |    |     |         | 11th anti-  | 3            | 4             | 5                | 6            | 7               | 0          | 1 | 2      |
|            |    |   |   |               |    |     |         | i ith entry | 9            | 10            | 11               | 4            | 5               | 6          |   | 8      |
|            |    |   |   |               |    |     |         |             |              |               |                  |              |                 |            |   | 050489 |

# **11. ELECTRIC CHARACTERISTICS**

## 11.1 ABSOLUTE MAXIMUM RATINGS

| SYMBOL           | ITEM                                                             | RATING         | UNIT |
|------------------|------------------------------------------------------------------|----------------|------|
| V <sub>CC</sub>  | $V_{CC}$ Supply Voltage (with respect to GND (V <sub>SS</sub> )) | – 0.5 to + 7.0 | V    |
| VIN              | Input Voltage (with respect to GND ( $V_{SS}$ ))                 | -0.5 to +7.0   | V    |
| Vout             | Output Voltage (with respect to GND (V <sub>SS</sub> ))          | - 0.5 to + 7.0 | V    |
| PD               | Power Dissipation                                                | 1              | W    |
| T <sub>sol</sub> | Soldering Temperature (soldering time 10 sec)                    | 260            | °C   |
| T <sub>stg</sub> | Storage Temperature                                              | – 65 to + 150  | °C   |
| T <sub>opr</sub> | Operating Temperature                                            | 0 to 70        | °C   |

050489

# 11.2 D.C. ELECTRICAL CHARACTERISTICS (Ta = 0 to 70°C, $V_{CC}$ = 5V ± 10%, $V_{SS}$ = 0V)

| SYMBOL           | PARAMETER                                              | CONDITIONS                     | MIN.  | TYP. | MAX.  | UNIT |
|------------------|--------------------------------------------------------|--------------------------------|-------|------|-------|------|
| V <sub>IL1</sub> | Input Low Voltage (RL <sub>0</sub> ~RL <sub>7</sub> )  |                                | - 0.5 |      | 1.4   | V    |
| V <sub>IL2</sub> | Input Low Voltage (Others)                             |                                | - 0.5 |      | 0.8   | V    |
| V <sub>IH1</sub> | Input High Voltage (RL <sub>0</sub> ~RL <sub>7</sub> ) |                                | 2.2   |      |       | V    |
| V <sub>IH2</sub> | Input High Voltage (Others)                            |                                | 2.0   |      |       | V    |
| V <sub>OL</sub>  | Output Low Voltage                                     | I <sub>OL</sub> = 2.2mA        |       |      | 0.45  | V    |
| V <sub>OH1</sub> | Output High Voltage (IRQ)                              | I <sub>OH</sub> = -100μA       | 3.5   |      |       | V    |
| V <sub>OH2</sub> | Output High Voltage (Others)                           | l <sub>OH</sub> = -400μA       | 2.4   |      |       | V    |
|                  | Input Leak Current                                     | $V_{IN} = V_{CC}$              |       |      | + 10  |      |
| IL1              | (SHIFT, CNTL, RL <sub>0</sub> ~RL <sub>7</sub> )       | V <sub>IN</sub> = 0V           |       |      | - 100 | μА   |
| I <sub>IL2</sub> | Input Leak Current (Others)                            | $0V \leq V_{IN} \leq V_{CC}$   |       |      | ±10   | μA   |
| IOFL             | Output Leak Current                                    | $0.45V \le V_{OUT} \le V_{CC}$ |       |      | ± 10  | μA   |
| lcc              | Supply Current                                         |                                |       |      | 120   | mA   |

050489

### 11.3 INPUT CAPACITY

| SYMBOL | PARAMETER       | CONDITION                          | MIN. | TYP. | MAX. | UNIT |
|--------|-----------------|------------------------------------|------|------|------|------|
| CIN    | Input Capacity  | f <sub>c</sub> = 1MHz              |      | 5    | 10   | pF   |
| COUT   | Output Capacity | Pins returned to V <sub>SS</sub> . |      | 10   | 20   | рF   |

| SYMBOL           | PARAMETER                                           | TEST CONDITIONS | MIN. | TYP. | MAX. | UNIT |
|------------------|-----------------------------------------------------|-----------------|------|------|------|------|
| t <sub>AR</sub>  | Address Set up Time ( $\overline{RD} \downarrow$ )  |                 | 0    |      |      | ns   |
| t <sub>RA</sub>  | Address Set up Time ( $\overline{RD} \uparrow$ )    |                 | 0    |      |      | ns   |
| t <sub>RR</sub>  | RD Pulse Width                                      |                 | 250  |      |      | ns   |
| t <sub>RD</sub>  | Valid Data ( $\overline{RD} \uparrow$ )             | $C_L = 150 pF$  |      |      | 150  | ns   |
| t <sub>AD</sub>  | Address to Valid Data                               | $C_L = 150 pF$  |      |      | 250  | ns   |
| t <sub>DF</sub>  | Data Floating ( $\overline{\text{RD}} \uparrow$ )   |                 | 10   |      | 100  | ns   |
| t <sub>RCY</sub> | Read Cycle Time                                     |                 | 1    |      |      | μs   |
| t <sub>AW</sub>  | Address Set up Time ( $\overline{WR}\downarrow$ )   |                 | 0    |      |      | ns   |
| t <sub>WA</sub>  | Address Hold Time ( $\overline{WR} \uparrow$ )      |                 | 0    |      |      | ns   |
| tww              | WR Pulse Width                                      |                 | 250  |      |      | ns   |
| t <sub>DW</sub>  | Data Set up Time (₩R↑)                              |                 | 150  |      |      | ns   |
| t <sub>WD</sub>  | Data Hold Time ( $\overline{\mathrm{WR}}\uparrow$ ) |                 | 0    |      |      | ns   |
| tow              | CLK Pulse Width                                     |                 | 120  |      |      | ns   |
| t <sub>CY</sub>  | Clock period                                        |                 | 320  |      |      | ns   |

# 11.4 A.C. ELECTRICAL CHARACTERISTICS (Ta = 0 to 70°C, $V_{CC}$ = 5.0V ± 10%, $V_{SS}$ = 0V)

# 12. TIMING DIAGRAM



Figure 12.1 Read Timing















Figure 12.5 Example of Display

# 13. EXTERNAL DIMENSION

## 13.1 40 PIN DIP EXTERNAL DIMENSION

DIP40-P-600



050489

Note: Each lead pitch is 2.54mm, and all the leads are located within  $\pm 0.25$ mm from their theoritical positions with respect to No.1 and No.40 leads.

# 14. EXAMPLE OF APPLICATION CIRCUIT



Figure 14.1 Example of Application Circuit

# CMOS PROGRAMMABLE PERIPHERAL INTERFACE

# TMP82C255AN-2 / TMP82C265AF-2 TMP82C255AN-10 / TMP82C265AF-10

# 1. GENERAL DESCRIPTION AND FEATURES

The TMP82C255A/TMP82C265A is a CMOS high speed programmable input/output interface with six 8-bit I/O ports. The function is almost equivalent to TMP82C55A $\times$ 2. The TMP82C265A has the function that ports state are selectable immediately after reset by hardware either in input state or output state.

The TMP82C255A has not this function.

The TMP82C255A/TMP82C265A is fabricated using Toshiba's CMOS Silicon Gate Technology.

- (1) 48 programmable I/O terminals (8 bit  $\times$  6 ports)
- (2) The ports of TMP82C265A are capable to set to output after reset by hardware.
- (3) High Speed Version (TRD=100ns MAX : TMP82C255AN-10/TMP82C265AF-10)
- (4) Low power consumption 3mA. Typ.  $10\mu A. \ MAX. \ (@5V \ stand-by)$
- (5) Three operation modes (Mode 0, Mode 1, Mode 2)
- (6) Bit set/reset capability ( $PC_{00}$  to  $PC_{07}$ ,  $PC_{10}$  to  $PC_{17}$ )
- (7) All ports are capable of driving darlington transistors -2.5mA. Typ. @VEXT=1.5V, REXT=1.1kΩ
- (8) Extended operating temperature :  $-40^{\circ}$ C to  $+85^{\circ}$ C
- (9) Two packages

| TMP82C255AN | 64 PIN Shrink DIP        |
|-------------|--------------------------|
| TMP82C265AF | 80 PIN Mini Flat Package |



MPU85-317

050489

TMP82C255A/TMP82C265A

TOSHIBA

ω

TMP82C255A/TMP82C265A



MPU85-318

DB7~ DB0 RD  $\overline{WR}$  RESET A<sub>0</sub> A<sub>1</sub>  $\overline{CS1}$  SEL<sub>1</sub>  $\overline{CS0}$  SEL<sub>0</sub> GND Vcc READ WRITE CONTROL LOGIC DATA BUS BUFFER BLOCK-0 BLOCK-1 GROUP B GROUP A GROUP B GROUP A CONTROL CONTROL CONTROL CONTROL INTERNAL 8-BIT BUS GROUP B GROUP B GROUP A GROUP A PORT C PORT C PORT C PORT B PORT C PORT A PORT B PORT A 6 6 ò ò 0 õ Ô 0 PC<sub>13</sub>~ PC<sub>10</sub> PA17~ PA10 PC<sub>03</sub>~ PC<sub>00</sub> PB<sub>07</sub>~ PB<sub>00</sub> PC<sub>07</sub>~ PC<sub>04</sub> PA07~ PA00 PB17~ PC17~ PB<sub>10</sub> PC<sub>14</sub> 050489

TMP82C265A

MPU85-319

# 4. PIN NAMES AND PIN FUNCTIONS

| Pin Name                           | Number<br>of Pin | Input/Output<br>3-state | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------|------------------|-------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D7~D0                              | 8                | l/O<br>3-state          | 3-state bidirectional 8-bit data bus. Used for data transfer with MPU. Also, used for transfer of control words to this device and status information from this device.                                                                                                                                                                                                                                                                                                                   |
| PA07~PA00                          | 8                | I/O                     | There are two 3-state 8-bit I/O Port named PA0 and PA1. Operation                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PA17~PA10                          | 8                | 3-state                 | A contains the output latch buffer and input latch.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PB07~PB00                          | 8                | I/O                     | There are two 3-state 8-bit I/O Port named PB0 and PB1. Operation                                                                                                                                                                                                                                                                                                                                                                                                                         |
| PB <sub>17</sub> ~PB <sub>10</sub> | 8                | 3-state                 | A contains the output latch buffer and input latch.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| PC <sub>07</sub> ~PC <sub>00</sub> | 8                | I/O                     | There are two 3-state 8-bit I/O Port named PC0 and PC1. Operation mode and input/output configuration are defined by software. Port C can be divided into two 4-bit ports by the mode control and also,                                                                                                                                                                                                                                                                                   |
| PC <sub>17</sub> ~PC <sub>10</sub> | 8                | 3-state                 | used as the control signal for Port A and Port B. In this case, each 3 bits of $PC_{00}$ to $PC_{02}$ and $PC_{10}$ to $PC_{12}$ are used for Port B control and each 5 bits of $PC_{03}$ to $PC_{07}$ and $PC_{13}$ to $PC_{17}$ for Port A control.                                                                                                                                                                                                                                     |
| <u>CS0</u>                         | 1                | Input                   | Chip select input. When the terminal $\overline{CS0}$ is at "L" level, data transfer between BLOCK-0 and MPU is possible. And when the terminal $\overline{CS1}$ is at "L" level, data transfer between BLOCK-1 and                                                                                                                                                                                                                                                                       |
| CS1                                | 1                |                         | MPU is possible. At "H" level, the data bus is placed in the high impedance state and control from the processor is ignored.                                                                                                                                                                                                                                                                                                                                                              |
| A <sub>0</sub> , A <sub>1</sub>    | 2                | Input                   | Used for selecting Port A, B, C and the control registers. Normally, this terminal is connected to low order 2 bits of the address bus.                                                                                                                                                                                                                                                                                                                                                   |
| RD                                 | 1                | Input                   | Read signal. Only the TMP82C265A has this terminal. When this terminal is at "L" level, data or status information in this device is transferred to MPU.                                                                                                                                                                                                                                                                                                                                  |
| WR                                 | 1                | Input                   | Write signal. Only the TMP82C265A has this terminal. When this terminal is at "L" level, data or control word is written into this device from MPU.                                                                                                                                                                                                                                                                                                                                       |
| R/₩                                | 1                | Input                   | READ/WRITE signal. Only TMP82C255A has this terminal. When the terminal $\overline{CS0}$ or $\overline{CS1}$ is at "L" level, if this terminal is at "H" level, data or status information in this device is transferred to MPU. If this terminal is at "L" level, data or control word is written into this device from MPU.                                                                                                                                                             |
| SEL <sub>O</sub>                   | 1                | land                    | Only the TMP82C265A has these terminals. When SEL <sub>0</sub> or SEL <sub>1</sub> is a "H" level, the ports are set to input state after reset, when it is a "L" level, the ports are set to output state after reset. If the terminals is                                                                                                                                                                                                                                               |
| SEL1                               | Input            |                         | at "L" level, the function is only capable to set to output state in<br>mode 0. BLOCK-0 ports of block diagram is controled by SEL <sub>0</sub> .<br>BLOCK-1 ports of block diagram is controled by SEL <sub>1</sub> .                                                                                                                                                                                                                                                                    |
| RESET                              | 1                | Input                   | When this terminal is at "H" level, all internal registeres including<br>the control register are cleared, and the function turn out input<br>state in mode 0 for the TMP82C55A and TMP82C265A with SEL <sub>0</sub> or<br>SEL <sub>1</sub> "H" level. THe function turn out output state in mode 0 for the<br>TMP82C265A with SEL <sub>0</sub> or SEL <sub>1</sub> "L" level. Each BLOCK of<br>TMP82C265A is capable to set to different mode by SEL <sub>0</sub> and SEL <sub>1</sub> . |

| Pin Name        | Number<br>of Pin | Input/Output<br>3-state | Function |
|-----------------|------------------|-------------------------|----------|
| Vcc             | 1                | Power supply            | 5V       |
| V <sub>SS</sub> | 1                | Power supply            | GND      |
|                 |                  |                         | 050489   |

MPU85-321

### 5. DESCRIPTION OF BASIC OPERATION

### 5.1 TMP82C255A FUNCTIONS AND FEATURES

The TMP82C255A is a programmable peripheral interface consisting of Block-0 and Block-1 each of which has 3 sets, total 6 sets of 8-bit ports (PA0, PB0, PC0, PA1, PB1 and PC1) each of which has 2 built-in control registers.

Block-0 and Block-1 have the independent chip select input terminals  $\overline{\text{CS0}}$  and  $\overline{\text{CS1}}$ , respectivery. Data buses D<sub>7</sub>-D<sub>0</sub>, address input terminals A<sub>1</sub> and A<sub>0</sub>, RESET input terminals, and  $R/\overline{W}$  terminal are commonly used by Block-0 and Block-1.

Read and Write functions are controlled by one  $R/\overline{W}$  terminal and therefore,  $\overline{RD}$  and  $\overline{WR}$  signals and address must be synthesized and connected to the  $R/\overline{W}$ ,  $\overline{CS0}$  and  $\overline{CS1}$  terminals.

Total 24 ports input/output terminals each of Block-0 and Block-1 are divided into 12bit group A and Group B. Group A consist of upper 4 bits of Ports A and Port C, while Group B consists of lower 4 bits of Port B and Port C. Each group is programmable independently by control word from MPU. Three operation modes are available; Mode 0, Mode 1 and Mode 2. In mode 0, it is programmable to use 28-bit input/output ports as the input or output port independently. In Mode 1, the input/output ports are divided into group A and Group B. In each group, 8 bits are used for the input or output port and the remaining 4 bits are used as the control signal. Mode 2 is applicable only to Group A and 12 bits are used for 8-bit two-way bus and 5-bit control signal. Further, when port C is used as the output port, any bit of port C can be set/reset. There are two control registers; one is used for mode setting and the other is used for bit seting/resetting. The control register cannot be read. Further, when the reset input becomes "H" level, the input/output internal registers are all reset and all the input/output terminals are placed in Mode 0 and input Mode (high impedance state).



Figure 5.1 Connecting example of TMPZ84C00A and TMP82C255A

In case of the TMP82C255, the read operation is controlled by the terminals  $\overline{CS0}$  or  $\overline{CS1}$  when the R/W terminals is at "H" level and therefore, there is no AC electrical characteristics for rise and fall of the  $\overline{RD}$  terminal but and fall of the  $\overline{CS0}$  or  $\overline{CS1}$  terminal are controlled.

The write opertion is controlled by the terminal  $\overline{CS0}$  or  $\overline{CS1}$  when the  $R/\overline{W}$  is at "L" level. Further, the maximum control of the setup time TWC of the  $\overline{CS0}$  or  $\overline{CS1}$  for fall of  $R/\overline{W}$  terminal and the hold time  $T_{WC}$  of the  $\overline{CS0}$  or  $\overline{CS1}$  for the rise of  $R/\overline{W}$  terminal is added. This is because the  $\overline{CS0}$  or  $\overline{CS1}$  terminal controls the read operation when the  $R/\overline{W}$  is at "H" level.

#### 5.2 TMP82C255A BASIC OPERATION

Basic operation of the TMP82C255A for BLOCK-0. PC0 are as shown in Table 5.1.

| <del>CS0</del> | RESET | A <sub>1</sub> | A <sub>0</sub> | R/W | Function                                            |
|----------------|-------|----------------|----------------|-----|-----------------------------------------------------|
| ×              | 1     | ×              | ×              | ×   | Set to all ports (six ports) input state in mode 0. |
|                |       |                |                |     | Ports terminals are in High Impedance state.        |
| 0              | 0     | 0              | 0              | 1   | Data Bus ← PAO                                      |
| 0              | 0     | 0              | 1              | 1   | Data Bus ← PB0                                      |
| · 0            | 0     | 1              | 0              | 1.  | Data Bus 🔶 PCO                                      |
| 0              | 0     | 0              | 0              | 0   | $PA_0 \leftarrow Data Bus$                          |
| 0              | 0     | 0              | 1              | 0   | $PB_0 \leftarrow Data Bus$                          |
| 0              | 0     | 1              | 0              | 0   | PC <sub>0</sub> ← Data Bus                          |
| 0              | 0     | 1              | 1              | 0   | Control register for BLOCK-0 $\leftarrow$ Data Bus  |
| 0              | 0     | 1              | 1              | 1   | Inhibition of combination                           |
| 1              | 0     | ×              | ×              | ×   | Non active                                          |

Table 5.1 Basic Operation for Block-0 of the TMP82C255A

050489

Basic Operation for BLOCK-1 of the TMP82C255A is equal to the one shown in Table 5.1. BLOCK-1 is selected when  $\overline{\text{CS1}}=0$ .

#### 5.3 TMP82C265A FUNCTION AND FEATURES

The TMP82C265A can be set to general mode when the terminal  $SEL_0$  or  $SEL_1$  is fixed at "H" level and to the output mode when it is fixed at "L" level.

In the general mode, the TMP82C265A has the functions similar to those of the TMP82C55A but for the  $\overline{WR}$  and  $\overline{RD}$  functions, the independent  $\overline{RD}$  and  $\overline{WR}$  terminals are provided as in the former TMP82C255A unlike R/W 1 terminal in the TMP82C255A. Therefore, the TMP82C265A operates when connected in the same connecting method as before.

In the output mode, all ports of the TMP82C265A are set in "L" output state in mode 0 after reset. Further, even when the write operation is made in any mode, the ports are set in output state in mode 0, and "L" level signals are output from the ports.

### 5.4 TMP82C265A BASIC OPERATION

Basic operation of the TMP82C265A in the general mode (the terminal  $SEL_0$ - $SEL_1$  is "L" level) is equal to that of the TMP82C255A.

Basic operation for BLOCK-0 of the TMP82C265A  $\,$  in the output only mode (SEL\_0: "L" level) is as shown in Table 5.2.

| SEL <sub>0</sub> | CS0 | RESET | D <sub>7</sub> | A <sub>1</sub> | A <sub>0</sub> | RD | WR | Function                                                               |
|------------------|-----|-------|----------------|----------------|----------------|----|----|------------------------------------------------------------------------|
| 0                | ×   | 1     | ×              | ×              | ×              | ×  | ×  | Set to PA0, PB0 and PC0 ports "L" level output state in mode 0         |
| 0                | 0   | 0     | 1              | 1              | 1              | 1  | 0  | PA0, PB0 and PC0 ports "L" level output state in<br>mode 0 set command |
| ×                | 0   | 0     | 0              | 1              | 1              | 1  | 0  | Bit set/reset control                                                  |
| $\triangle$      | 0   | 0     | ×              | 0              | 0              | 1  | 0  | PA0 ← Data Bus                                                         |
|                  | 0   | 0     | ×              | 0              | 1              | 1  | 0  | PB0 ← Data Bus                                                         |
|                  | 0   | 0     | ×              | 1              | 0              | 1  | 0  | PC0 ← Data Bus                                                         |
| $\triangle$      | 0   | 0     | ×              | 0              | 0              | 0  | 1  | Data Bus $\leftarrow$ PAO (Read the terminal state)                    |
|                  | 0   | 0     | ×              | 0              | 1              | 0  | 1  | Data Bus 🛛 ← PBO (Read internal output latch)                          |
| $\square$        | 0   | 0     | ×              | 1              | 0              | 0  | 1  | Data Bus $\leftarrow$ PCO (Read internal output latch)                 |

Table 5.2 Output Mode Basic Operation for Block-0 of the TMP82C265A

050489

 $\bigtriangleup$  : The output only mode is maintained when  ${\rm SEL}_0$  is either in "L" or "H" level if set to the output state.

However, if the RESET terminal is set to "H" level or mode is written when  ${\rm SEL}_0$  is at "H" level, the output mode is changed to the general mode.

Basic operation of the TMP82C265A for Block-1 is equal to that shown in Table 5.2 but the control is made by the terminal SEL<sub>1</sub> and  $\overline{CS1}$ .

# 6. DETAILED OPERATIONAL DESCRIPTION

The operation of the TMP82C255A and TMP82C265A in the general made is described in detail. Further, the operation is described for Block-0. Block-1 has the same functions as those of Block-0 and therefore, it is omitted.

The operation of the TMP82C265A in the output mode is considered to be a special case of the description for the general mode provided below, in which the TMP82C265A has been set in the output state in mode 0 from immediately after reset irrespective of command input and therefore, the description is omitted here.

### 6.1 MODE SELECTION

There are three basic modes of operation that can be selected by control words.

Mode 0 - Basic I/O (Group A, Group B)

Mode 1 - Strobe input/Strobe output(Group A, Group B)

Mode 2 - Two-way bus(Port A only)

Operation modes for Group A and Group B can be independently defined by the control word from the MPU. If  $D_7$  is set to "1" in writing a control word into the PPI, on operation mode is selected, while of  $D_7$ = "0", the set/reset function for Port C is selected.

## 6.1.1 Control Word to Define Operation Mode

Figure 6.1 shows the control words to define operation mode of the TMP82C255A/ TMP82C265A.



050489

Figure 6.1 Control Word for Mode Selection

### 6.1.2 Port C Bit Set/Reset Control Word

Any bit of 8 bits of Port C can be set/reset by Port C bit set/reset control word. Figure 6.2 shows the Port C bit set/reset control word.



Figure 6.2 Control Word for Bit Set/Reset

## 6.2 OPERATION MODES

## 6.2.1 Mode 0 (Basic I/O)

This functional configuration is used for simple input or output operations. No 'handshaking' is required and data is simply written to or read from a specified part. Output data to the ports from MPU are latched out but input data from the ports are not latched.

In Mode 0, 24 I/O terminals are divided into four groups of Port A (8 bits), Port B (8 bits), high order 4 bits of Port C and low order 4 bits of Port C. Each port can be programmed to be input or output. The configuration of each port are determined according to the contents of Bit 4  $(D_4)$ , 3  $(D_3)$ , 1  $(D_1)$  and 0  $(D_0)$  of the control word for mode selection.

The I/O configuration of each port in Mode 0 are shown in Table 6.2.

| $ \begin{array}{ c c c c c c c c c c c c c c c c c c c$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | ort C                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------|
| 0      0      0      0      Out      In      Out       | <sub>3</sub> ~PC <sub>00</sub> ) |
| 0      0      0      1      Out      Out      Out      Out      In      Out        0      0      1      0      Out      Out      Out      In      In </td <td>Dut</td>                                           | Dut                              |
| 0      0      1      0      Out      Out      In      0        0      0      1      1      Out      Out      In      0        0      1      0      0      Out      In      Out      In        0      1      0      0      Out      In      Out      0        0      1      0      1      Out      In      Out      0        0      1      1      0      Out      In      In      0        0      1      1      Out      In      In      In      0        0      1      1      Out      In      In      In      0        1      0      0      In      In      In      In      0      0                                                                                                                                                                                                                                                                                                            | n                                |
| 0      0      1      1      Out      Out      In        0      1      0      0      Out      In      Out      Out <td>Dut</td> | Dut                              |
| 0      1      0      0      Out      In      <                                                  | n                                |
| 0      1      Out      In      Out        0      1      1      0      Out      In      In      In        0      1      1      0      Out      In      In      In      In        0      1      1      1      Out      In      In      In        1      0      0      0      In      Out      Out      Out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Dut                              |
| 0      1      1      0      Out      In      In      In        0      1      1      1      Out      In                                                                   | n                                |
| 0 1 1 1 Out In In<br>1 0 0 0 In Out Out 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Dut                              |
| 1 0 0 0 in Out Out 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | In                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Dut                              |
| 1 0 0 1 In Out Out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | n                                |
| 1 0 1 0 in Out in 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Dut                              |
| 1 0 1 1 In Out In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | In                               |
| 1 1 0 0 in In Out 9                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Dut                              |
| 1 1 0 1 In In Out                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | n                                |
| 1 1 1 0 In In In 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Dut                              |
| 1 1 1 1 In In In                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | n                                |

Table 6.2 Port definition in Mode 0

## 6.2.2 Mode 1 (Strobe I/O)

In Mode 1, input/output of port data is performed in conjunction with the srtobe signals or 'handshaking' signals. Port C is used to control Port A or Port B.

The basic operatings in Mode 1 are as follows:

- Mode 1 can be set for two groups of Group A and Group B.
- Each group consist of 8-bit data port and 4-bit control/data port.
- The 8-bit data port can be set as input or output port.
- The control/data port is used as control or status of the 8-bit data port.
- (1) When used as the input port in Mode 1 :
  - <u>STB</u> (Strobe Input)

At "0", input data is loaded in the internal input latch in the port.

In this case, a control signal from MPU is not concerned and data is input from the port any time. This data is not read out on the data bus unless MPU executes an input instruction.

• IBF (Input Buffer Full F/F Output)

When data is loaded in the internal input latch from the port, this output is set to "1". IBF is set ("1") by  $\overline{\text{STB}}$  input being reset and is reset ("0") by the rising edge of  $\overline{\text{RD}}$  input.

• INTR (Interrupt Request Output)

Used for the interrupt process of data loaded in the internal input latch. When  $\overline{\text{STB}}$  input is at "0" if INTE (INTE flag) in the PPI is in the enabled state ("1"), IBF is set to "1". INTR is set to "1" immediately after the rising edge of this  $\overline{\text{STB}}$  input and reset to "0" by the falling edge of  $\overline{\text{RD}}$  input.

The INTE flags of Group A and Group B are controlled as follows:

INTEA – Control by bit set/reset of  $PC_{04}$ 

INTEB - Control by bit set/reset of  $PC_{02}$ 

- (2) When used as the output port in Mode 1:
  - <u>OBF</u> (Output Buffer Full F/F Output)

This is a flag which shows that MPU has written data into a specified port.  $\overline{OBF}$  is set to becomes "0" at the rising edge of  $\overline{WR}$  signal and is set to "1" at the falling edge of  $\overline{ACK}$  (Acknowledge input) signal.

• <u>ACK</u> (Acknowledge Input)

 $\overline{\text{ACK}}$  signal is sent to the PP1 as a response from a peripheral device that received data from the port.

• INTR (Interrupt Request Output)

When a peripheral device received data from MPU, INTR is set to "1" and the interrupt is requested to MPU. If  $\overline{ACK}$  signal is received when INTE flag is in the enable state,  $\overline{OBF}$  is set to "1" and INTR signal becomes "1" immediately after the rising edge of  $\overline{ACK}$  signal. Further, INTR is reset at the falling edge of  $\overline{WR}$  signal when data is written into the PPI by MPU.

The INTE flags of Group A and Group B are controlled as follows:

INTEA – Control by bit set/reset of PC<sub>06</sub>

INTEB – Control by bit set/reset of  $PC_{02}$ 











#### 6.2.3 Mode 2 (Strobed Bidirectional Bus I/O)

In this mode, Port A is used as 8 bits bidirectional bus for data transfer with a peripheral device. This mode is applicable only to Group A, which consists of an 8-bit bidirectional bus (Port A 8-bit) and 5-bit control signals (high order 5 bits of Port C). The bidirectional bus (Port A) has both the internal input and output registers. When group A is set in Mode 2, Group B can be set independently. There are 5 control signals as follows when Group A is used in Mode 2.

• OBF (Output buffer Full F/F Output)

When MPU writes data into of Port A,  $\overline{OBF}$  is set to "0" to inform a peripheral device that the PPI is ready to output data. However, Port A is kept in the floating (high impedance) state until  $\overline{ACK}$  input signal is received.

• ACK (Acknowledge Input)

When ACK signal is set to "0", the data of the 3-state output buffer of Port A is send out. If ACK signal is at "1", Port A is in the high impedance state.

• <u>STB</u> (Strobe Input)

When  $\overline{\text{STB}}$  input is set to "0", the data from peripheral devices are held in the input latch. When the active  $\overline{\text{RD}}$  signal is input into the PPI, the latched input data are output on the system data bus (D<sub>7</sub>-D<sub>0</sub>).

• IBF (Input Buffer Full F/F Output)

When data from peripheral devices are held in the input latch, IBF is set to "1".

• INTR (Interrupt Request Output)

INTR is the output to request the interrupt to MPU and its function is the same as that in Mode 1. There are two interrupt enable flip-flop (INTE), INTE1 corresponds to INTEA in Mode 1 output and INTE2 to INTEA in Mode 1 input.

- INTE2 Used to generate INTR signal in conjunction with IBF and  $\overline{STB}$  singals, and is controlled by PC<sub>04</sub> bit set/reset.

Figure 6.7 shows the operating example and the timing diagram in Mode 2.



Figure 6.7 Oerating example in Mode 2








MPU85-334

### 6.2.4 Precautions for use in Mode 1 and 2

When used in Mode 1 and 2, bits which are not used as control or status in Port C can be used as follow.

If porgrammed as the input, they are accessed by normal Port C read.

If porgrammed as the output, high order bits of Port C ( $PC_{07}$ - $PC_{04}$ ) are accessed using the bit set/reset function. As to low order bits of Port C ( $PC_{03}$ - $PC_{00}$ ), in additions to access by the bit set/reset function, 3 bits only can be accessed by normal writing.

### 6.3 READING PORT C STATUS

When Port C is used as the control port, that is, when Port C is used in Mode 1 or Mode 2, the status information of the control word can be read out by a normal read operation of Port C.

| Data Mode     | D <sub>7</sub> | D <sub>6</sub> | D <sub>5</sub> | D4    | D <sub>3</sub> | D <sub>2</sub>  | D1   | D <sub>0</sub> |
|---------------|----------------|----------------|----------------|-------|----------------|-----------------|------|----------------|
| Mode 1 Input  | 1/0            | 1/0            | IBFA           | INTEA | INTRA          | INTEB           | IBFB | INTRB          |
| Mode 1 Output | OBFA           | INTEA          | 1/0            | 1/0   | INTRA          | INTEB           | OBFB | INTRB          |
| Mode 2        | OBFA           | INTE1          | IBFA           | INTE2 | INTRA          | By Group B Mode |      | ode            |

Table 6.3 Status Word Format of Port C

### 7. ELECTRICAL CHARACTERISTICS

### 7.1 ABSOLUTE MAXIMUM RATINGS

| Symbol           | ltem                         | Rating                   | Unit |
|------------------|------------------------------|--------------------------|------|
| V <sub>CC</sub>  | Supply Voltage               | -0.5~7.0                 | V    |
| V <sub>IN</sub>  | Input Voltage                | $-0.5 \sim V_{CC} + 0.5$ | V    |
| PD               | Power Dissipation            | 250                      | mW   |
| TSOLDER          | Soldring Temperature (10sec) | 260                      | °C   |
| T <sub>STG</sub> | Storage Temperature          | - 65~ + 150              | °C   |
| T <sub>OPR</sub> | Operating Temperature        | - 40~ + 85               | °C   |

050489

050489

### 7.2 DC ELECTRICAL CHARACTERISTICS

| Symbol           | ltem                                          | Test Condition                                                                 | Min.                  | Тур.    | Max.                  | Unit |
|------------------|-----------------------------------------------|--------------------------------------------------------------------------------|-----------------------|---------|-----------------------|------|
| VIL              | Input Low Voltage                             |                                                                                | - 0.5                 | —       | 0.8                   | V    |
| VIH              | Input High Voltage                            |                                                                                | 2.2                   | _       | V <sub>CC</sub> + 0.5 | V    |
| VOL              | Output Low Voltage                            | I <sub>OL</sub> = 2.5mA                                                        |                       | _       | 0.45                  | V    |
| V <sub>OH1</sub> | Output High Voltage                           | I <sub>OH</sub> = -400µА                                                       | 2.4                   | -       | -                     | V    |
| V <sub>OH2</sub> | Output High Voltage                           | I <sub>OH</sub> = - 100µА                                                      | V <sub>CC</sub> – 0.8 | —       | _                     | V    |
| IIL              | Input Leak Current                            | $0\!\leq\!V_{IN}\!\leq\!V_{CC}$                                                | —                     | —       | ± 10                  | μA   |
| I <sub>OL</sub>  | Output LeaK Current<br>(High Impedance State) | $0 \le V_{OUT} \le V_{CC}$                                                     | V <sub>cc</sub> – –   |         | ±10                   | μА   |
| Idar             | Darlington Drive<br>Current                   | V <sub>EXT</sub> = 1.5V<br>R <sub>EXT</sub> = 1.1kΩ                            | - 1.0                 | - 1.0 - |                       | mA   |
| Icc1             | Operating Supply<br>Current                   | I / O cycle Time<br>1µsec                                                      | - 3.0                 |         | 5.0                   | mA   |
| I <sub>CC2</sub> | Stand-by Supply<br>Current                    | $V_{IH} > V_{CC} - 0.2V$<br>$V_{IL} < 0.2V$<br>$\overline{CS} > V_{CC} - 0.2V$ |                       |         | 10                    | μА   |

### $TA = -40^{\circ}C \text{ to } + 85^{\circ}C, V_{CC} = 5V \pm 10\%, V_{SS} = 0V$

\* Total current of all darlington drive ports must not exceed 60mA.

### 7.3 CAPACITANCE

 $TA = 25^{\circ}C$ ,  $V_{CC} = V_{SS} = 0V$ 

| Symbol           | ltem              | Test Condition | Min. | Тур. | Max. | Unit |
|------------------|-------------------|----------------|------|------|------|------|
| C <sub>IN</sub>  | Input Capacitance | f = 1MHz       | _    | _    | 10   | pF   |
| C <sub>I/O</sub> | I/O Capacitance   | (*)            |      | -    | 20   | рF   |

(\*): All terminals except that to be measured should be earthed.

050489

### 7.4 AC ELECTRICAL CHARACTERISTICS (1/2)

 $TA = -40^{\circ}C \text{ to } + 85^{\circ}C, V_{CC} = 5V \pm 10\%, V_{SS} = 0V$ 

| Symbol           | Parameter                                                                                         | A   | - 2  | A - 10 |      | Unit |
|------------------|---------------------------------------------------------------------------------------------------|-----|------|--------|------|------|
| Symbol           |                                                                                                   |     | Max. | Min.   | Max. | Unit |
| t <sub>AR</sub>  | Address set-up time for $\overline{RD}$ fall                                                      | 0   | —    | 0      | -    | ns   |
| t <sub>RA</sub>  | Address hold time for $\overline{RD}$ rise                                                        | 0   | —    | 0      | -    | ns   |
| t <sub>RR</sub>  | RD pulse width                                                                                    | 160 | —    | 150    | —    | ns   |
| t <sub>RD</sub>  | Delay from $\overline{RD}$ fall to decided data output                                            |     | 140  | -      | 100  | ns   |
| t <sub>DF</sub>  | Time from $\overline{RD}$ rise to data bus floating                                               | 0   | 40   | 0      | 40   | ns   |
| t <sub>RV</sub>  | Time from $\overline{RD}$ or $\overline{WR}$ rise to next $\overline{RD}$ or $\overline{WR}$ fall | 200 | -    | 180    | -    | ns   |
| t <sub>AW</sub>  | Address set-up time for $\overline{WR}$ fall                                                      | 20  | _    | 20     | -    | ns   |
| t <sub>WA</sub>  | Address holding time for $\overline{WR}$ rise                                                     | 0   | _    | 0      |      | ns   |
| t <sub>WW</sub>  | WR pulse width                                                                                    | 120 | —    | 120    | -    | ns   |
| t <sub>DW</sub>  | Bus data set-up time for $\overline{W}R$ rise                                                     | 100 | _    | 100    | -    | ns   |
| t <sub>WD</sub>  | Bus data holding time for WR rise                                                                 | 20  | -    | 20     | -    | ns   |
| t <sub>WB</sub>  | Delay from $\overline{WR}$ rise to decided data output                                            | -   | 350  | —      | 350  | ns   |
| t <sub>IR</sub>  | Port data set-up time for $\overline{RD}$ fall                                                    | 0   | -    | 0      | —    | ns   |
| t <sub>HR</sub>  | Port data holding time for $\overline{RD}$ rise                                                   | 0   |      | 0      | —    | ns   |
| t <sub>AK</sub>  | ACK pulse width                                                                                   | 300 | -    | 300    | -    | ns   |
| ts⊤              | STB pulse width                                                                                   | 350 | —    | 350    |      | ns   |
| tps              | Port data set-up time for $\overline{STB}$ rise                                                   | 20  | -    | 20     | -    | ns   |
| t <sub>РН</sub>  | Port data holding time for STB rise                                                               | 150 | -    | 150    | -    | ns   |
| t <sub>AD</sub>  | Delat from $\overline{ACK}$ fall to decided data output Delay                                     | _   | 300  |        | 300  | ns   |
| t <sub>KD</sub>  | Time from ACK rise up to port<br>(Port in Mode 2) floating                                        | 25  | 250  | 20     | 250  | ns   |
| t <sub>WOB</sub> | Delay from $\overline{WR}$ rise to $\overline{OBF}$ fall                                          |     | 300  |        | 300  | ns   |
| t <sub>AOB</sub> | Delay from $\overline{ACK}$ fall to $\overline{OBF}$ rise                                         |     | 350  | —      | 350  | ns   |
| t <sub>SIB</sub> | Delay from $\overline{\text{STB}}$ fall to $\overline{\text{IBF}}$ rise                           |     | 300  | -      | 300  | ns   |

### AC ELECTRICAL CHARACTERISTICS (2/2)

| Sumbol           | Paramotor                                                                                        | A - 2 |      | A - 10 |      | Unit |
|------------------|--------------------------------------------------------------------------------------------------|-------|------|--------|------|------|
| Symbol           |                                                                                                  |       | Max. | Min.   | Max. | Unit |
| t <sub>RIB</sub> | Delay from RD fall to IBF rise                                                                   | -     | 300  |        | 300  | ns   |
| t <sub>RIT</sub> | Delay from RD fall to INTR fall                                                                  | -     | 400  | _      | 400  | ns   |
| t <sub>SIT</sub> | Delay from ACK rise to INTR rise                                                                 |       | 300  | _      | 300  | ns   |
| t <sub>AIT</sub> | Delay from ACK rise to INTR rise                                                                 | -     | 350  | -      | 350  | ns   |
| t <sub>WIT</sub> | Delay from $\overline{WR}$ rise to INTR fall                                                     | -     | 450  | -      | 450  | ns   |
| t <sub>AC</sub>  | Address set-up time for $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ fall                   | 0     | -    | 0      | -    | ns   |
| t <sub>CA</sub>  | Address hold time for $\overline{CSO}$ , $\overline{CSI}$ rise                                   | 0     |      | 0      | -    | ns   |
| t <sub>CC</sub>  | CSO, CSI pulse width                                                                             | 160   |      | 150    | —    | ns   |
| t <sub>CD</sub>  | Delay from $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ fall to decided data output         | _     | 140  | _      | 100  | ns   |
| t <sub>DFC</sub> | Time from $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ rise to data bus floating            | 0     | 40   | 0      | 40   | ns   |
| T <sub>CW</sub>  | $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ set-up time for R/ $\overline{\text{W}}$ fall  | -     | 0    |        | 0    | ns   |
| Twc              | $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ holding time for R/ $\overline{\text{W}}$ rise | -     | 50   |        | 50   | ns   |
| tıc              | Port data set-up time for $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ fall                 | 0     |      | 0      | -    | ns   |
| t <sub>HC</sub>  | Port data holding time for $\overline{\text{CSO}}$ , $\overline{\text{CSI}}$ rise                | 0     |      | 0      |      | ns   |
| t <sub>CIB</sub> | Delay from $\overline{CSO}$ , $\overline{CSI}$ fall to $\overline{IBF}$ rise                     | —     | 300  |        | 300  | ns   |
| t <sub>CIT</sub> | Dekay from CSO, CSI fall to INTR fall Delay                                                      |       | 400  |        | 400  | ns   |
| t <sub>RES</sub> | RESET pulse width                                                                                | 500   | —    | 500    | -    | ns   |

Note 1:

A-2 : TMP82C255AN-2, TMP82C265AF-2

A-10 : TMP82C255AN-10, TMP82C265AF-10

Note 2 :

Following AC specifications of TMP82C255A are applied to the logical AND timing between  $R/\overline{W}$  terminal and  $\overline{CS0}$  or  $\overline{CS1}$  terminal.

| Symbol          |                 |                 |                 |  |  |
|-----------------|-----------------|-----------------|-----------------|--|--|
| T <sub>AW</sub> | T <sub>WA</sub> | T <sub>DW</sub> | T <sub>WD</sub> |  |  |
| Т <sub>WB</sub> | T <sub>CW</sub> | Т <sub>WC</sub> |                 |  |  |

050489

050489

Note 3:

AC Measuring Point

### TOSHIBA

### 8.1 TMP82C255A TIMING DIAGRAM (1)



Figure 8.1 TMP82C255A Timing diagram (1)

MPU85-339







MPU85-340



Figure 8.1 TMP82C255A Timing diagram (3)

### TOSHIBA

### 8.2 TMP82C265A TIMING DIAGRAM (1)





Figure 8.2 TMP82C265A Timing diagram (1)





### TOSHIBA



Figure 8.2 TMP82C265A Timing diagram (3)

### **OUTLINE DRAWINGS** 9.

SDIP64-P-750



160289

Note: Each lead pitch is 1.78mm. All leads are located within 0.25mm of their trve longitudical position with respect to No.1 and No.64 leads.

TMP82C255A/TMP82C265A

### QFP80-P-1420

Unit : mm



### SALES SUBSIDIARIES

 
 Toshiba America Electronic Components, Inc.

 Inrine Head Office

 9775 Toido Way, Irvine, CA 92718, U.S.A.

 Tai:...(714) 455-2000. Fax: (714) 859-3963

 Eastern Areo Office

 25 Mail Road, Shi Floor,

 Burlington, MA 01803, U.S.A.

 Tei:...(817) 272-4392, 5548. Fax: (617) 272-3089

 South Eastern Regional Office

 Waterford Center 5555, Triangle Parkway

 She 300 Arcross, GA 30092, U.S.A.

 Tei:...(404) 368-0203. Fax: (404) 368-0075

 North Western Office
Waterford Center 5555, Triangle Partway Ste 300 Norcoss, GA 30092, U.S.A. Tel.: (404) 368-0203 Fax: (404) 368-0075 North Western Office 1220 Midas Way, Sunnyvale, CA 94086, U.S.A. Tel.: (408) 737-9844 Fax: (408) 737-9905 ASIC Marketing Office 1250 Midas Way, Sunnyvale, CA 94086, U.S.A. Tel.: (408) 733-3223 Fax: (408) 733-4539 South Western Regional Office 15521 Redhill Ave., Suite 205 Tustin, CA 92606, U.S.A. Tel.: (714) 259-0386 Fax: (714) 259-9439 Centre Area Office, 1250-Centre Area Office, 1260-Centre Area Office, 1260-Tel.: (704) 960-1500 Fax: (708) 945-1044 South Central Regional Office 777 East Cempbell Hd, Suite 550, Richardson, TX 75061, U.S.A. Tel.: (214) 400-0740 Fax: (214) 235-4114 Fishkill Sales Office Boce Raton Sales Office Boce Raton Sales Office Boce Raton Sales Office Boce Raton, FL 33432, U.S.A. Tel.: (301) 49-30-004 Fax: (305) 394-3006 Detroit Office Dio0 Prudential Town Center, Suite 2160, Southfield, MI 48075, U.S.A. Tel.: (313) 827-7700 Fax: (313) 827-4444 Portland Field Office 1700 NN 1679 Dace, Suite 240, Beavertown, OH 97006, U.S.A. Tel.: (300) 820-3018 Fax: (303) 629-0827 Martton, NJ 08053, U.S.A. Tel.: (609) 985-3737 Fax: (509) 596-8359

Toshiba Electronics Europe GmbH Düsseldorf Head Office Hansaallee 181, 4000 Düsseldorf 11, F.R. Germany Tel.: (0211) 5296-0 Fax: (0211) 5296-400 Telex: 8582685 Telex: 5582685 Liaison Offices Stuttgart: Vertriebsburo Baden-Wurttemberg Ettinger Str. 61 D-7250 Leonberg, F.R. Germany Tel: (07152) 21061-66 Fax: (07152) 27658 Telex: 7245706 Liaise Archellent: 22() München: Buro München Arabellastr. 33/v. 8000 München 81, F.R. Germany Tel.: (089) 928091-0 Fax: 089-9280942 Telex: 5-212363

Toshiba Electronics (UK) Limited Riverside Way, Camberley, Surrey GU 15 3YA, U.K. Tel.: 0276-694600 Fax: 0276-691583

Toshiba Electronics Scandinavia AB Gustavslundsvagen 141, 4th Floor S161 15 Bromma, Sweden Tel: 46-8-704 0900 Fax: 46-8-80 8459 Telex: 14169 TSBSTK S (Mailing Address: P.O. Box 15031 S-161 15 Bromma Sweden)

Toshiba Electronics France SARL Iosniba Liectronics France SARL Immeuble Robert Schumann, 3 Rue de Rome, 93561 Rosny-Sous-Bois Cedex Tel: (1) 48 94 20 20 Fax: (1) 48 94 51 15 Teles: 232 030

Toshiba Electronics Italiana S.R.L. Centro Direzionale Colleoni Palazzo Orione-Ingresso 3 (3º Piano) 2004 Agrate Brianza (Milano), Italy Tel.: 039-6057254 Fax: 039-6057252 Telex: 236423 SIAVBC

Toshiba Electronics España, S.A. Torres Heron Plaza Colón No. 2. Torre II. Planta 6-Pte-2, 28046 Madrid, Spain Tel.: (1) 53-25-846 Fax: (1) 41-91-266 Telex: 44672 TOSHE (E)

### Toshiba Electronics Taiwan Corp. Taipei Head Office

Br, Min Sheng Chan-kwo Building, 348-350 Min Sheng East Road Taipei, Taiwan Tel.: 02-502-9641 Fax: 02-503-7964 Telex: 26874 TETTP Telex: 25874 TETTP Kaohslung Office 16F-A Chung-Cheng Building No. 2 Chung-Cheng 3rd. 80027, Kaohsiung Tel.: (07) 241-0826 Fax: (07) 282-7446

Technic Bieterotics Asia, Ltd. Hong Kong Head Office 10th Floor, Sun Plaza, Canton Road, Tsimshatsui, Kowtoon, Hong Kong Tail: 3-721-8111 Fax: 3-739-8969 Telex: 33501 TSBEH HX Seoul Branch Office Room 1061, Chamber Building, 45, 4-KA Namdaemu-Ho, Chung-Ku, Seoul, Korea Tel: (2) 757-2472 - 4 Fax: (2) 757-2475 Singapore Branch Office 460 Alexandra Road #21-00, PSA Building, Singapore 0511 Tel:: 278 5252 Fax: 271 5155 Shanohal Branch Office Iei: 278 5252 Fax: 271 5155 Shanphai Branch Office Room 2612 26F, Rui Jin Building, 205 Mao Ming South Road, Shanghai, China Tei: 86-21-4334027 86-21-4334131 Fax: 86-21-433928 Bangkok Office B6: Thai Mac Town 210 South Cathor 2 8/F. Thai Wah Tower, 21/20 South Sathorn Road. Tungmahamek, Yannawa, Bangkok 10120, Thailand Tel.: (2) 240-9447 Fax: (2) 240-9446

### **OVERSEAS OFFICES**

### São Paulo<sup>.</sup>

40 Paulo: Toshiba Brasileira Representacoes Ltda. Av., Paulista, 807, 21 Andar Cito 2106, Cerqueira Cesar, Cep. 01311-São Paulo-S.P.-Brasil Tel.: 283-4511, 4714, 4964 Fax: (11) 251-4104

Beijing: Toshiba Corporation Beijing Office Room 1622/1624 Beijing Hotel, Dong Chang An Jie, Beijing, The People's Republic of China Tel: (01)55-7019 Telex: 22807 TOSPK CN Cable: TOSHIBA PEKING

### Guangzhou:

Toshiba Corporation Guangzhou Office Room 1161-1162 China Hotel, Office Tower, Liu Hua, Lu, Guangzhou, The People's Republic of China Tel.: (020)677420, 677800 Fax: (020)677427 Telex: 44585 TSBGZ CN Cable: TOSHIBA GUANGZHOU

### MANUFACTURING SUBSIDIARIES AND JOINT VENTURES

Toshiba America Electronic Components, Inc. Microelectronics Center 1220, Midas Way, Sunnyvale, CA 94086, U.S.A. Tel.: (408) 739-0560 Fax: (408) 746-0577 Telex: 346378

Toshiba Display Devices Inc. Westinghouse Circle, Horseheads, New York 14845, U.S.A. Tel.: (607) 796-3500 Fax: (607) 796-3564

### Industria Mexicana Toshiba, S.A. Calzada de Guadalupe, No. 303, Cuatitlan, Edo de Mexico, Mexico Tel.: 5-65-00-88 Telex: 017-72-560 Cable: Toshiba Mexico

Toshiba Semiconductor G.m.b.H. Grotrian-Steinweg Str. 10, 3300 Braunschweig, F.R. Germany Tel.: (0531) 31-0060 Fax: (0531) 31006139 Telex: 95286 TSCD

## Toshiba Electronics Malaysia Sdn. Bhd. osniba Liectronics Malaysia Sdn. Bhd. 42057 Telok Panglima, Grang, 15KM Klang-Banting Road, Kuala Langat Selangor, Malaysia Tel.: 03-352-6001-7 Fax: 03-352-6139 Telex: TOEL MA 39506 Telex: TOEL MA 39506 Penang Branch Office Lot 2.08 2nd Floor, Wisma Chocolate Products, 41 Adoo Sitte Lane Panany 10400, Malaysia Tel: 04-368523, 04-368529 Fax: 04-368515 Kuela Lumpur Branch Office 6th Floor, Main Tower Block, Wisma Mcis, Jalan Barat 46200 Petaling Jaya, Malaysia Tel: 03-765561 Fax: 03-7655409

Toshiba Display Devices (Thailand) Co., Ltd. 201 Vibhavadee Rangist Road, Ladyao Sub-district, Bangkhen District, Bangkok Tel: (2)513-4260 Fax: (2)513-4260

9003

The information in this guide has been carefully checked and is believed to be reliable, however Ine imormation in this guide has been careful or levels at to is believed to be reliable. Noween no responsibility can be assumed for inaccuraces that may not have been caught. All information in this guide is subject to change without prior notice. Furthermore Toshiba cannot assume responsibility for the use of any iconse under the guident nights of Toshiba or any third parties.

TOSHIBA CORPORATION INTERNATIONAL OPERATIONS-ELECTRONIC COMPONENTS

1-1, SHIBAURA 1-CHOME, MINATO-KU, TOKYO, 105-01, JAPAN Tel.: (03) 457-3495 Fax: (03) 451-0576 Telex: J22587



### TOSHIBA AMERICA ELECTRONIC COMPONENTS, INC.

### **REGIONAL SALES OFFICES**

### NORTHWEST REGION

1220 Midas Way Sunnyvale, CA 94086 TEL: (408) 737-9844 FAX: (408) 737-9905

### SOUTHWEST REGION

15621 Redhill Ave. Suite 205 Tustin, CA 92680 TEL: (714) 259-0368 FAX: (714) 259-9439 CENTRAL REGION One Parkway North Suite 500 Deerfield, IL 60015-2547 TEL: (708) 945-1500 FAX: (708) 945-1044 TWX: 29-7131

### SOUTHCENTRAL REGION 777 E. Campbell Road

777 E. Campbell Road Suite 650 Richardson, TX 75081 TEL: (214) 480-0470 FAX: (214) 235-4114 EASTERN REGION 25 Mall Road 5th Floor Burlington, MA 01803 TEL: (617) 272-4352 FAX: (617) 272-3089 TWX: 710-321-6730

### SOUTHEASTREGION

Waterford Centre 5555 Triangle Parkway Suite 300 Norcross, GA 30092 TEL: (404) 368-0203 FAX: (404) 368-0075

# TOSHIBA